HTML5如何通过navigator.mediaDevices.getUserMedia调用手机摄像头

发布时间:2021-05-23 15:03:11

来源:亿速云

阅读:76

作者:小新

这篇文章主要介绍了HTML5如何通过navigator.mediaDevices.getUserMedia调用手机摄像头,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

navigator.mediaDevices.getUserMedia

应项目要求,需要实现移动端app嵌入H5页面完成实人认证的功能。打开getUserMedia文档,链接如下:

https://developer.mozilla.org/zh-CN/docs/Web/API/MediaDevices/getUserMedia

看上去很简单,最终却写的怀疑人生。

API环境

问题一:(为什么不管怎么配置都显示前置摄像头)

想正常使用API必须在https环境下进行,否则你会发现不管怎么写,都只能调用默认的摄像头(大部分都是前置,只有少部分是后置)

前端开发者可以将文件上传至"码云"仓库,获取https链接然后在手机上预览

链接:码云仓库入口

问题二:(API在安卓和ios效果一样吗?)

根据官方文档,目前navigator.mediaDevices.getUserMedia在ios上只支持11版本以上,且只能在safari正常运行。安卓目前没有发现版本限制,需要兼容的代码如下if (navigator.mediaDevices === undefined) {

navigator.mediaDevices = {};

}

if (navigator.mediaDevices.getUserMedia === undefined) {

navigator.mediaDevices.getUserMedia = function (constraints) {

var getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia || navigator.oGetUserMedia;

if (!getUserMedia) {

return Promise.reject(new Error('getUserMedia is not implemented in this browser'));

}

return new Promise(function (resolve, reject) {

getUserMedia.call(navigator, constraints, resolve, reject);

});

}

}

问题三:(第一次启用成功调用前置摄像头,第二次需要调用后置却黑屏或者失败)

失败的原因很多,列举两个一开始我遇到的问题

1.前置摄像头调用后,摄像功能需要关闭后才能正常执行第二次调用,否则会报错:设备被占用。解决方法,在每次执行调用方法前,先关闭摄像设备。if (window.stream) {

window.stream.getTracks().forEach(track => {

track.stop();

});

}

亲测有用,别的找了很多停止的方法都没有效果。

2.调用后置API的方法还是无法唤醒后置摄像头,于是我找到另外一个方法,通过查看手机摄像头ID,来直接唤醒后置。var deviceInfoId="", //摄像头ID

num = 0, //摄像头数量

carema = []; //摄像头ID数组

//在页面加载完成后获得设备ID数组

window.onload = navigator.mediaDevices.enumerateDevices().then(gotDevices);

function gotDevices(deviceInfos) {

for (let i = 0; i

if (deviceInfos[i].kind === 'videoinput') {

carema.push(deviceInfos[i].deviceId)

}

}

deviceInfoId = carema[后置位置];

}

var constraints = {

audio: false,

video: {

deviceId: deviceInfoId,

//放在app里面需要下面配置一下

"permissions": {

"audio-capture": {

"description": "Required to capture audio using getUserMedia()"

},

"video-capture": {

"description": "Required to capture video using getUserMedia()"

}

}

}

};

navigator.mediaDevices.getUserMedia(constraints)

.then(function (stream) {

var video = document.getElementById('video');

try {

window.stream = stream;

video.srcObject = stream;

} catch (error) {

video.src = window.URL.createObjectURL(stream);

}

this.localMediaStream = stream;

// video.play();   这个加不加好像没有影响

})

.catch(function (err) {

console.log(err.name + ": " + err.message);

});

如果只是一部手机可以这样,但是测试了多部手机发现摄像头数组毫无规律可循,这个方法慎用。

如果页面上添加选择摄像设备的按钮的话,这个方法还是不错的。查看设备能调用几个摄像头链接如下:https://webrtc.github.io/samples/src/content/devices/input-output/

由于我们的项目页面不希望出现切换按钮,面对后置出现的众多BUG,最终选择放弃,使用input调用摄像头。

成功调用后用canvas实现成像并适应屏幕大小

我这里的代码是取video的宽高然后复制给canvas,这样可以让canvas和video保持一致,只用给video设置宽度100%,高度调节成合适的值,就实现了适应手机屏幕。var video = document.getElementById('video');

var canvas = document.getElementById('canvas'),

ctx = canvas.getContext('2d'),

CHeight = video.clientHeight, //获取屏幕大小让canvas自适应

CWidth = video.clientWidth;

canvas.width = CWidth;

canvas.height = CHeight;

//localMediaStream 在data里定义一个{}

if (localMediaStream) {

ctx.drawImage(video, 0, 0, CWidth, CHeight);

var dataURL = canvas.toDataURL('image/jpeg'); //dataURL = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAA'

img.src = dataURL;

video成像镜像问题

API唤醒的前置摄像头是相反的,很不舒服很不舒服。

之后用css处理一下给video添加 transform: rotate(180deg),可以实现反转,但是还是没有达到和手机一样的效果。

这时候可以选择通过设备ID调用前置摄像头,前置摄像头的laval一直都是“default”,也有的是空值,但是也能实现。

配置代码如下:var constraints = window.constraints = {

audio: false,

video: {

sourceId: 'default',

facingMode:  { exact: "user" }

}

};

完美调用自己手机的前置摄像头!!!

完整代码如下:

页面代码:

点击自拍一张头像
拍照

// 头像相机

moveToCameraAVG() {

var self = this;

if (navigator.mediaDevices === undefined) {

navigator.mediaDevices = {};

}

if (navigator.mediaDevices.getUserMedia === undefined) {

navigator.mediaDevices.getUserMedia = function (constraints) {

var getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia || navigator.oGetUserMedia;

if (!getUserMedia) {

return Promise.reject(new Error('getUserMedia is not implemented in this browser'));

}

return new Promise(function (resolve, reject) {

getUserMedia.call(navigator, constraints, resolve, reject);

});

}

}

if (window.stream) {

window.stream.getTracks().forEach(track => {

track.stop();

});

}

var constraints = window.constraints = {

audio: false,

video: {

sourceId: 'default',

facingMode:  { exact: "user" }

}

};

navigator.mediaDevices.getUserMedia(constraints)

.then(function (stream) {

var video = document.getElementById('video');

try {

window.stream = stream;

video.srcObject = stream;

} catch (error) {

video.src = window.URL.createObjectURL(stream);

}

self.localMediaStream = stream;

video.play();

})

.catch(function (err) {

alert(err.name + ": " + err.message);

});

},

//停止摄像机

stopCapture: function () {

var video = document.getElementById('video');

if (!video.srcObject) return

let stream = video.srcObject

let tracks = stream.getTracks();

tracks.forEach(track => {

track.stop()

})

},

// 头像照片

captureAvg() {

var vm = this;

var video = document.getElementById('video');

var canvas = document.getElementById('canvas'),

ctx = canvas.getContext('2d'),

CHeight = video.clientHeight, //获取屏幕大小让canvas自适应

CWidth = video.clientWidth;

canvas.width = CWidth;

canvas.height = CHeight;

if (vm.localMediaStream) {

ctx.drawImage(video, 0, 0, CWidth, CHeight);

var dataURL = canvas.toDataURL('image/jpeg'); //dataURL = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAA'

vm.imginfo = dataURL;

// 停止摄像机

video.pause();

this.stopCapture();

}

},

感谢你能够认真阅读完这篇文章,希望小编分享的“HTML5如何通过navigator.mediaDevices.getUserMedia调用手机摄像头”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

MediaDevices html5,HTML5如何通过navigator.mediaDevices.getUserMedia调用手机摄像头相关推荐

  1. MediaDevices html5,HTML5通过navigator.mediaDevices.getUserMedia调用手机摄像头问题

    .kind === 'videoinput') { carema.push(deviceInfos.deviceId) } } deviceInfoId = carema[后置位置]; } var c ...

  2. uniapp调用手机摄像头_HTML5通过navigator.mediaDevices.getUserMedia调用手机摄像头问题...

    navigator.mediaDevices.getUserMedia 应项目要求,需要实现移动端app嵌入H5页面完成实人认证的功能.打开getUserMedia文档,链接如下: https://d ...

  3. H5通过navigator.mediaDevices.getUserMedia调用手机摄像头

    navigator.mediaDevices.getUserMedia 应项目要求,需要实现移动端app嵌入H5页面完成实人认证的功能.打开getUserMedia文档,链接如下: https://d ...

  4. HTML5通过js调用手机摄像头

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  5. html5 调用手机摄像头详解

    html5 调用手机摄像头详解   首先,我们看看HTML代码结构,当然,这部分的DOM内容应该是在用户允许使用其摄像头事件出发后,动态加载生成的.  注意: 我们采用的是 640X480的分辨率,如 ...

  6. 原生html调手机拍照,如何让HTML5调用手机摄像头拍照——实践就是一切

    原文:如何让HTML5调用手机摄像头拍照--实践就是一切 NanShan 小编将思路提供给了大家,学编程最重要的是实践,我这虽然有完善的代码,但是希望大家都可以自己写出属于自己的代码 HTML5 Th ...

  7. html5调用手机摄像头,实现拍照上传功能

    http://www.glve.net/html5-calls-cell-phone-cameras-to-achieve-photo-upload-feature.html 今天做手机网站,想实现手 ...

  8. (亲测可用)html5 file调用手机摄像头

    在切图网一个客户的webapp项目中需要用到 html5调用手机摄像头,找了很多资料,大都是 js调用api  然后怎样怎样,做了几个demo测试发现根本不行, 后来恍然大悟,用html5自带的 in ...

  9. 使用HTML5+调用手机摄像头和相册

    前言: 前端时间使用HTML5做了一个WEB端APP,其中用到了H5页面调用手机摄像头的功能,当时也是花了不少时间去研究.最终是采用了HTML5plus(HTML5+)的方式完成了该功能,现将具体方法 ...

最新文章

  1. 11G RAC 进程启动顺序
  2. 精通python-轻松打造11周精通python计划(完结) | 软件库
  3. 图解Tomcat类加载机制(阿里面试题)
  4. 多元时间序列回归模型_多元时间序列分析和预测:将向量自回归(VAR)模型应用于实际的多元数据集...
  5. Python文档阅读笔记-PyAutoGUI基本使用
  6. 数学建模之图论——图与网络模型(一)(基本概念和最短路问题,附MATLAB源码)
  7. java实现井字棋 人工智能,Storm之——实现井字棋游戏(人工智能)
  8. WinEdt LaTeX参考文献的交叉引用
  9. Nginx配置文件(作为Web服务器)
  10. 基于偏微分方程的图像分割(二)Snake模型 Matlab实现
  11. 力扣刷题 DAY_85 贪心
  12. 网页框架布局设计_实用的网页设计-框架和框架用法介绍
  13. 自学就能轻松学会搭建网站的步骤教程
  14. 构造方法调用另一个构造方法
  15. 曲线救国的就业路线是否合理?
  16. char* p 和 char p[]区别及应用
  17. 培训4个月编程学什么比较好_编程,开放式硬件以及4月的更多新文章
  18. 高通平台启动log概述(PBL log、sbl1 log、kernel log)
  19. 科研实习 | 新加坡国立大学尤洋老师课题组招收Data-centric AI科研实习生
  20. java实现通话_Java做一个最简单的通话程序

热门文章

  1. BUUCTF WEB AreUSerialz 1
  2. xp框架下载官方_微软windows10官方系统去哪里下载?电脑系统一定要用原版的
  3. Mac OS 使用Communicator 方法
  4. 发现螃蟹wifi驱动11w的缺陷
  5. 1110: 最少操作数
  6. Triangle Count算法
  7. win10多年使用的一些安全和优化(转载)
  8. 德国外观设计专利申请流程
  9. coursera 吴恩达 -- 第一课 神经网络和深度学习 :第二周课后习题 Neural Network Basics Quiz, 10 questions
  10. 半导体功率器件测试系统