JavaScript 如何在瀏覽器中使用攝像頭
1.獲得攝像頭權(quán)限(本文使用chrome)
首先確保你運(yùn)行以下js所在的url是https協(xié)議的或者localhost的:
const constrains = { video: true, audio: true } navigator.mediaDevices.getUserMedia(constrains) .then(stream => { console.log('得到stream的類型是MediaStream') }) // 在一些老的瀏覽器上的話: // navigator.webkitGetUserMedia // navigator.mozGetUserMedia
之后你的瀏覽器會有彈出框,告訴你你的瀏覽器想要訪問camera,問你是否允許。
此外,這里的constrains可以設(shè)置分辨率的最小、理想和最大值,還可以在手機(jī)端通過設(shè)置facingMode來控制攝像頭的方向等。
2.將得到的stream:MediaStream給video, camera實現(xiàn)直播效果
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實時錄制下來的內(nèi)容
3.照相
// 展示相片的image標(biāo)簽 const image = document.createElement('image') // canvas會讀取video中的內(nèi)容,然后輸出(有點(diǎn)類似于給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生成的圖片轉(zhuǎn)換成一個data url const url = canvas.toDataURL() image.src = url
4.錄像
需要在2.MediaStream給video的基礎(chǔ)上做些修改
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標(biāo)簽用來展示錄制下來的內(nèi)容 const video = document.createElement('video'); //document.body.appendChild(video) // 開始錄像 startRecord() // do something....,比方說這里搞兩個button、一個開始錄影,一個結(jié)束錄影 // 結(jié)束錄影 stopRecord().then(videoUrl => { video.src = videoUrl }) // 此時video標(biāo)簽的內(nèi)容就是你錄制下來的內(nèi)容。
以上就是JavaScript 如何在瀏覽器中使用攝像頭的詳細(xì)內(nèi)容,更多關(guān)于JavaScript 瀏覽器使用攝像頭的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
ES6中的Promise.all()和Promise.race()函數(shù)的實現(xiàn)方法
這篇文章主要介紹了ES6的Promise.all()和Promise.race()函數(shù),結(jié)合實例代碼介紹了ES6 Promise.race和Promise.all方法使用,通過實例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02基于JavaScript實現(xiàn)焦點(diǎn)圖輪播效果
這篇文章主要為大家詳細(xì)介紹了基于JavaScript實現(xiàn)焦點(diǎn)圖輪播效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03js獲取下拉列表框<option>中的value和text的值示例代碼
本篇文章主要是對js獲取下拉列表框<option>中的value和text的值示例代碼進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-01-01基于JavaScript實現(xiàn)帶數(shù)據(jù)驗證和復(fù)選框的表單提交
這篇文章主要介紹了基于JavaScript實現(xiàn)帶數(shù)據(jù)驗證和復(fù)選框的表單提交功能,需要的朋友可以參考下2017-08-08javascript跟隨滾動效果插件代碼(javascript Follow Plugin)
這篇文章介紹了javascript跟隨滾動效果插件代碼(javascript Follow Plugin),有需要的朋友可以參考一下2013-08-08實例分析JS中的相等性判斷===、 ==和Object.is()
這篇文章主要給大家介紹了關(guān)于JS中相等性判斷===、 ==和Object.is()的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用JS具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11