uni-app简单模拟人脸识别

uni-app使用live-pusher简单模拟人脸识别页面样式

实现想法

公司的需求是模拟一个人脸识别,不用第三发插件,简单模拟样式即可。

基本思路是调起手机前置摄像头 ,再设置一个圆形的样式来达到一个基本样式

调起手机摄像头

看了官方的媒体组件,只有camera和live-pusher比较合适

camera不支持App,并且需要触发调用,不合符需求

所以只剩下live-pusher一个选择

引入组件,并基础设置后

javascript 复制代码
<live-pusher id="pusherId" 
			 ref="pusherRef" 
			 class="livePusher" 
             aspect="1:1"    // 宽高比例
             :whiteness="1"  // 美白
             :beauty="1"     // 美颜
             />

我们在页面上可以看见效果

不过这里需要注意一下,如果你是 nvue 页面,还需要手动调起一下摄像头

javascript 复制代码
onMounted(() => {
	const instance = getCurrentInstance() as ComponentInternalInstance;
    const pusherContext = uni.createLivePusherContext("pusherId", instance.ctx)
    pusherContext.startPreview() 
})

官方文档中写默认摄像头为前置,但此时显示的是后置摄像头,并且设置的默认前置也是不生效的,需要手动翻转一下

javascript 复制代码
onMounted(() => {
	// 获取当前组件实例
	const instance = getCurrentInstance() as ComponentInternalInstance;
    // 获取live-pusher上下文对象
    const pusherContext = uni.createLivePusherContext("pusherId", instance.ctx)
    // 翻转摄像头
    pusherContext.switchCamera()
})

设置圆形

这是一个令人头疼的问题

组件设置宽高为正方形后,设置了圆角属性不生效

尝试了nvue页面在父级元素画圆后设置溢出隐藏,也无济于事

最后添加了cover-img标签,用一张圆形的图片盖住四角达到的效果

javascript 复制代码
  <template>
	   <div class="face">
	     <view>拿起手机,眨眨眼</view>
	     <div class="pushContent">
	       <live-pusher id="pusherId" ref="pusherRef" class="livePusher" 
	                  aspect="1:1" :whiteness="1" :beauty="1" device-position="front"
	                  />
	       <cover-image class="pusherImg" src="/static/images/faceRadio.png" alt=""></cover-image>
	     </div>
	   </div>
  </template>
  <script lang="ts" setup>
  import { onMounted, ref, getCurrentInstance, type ComponentInternalInstance } from 'vue';

  const pusherRef = ref({} as UniHelper.LivePusherInstance)
  
  onMounted(() => {
    const instance = getCurrentInstance() as ComponentInternalInstance;
    const pusherContext = uni.createLivePusherContext("pusherId", instance.ctx)
	pusherContext.switchCamera()
    // pusherContext.startPreview({}) // nvue 页面吊起摄像头
  })   
  </script> 
  <style>
	  page{
	    background-color: #FFF !important;
	  }
  </style>
  <style lang="scss"  scoped>
  .face{
    padding: 46rpx 45rpx;
    text-align: center;
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
    .pushContent{
      position: relative;
      width: 300rpx;
      height: 300rpx;
      border-radius: 250rpx;
      overflow: hidden;
      margin: 50rpx auto;
      .livePusher{
        width: 300rpx;
        height: 300rpx;
        border-radius: 50%;
      }
      .pusherImg{
          position: absolute;
          top: 0;
          left: 0;
          bottom: 0;
          right: 0;
          width: 300rpx;
          height: 300rpx;
        }
    }
  }
  </style>

看下最终效果,先这样吧。

有别的好的方法,请路过留言,万分感谢!

相关推荐
西幻凌云3 天前
初始——正则表达式
c++·正则表达式·1024程序员节
启芯硬件4 天前
电源XL6009E1的dieshot细节分析-芯片设计干货
大数据·经验分享·硬件工程·1024程序员节
一颗青果5 天前
单例模式 | 死锁
linux·服务器·单例模式·1024程序员节
yBmZlQzJ8 天前
财运到内网穿透域名解析技术机制与中立评估
运维·经验分享·docker·容器·1024程序员节
yBmZlQzJ8 天前
内网穿透工具通过端口转发实现内外网通信
运维·经验分享·docker·容器·1024程序员节
数据皮皮侠AI9 天前
数字经济政策工具变量数据(2008-2023)
大数据·数据库·人工智能·笔记·1024程序员节
网安_秋刀鱼9 天前
【java安全】shiro反序列化1(shiro550)
java·开发语言·安全·web安全·网络安全·1024程序员节
unable code11 天前
攻防世界-Misc-Wire1
网络安全·ctf·misc·1024程序员节
开开心心就好12 天前
版本转换工具,支持Win双系统零售批量版
linux·运维·服务器·pdf·散列表·零售·1024程序员节