国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

JavaScript 如何在瀏覽器中使用攝像頭

瀏覽:92日期:2023-10-06 17:35:57

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

之后你的瀏覽器會(huì)有彈出框,告訴你你的瀏覽器想要訪問(wèn)camera,問(wèn)你是否允許。此外,這里的constrains可以設(shè)置分辨率的最小、理想和最大值,還可以在手機(jī)端通過(guò)設(shè)置facingMode來(lái)控制攝像頭的方向等。

2.將得到的stream:MediaStream給video, camera實(shí)現(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(); })

此時(shí)video將播放camera實(shí)時(shí)錄制下來(lái)的內(nèi)容

3.照相

// 展示相片的image標(biāo)簽 const image = document.createElement(’image’) // canvas會(huì)讀取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) // 此時(shí)將canvas生成的圖片轉(zhuǎn)換成一個(gè)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)簽用來(lái)展示錄制下來(lái)的內(nèi)容 const video = document.createElement(’video’); //document.body.appendChild(video) // 開(kāi)始錄像 startRecord() // do something....,比方說(shuō)這里搞兩個(gè)button、一個(gè)開(kāi)始錄影,一個(gè)結(jié)束錄影 // 結(jié)束錄影 stopRecord().then(videoUrl => { video.src = videoUrl }) // 此時(shí)video標(biāo)簽的內(nèi)容就是你錄制下來(lái)的內(nèi)容。

以上就是JavaScript 如何在瀏覽器中使用攝像頭的詳細(xì)內(nèi)容,更多關(guān)于JavaScript 瀏覽器使用攝像頭的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 亚洲 欧美 都市 自拍 在线 | 大陆高清自拍 | 看一级毛片一区二区三区免费 | 97视频在线播放 | 黄色免费看片网站 | 精品国产理论在线观看不卡 | 狠狠色婷婷丁香综合久久韩国 | 男人的天堂视频在线观看 | 久久久久久一级毛片免费野外 | 日本三级久久 | 久久成人免费视频 | 中文字幕av一区二区三区 | 女高中生被cao到哭视频 | 成人国产精品一区二区网站 | 午夜国产视频 | 成人久久18免费游戏网站 | 欧美日韩视频精品一区二区 | 久久福利精品 | 国产精品深爱在线 | 国产精品一区二区手机在线观看 | 免费在线精品视频 | 波多野结衣在线观看一区二区 | 成人在线观看不卡 | 国产在线观看成人免费视频 | 性一级片 | 在线看欧美日韩中文字幕 | 国产欧美日韩在线人成aaaa | 在线免费看a | 日本一区二区高清免费不卡 | 91精品国产9l久久久久 | 国产精品v欧美精品v日本精 | 成人欧美一区二区三区在线观看 | 一级成人毛片免费观看欧美 | www.99在线观看 | 91久久香蕉| 日韩免费观看的一级毛片 | 国产福利一区二区在线精品 | 亚洲视频网站在线观看 | 色天使色婷婷在线影院亚洲 | 成年女人午夜免费视频 | 国产国产人免费人成成免视频 |