web camera 重复出现摄像头权限请求弹框问题

最近在做一个web camera的需求。基本功能是结合图像识别算法,进行证件或者活体的验证。

在实现H5的功能时,衍生出息屏后也需要正常使用的需求,所以增加了visibilitychange监听事件的逻辑,当前页面变为可见时,先关闭web camera,再重新打开web camera。

这里其实经历了两次变化。

第一次:活体检测息屏后,由于没有立即关掉camera,同时也没有终止requestAnimation事件,导致息屏后活体检测的逻辑仍然在走,对于动作检测完全不准确。所以我针对活体检测的visibilitychange监听事件做了调整。当前页面不可见时,关闭camera,页面可见时,再重新打开web camera。

本来功能是很顺畅的。但我们遇到了真我GT 6T这个奇葩。每次打开web camera都要请求一次权限,同时请求一次权限就会触发visibilitychange监听事件,触发监听事件后,由于当前页面是可见的,所以会再次触发打开web camera。就这样,A 触发B,B触发A,A再触发B,B再触发A。导致不断出现请求权限弹框,流程完全无法走下去。

所以进行了第二次改动。

第二次:调整第一次的逻辑。恢复原来visibilitychange监听事件的逻辑:当前页面变为可见时,先关闭web camera,再重新打开web camera。

但是在活体检测组件本身增加visibilitychange监听事件,当页面不可见时,取消requestAnimationFrame逻辑。在打开web camera 后,重新执行活体检测功能。

目前看来,这个处理方法比较可靠。

相关推荐
学不会•1 小时前
css数据不固定情况下,循环加不同背景颜色
前端·javascript·html
活宝小娜3 小时前
vue不刷新浏览器更新页面的方法
前端·javascript·vue.js
程序视点4 小时前
【Vue3新工具】Pinia.js:提升开发效率,更轻量、更高效的状态管理方案!
前端·javascript·vue.js·typescript·vue·ecmascript
coldriversnow4 小时前
在Vue中,vue document.onkeydown 无效
前端·javascript·vue.js
我开心就好o4 小时前
uniapp点左上角返回键, 重复来回跳转的问题 解决方案
前端·javascript·uni-app
开心工作室_kaic5 小时前
ssm161基于web的资源共享平台的共享与开发+jsp(论文+源码)_kaic
java·开发语言·前端
刚刚好ā5 小时前
js作用域超全介绍--全局作用域、局部作用、块级作用域
前端·javascript·vue.js·vue
沉默璇年6 小时前
react中useMemo的使用场景
前端·react.js·前端框架
yqcoder6 小时前
reactflow 中 useNodesState 模块作用
开发语言·前端·javascript
2401_882727576 小时前
BY组态-低代码web可视化组件
前端·后端·物联网·低代码·数学建模·前端框架