JavaScript怎样实现摄像头使用?
Admin 2021-10-15 群英技术资讯 1546 次浏览
这篇文章主要给大家分享JavaScript怎样实现摄像头使用的内容,本文的实例是实现在浏览器中实现摄像头的拍照录像功能,那么具体怎样实现呢?下面我们来具体看看实现代码。
1.获得摄像头权限(本文使用chrome)
首先确保你运行以下js所在的url是https协议的或者localhost的:
const constrains = {
video: true,
audio: true
}
navigator.mediaDevices.getUserMedia(constrains)
.then(stream => {
console.log('得到stream的类型是MediaStream')
})
// 在一些老的浏览器上的话:
// navigator.webkitGetUserMedia
// navigator.mozGetUserMedia
之后你的浏览器会有弹出框,告诉你你的浏览器想要访问camera,问你是否允许。
此外,这里的constrains可以设置分辨率的最小、理想和最大值,还可以在手机端通过设置facingMode来控制摄像头的方向等。
2.将得到的stream:MediaStream给video, camera实现直播效果
const video = document.createElement('video');
//document.body.appendChild(video)
const constrains = {
video: true,
audio: true
}
navigator.mediaDevices.getUserMedia(constrains)
.then(stream => {
video.srcObject = stream;
video.play();
})
此时video将播放camera实时录制下来的内容
3.照相
// 展示相片的image标签
const image = document.createElement('image')
// canvas会读取video中的内容,然后输出(有点类似于给video截图)
const canvas = document.createElement('canvas')
const video = document.getElementById('video');
const context = canvas.getContext('2d')
context.drawImage(video, 0, 0, canvas.height, canvas.width)
// 此时将canvas生成的图片转换成一个data url
const url = canvas.toDataURL()
image.src = url
4.录像
需要在2.MediaStream给video的基础上做些修改
const constrains = {
video: true,
audio: true
}
let mediaRecorder
navigator.mediaDevices.getUserMedia(constrains)
.then(stream => {
mediaRecorder = new MediaRecorder(stream)
})
startRecord() {
mediaRecorder.start()
mediaRecorder.ondataavailable = e => {
chunks.push(e.data)
}
}
stopRecord() {
mediaRecorder.stop()
return new Promise(resolve => {
mediaRecorder.onstop = e => {
const blob = new Blob(chunks, { type: 'video/ogg; codecs=opus' })
const audioURL = window.URL.createObjectURL(blob)
resolve(audioURL)
}
})
}
// video标签用来展示录制下来的内容
const video = document.createElement('video');
//document.body.appendChild(video)
// 开始录像
startRecord()
// do something....,比方说这里搞两个button、一个开始录影,一个结束录影
// 结束录影
stopRecord().then(videoUrl => {
video.src = videoUrl
})
// 此时video标签的内容就是你录制下来的内容。
以上就是关于JavaScript怎样实现摄像头使用的介绍,本文代码具有一定的借鉴价值,有需要的朋友可以参考学习,希望对大家学习JS有帮助,想要了解更多可以继续浏览群英网络其他相关的文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
对于弹幕相信经常看剧的朋友应该都比较了解,很多朋友喜欢开着弹幕看剧,那么我们想要自己实现弹幕效果,要怎样做呢?下面小编就给大家分享使用原生JS怎样实现弹幕效果的实例,感兴趣的朋友可以参考。
在JS中,我们经常会遇到原型。字面上的意思会让我们认为,是某个对象的原型,可用来继承。但是其实这样的理解是片面的,下面通过本文来了解原型与原型链的细节,再顺便谈谈继承的几种方式。
前些日子了解到mqtt这样一个协议,可以在web上达到即时通讯的效果,所以下面这篇文章主要给大家介绍了关于vue中如何利用mqtt服务端实现即时通讯的相关资料,需要的朋友可以参考下
这篇文章主要介绍JS中的Canvas的内容,很多新手对Canvas绘制图形,使用和实现动画效果等等可能不是很了解,因此这篇文章就汇总了一些实例给大家做个参考,感兴趣的朋友可以看看,希望大家阅读完这篇文章能有所收获。
本文实例讲述了JavaScript中的this妙用。分享给大家供大家参考,具体如下:
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008