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 如何在瀏覽器中使用攝像頭的詳細內容,更多關于JavaScript 瀏覽器使用攝像頭的資料請關注腳本之家其它相關文章!
相關文章
ES6中的Promise.all()和Promise.race()函數的實現方法
這篇文章主要介紹了ES6的Promise.all()和Promise.race()函數,結合實例代碼介紹了ES6 Promise.race和Promise.all方法使用,通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2023-02-02
js獲取下拉列表框<option>中的value和text的值示例代碼
本篇文章主要是對js獲取下拉列表框<option>中的value和text的值示例代碼進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-01-01
javascript跟隨滾動效果插件代碼(javascript Follow Plugin)
這篇文章介紹了javascript跟隨滾動效果插件代碼(javascript Follow Plugin),有需要的朋友可以參考一下2013-08-08
實例分析JS中的相等性判斷===、 ==和Object.is()
這篇文章主要給大家介紹了關于JS中相等性判斷===、 ==和Object.is()的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用JS具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-11-11

