Html5浏览器调用用户摄像头

2021-05-30 09:04

阅读:669

标签:实时   服务器   异常   代码   ntb   device   document   dev   html5   

目前一个需求:要求用户开启摄像头进行人脸验证,验证完成后再关闭摄像头进行提示。如何进行人脸识别,只需要上传视频到服务器就行,考虑处理如何使用用户摄像头并进行实时预览。

这里主要是使用MediaStream获取视频流,然后利用video标签显示视频获取内容。Javascript代码如下:

let video = document.getElementById("video") //获取video节点
const config = {
  video:{width:150,height:150},  //指定摄像头画面尺寸,单位像素,也可以不指定具体大小,使用true表示使用
  audio:false  //不使用音频
}
/*getUserMedia会返回一个Promise,如果用户允许使用,那么resolve回调MediaStream,否则reject抛出异常*/
navigator.mediaDevices.getUserMedia(config)  
.then(MediaStream=>{
  video.srcObject = MediaStream
  video.play()  //指定视频源并播放
/*这里模拟识别成功,关闭摄像头,需要在MediaStream的Track里关闭掉我们使用的Track*/
  setTimeout(()=>{
    MediaStream.getVideoTracks()[0].stop()  //只会有一个视频流
    MediaStream.removeTrack(MediaStream.getVideoTracks()[0])
    video.srcObject = null  //srcObject恢复默认属性
  },4000)
})

需要注意的是,目前很多文章只讲了如何调用摄像头而不讲如何关闭,关闭的方法也只有removeTrack甚至只有关闭video,这种几乎是掩耳盗铃的行为,因为这样做只是断开了媒体流,硬件依然在工作。所以使用MediaStream.getTracks()[].stop()来关闭硬件。getTrack返回所使用的Track列表,因此需要逐个关闭:

    MediaStream.getTracks().forEach(track=>{
        track.stop()
    }

参考资料
https://developer.mozilla.org/zh-CN/docs/Web/API/MediaDevices/getUserMedia
https://developer.mozilla.org/zh-CN/docs/Web/API/MediaStream

Html5浏览器调用用户摄像头

标签:实时   服务器   异常   代码   ntb   device   document   dev   html5   

原文地址:https://www.cnblogs.com/pingxinwen/p/14679314.html


评论


亲,登录后才可以留言!