欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2020年12月02日 14:32:05   作者:Haochen Li  
這篇文章主要介紹了JavaScript 如何在瀏覽器中使用攝像頭,幫助大家更好的理解和學(xué)習(xí)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)文章

最新評論