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

詳解js的視頻和音頻采集

 更新時(shí)間:2018年08月09日 08:36:24   作者:Mr.su  
這篇文章給大家講述了關(guān)于js的視頻和音頻采集的相關(guān)知識(shí)點(diǎn)內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。

今天要寫的,不是大家平時(shí)會(huì)用到的東西。因?yàn)榧嫒菪詫?shí)在不行,只是為了說明下前端原來還能干這些事。
大家能想象前端是能將攝像頭和麥克風(fēng)的視頻流和音頻流提取出來,再為所欲為的么?;蛘哒f我想把我canvas畫板的內(nèi)容錄制成一個(gè)視頻,這些看似js應(yīng)該做不到的事情,其實(shí)都是可以做到的,不過兼容性不好。我在這里都是以chrome瀏覽器舉的例子。

這里先把用到的api列一下:

  • getUserMedia:打開攝像頭和麥克風(fēng)的接口(文檔鏈接)
  • MediaRecorder:采集音視頻流(文檔鏈接)
  • srcObject:video標(biāo)簽可直接播放視頻流,這是一個(gè)大家應(yīng)該很少用到其實(shí)兼容性很好的屬性,推薦大家了解(文檔鏈接)
  • captureStream:可以將canvas輸出流,其實(shí)不單單是canvas這里只是舉有這個(gè)功能,具體的可以看文檔(文檔鏈接)

1、從攝像頭展示視頻

一、打開攝像頭

// 這里是打開攝像頭和麥克設(shè)備(會(huì)返回一個(gè)Promise對(duì)象)
navigator.mediaDevices.getUserMedia({
 audio: true,
 video: true
}).then(stream => {
 console.log(stream) // 放回音視頻流
}).catch(err => {
 console.log(err) // 錯(cuò)誤回調(diào)
})

上面我們成功打開了攝像頭和麥克風(fēng),并獲取到視頻流。那接下來就是要把流呈現(xiàn)到交互界面中了。

二、展示視頻

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <meta http-equiv="X-UA-Compatible" content="ie=edge">
 <title>Document</title>
</head>
<body>
 <video id="video" width="500" height="500" autoplay></video>
</body>
<script>
 var video = document.getElementById('video')
 navigator.mediaDevices.getUserMedia({
 audio: true,
 video: true
 }).then(stream => {
 // 這里就要用到srcObject屬性了,可以直接播放流資源
 video.srcObject = stream
 }).catch(err => {
 console.log(err) // 錯(cuò)誤回調(diào)
 })
</script>

效果如下圖:

到這里為止我們已經(jīng)成功的將我們的攝像頭在頁(yè)面展示了。下一步就是如何將采集視頻,并下載視頻文件。

2、從攝像頭采集視頻

這里用到的是MediaRecorder對(duì)象:

創(chuàng)建一個(gè)新的MediaRecorder對(duì)象,返回一個(gè)MediaStream 對(duì)象用來進(jìn)行錄制操作,支持配置項(xiàng)配置容器的MIME type (例如"video/webm" or "video/mp4")或者音頻的碼率視頻碼率

MediaRecorder接收兩個(gè)參數(shù)第一個(gè)是stream音視頻流,第二個(gè)是option配置參數(shù)。下面我們可以把上面攝像頭獲取的流加入MediaRecorder中。

var video = document.getElementById('video')
navigator.mediaDevices.getUserMedia({
 audio: true,
 video: true
}).then(stream => {
 // 這里就要用到srcObject屬性了,可以直接播放流資源
 video.srcObject = stream
 var mediaRecorder = new MediaRecorder(stream, {
 audioBitsPerSecond : 128000, // 音頻碼率
 videoBitsPerSecond : 100000, // 視頻碼率
 mimeType : 'video/webm;codecs=h264' // 編碼格式
 })
}).catch(err => {
 console.log(err) // 錯(cuò)誤回調(diào)
})

在上面我們創(chuàng)建了MediaRecorder的實(shí)例mediaRecorder。接下來就是控制mediaRecorder的開始采集和停止采集的方法了。
MediaRecorder提供了一些方法和事件供我們使用:

  • MediaRecorder.start(): 開始錄制媒體,這個(gè)方法調(diào)用時(shí)可以通過給timeslice參數(shù)設(shè)置一個(gè)毫秒值,如果設(shè)置這個(gè)毫秒值,那么錄制的媒體會(huì)按照你設(shè)置的值進(jìn)行分割成一個(gè)個(gè)單獨(dú)的區(qū)塊, 而不是以默認(rèn)的方式錄制一個(gè)非常大的整塊內(nèi)容.
  • MediaRecorder.stop(): 停止錄制. 同時(shí)觸發(fā)dataavailable事件,返回一個(gè)存儲(chǔ)Blob內(nèi)容的錄制數(shù)據(jù).之后不再記錄
  • ondataavailable事件: MediaRecorder.stop觸發(fā)該事件,該事件可用于獲取記錄的媒體(Blob在事件的data屬性中可用作對(duì)象)
// 這里我們?cè)黾觾蓚€(gè)按鈕控制采集的開始和結(jié)束
var start = document.getElementById('start')
var stop = document.getElementById('stop')
var video = document.getElementById('video')
navigator.mediaDevices.getUserMedia({
 audio: true,
 video: true
}).then(stream => {
 // 這里就要用到srcObject屬性了,可以直接播放流資源
 video.srcObject = stream
 var mediaRecorder = new MediaRecorder(stream, {
 audioBitsPerSecond : 128000, // 音頻碼率
 videoBitsPerSecond : 100000, // 視頻碼率
 mimeType : 'video/webm;codecs=h264' // 編碼格式
 })
 // 開始采集
 start.onclick = function () {
 mediaRecorder.start()
 console.log('開始采集')
 }
 // 停止采集
 stop.onclick = function () {
 mediaRecorder.stop()
 console.log('停止采集')
 }
 // 事件
 mediaRecorder.ondataavailable = function (e) {
 console.log(e)
 // 下載視頻
 var blob = new Blob([e.data], { 'type' : 'video/mp4' })
 let a = document.createElement('a')
 a.href = URL.createObjectURL(blob)
 a.download = `test.mp4`
 a.click()
 }
}).catch(err => {
 console.log(err) // 錯(cuò)誤回調(diào)
})

ok,現(xiàn)在執(zhí)行一波操作;

上圖可以看到結(jié)束采集后ondataavailable事件返回的數(shù)據(jù)中有一個(gè)Blob對(duì)象,這就是視頻資源了,再接下來我們就可以通過URL.createObjectURL()方法將Blob為url下載到本地了。視頻的采集到下載就結(jié)束了,很簡(jiǎn)單粗暴。

上面是視頻采集下載的例子,如果只要音頻采集的,同樣道理的設(shè)置“mimeType”就好了。這里我就不舉例了。下面我在介紹將canvas錄制為一個(gè)視頻文件

2、canvas輸出視頻流

這里用到的是captureStream方法,將canvas輸出流,再用video展現(xiàn),或者用MediaRecorder采集資源也是可以的。

// 這里就閑話少說直接上重點(diǎn)了因?yàn)楹蜕厦嬉曨l采集的是一樣的道理的。
<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <meta http-equiv="X-UA-Compatible" content="ie=edge">
 <title>Document</title>
</head>
<body>
 <canvas width="500" height="500" id="canvas"></canvas>
 <video id="video" width="500" height="500" autoplay></video>
</body>
<script>
 var video = document.getElementById('video')
 var canvas = document.getElementById('canvas')
 var stream = $canvas.captureStream(); // 這里獲取canvas流對(duì)象
 // 接下來你先為所欲為都可以了,可以參考上面的我就不寫了。
</script>

下面我再貼一個(gè)gif(這是結(jié)合我上次寫的canvas事件的demo結(jié)合這次視頻采集的結(jié)合)傳送門(Canvas事件綁定)

希望大家可以實(shí)現(xiàn)下面的效果,其實(shí)還可以在canvas視頻里插入背景音樂什么的,這些都比較簡(jiǎn)單。

相關(guān)文章

  • 深入淺出理解JavaScript閉包的功能與用法

    深入淺出理解JavaScript閉包的功能與用法

    這篇文章主要介紹了深入淺出理解JavaScript閉包的功能與用法,結(jié)合實(shí)例形式從變量、函數(shù)的內(nèi)部屬性與作用域鏈分析了javascript閉包的相關(guān)概念、功能與使用技巧,需要的朋友可以參考下
    2018-08-08
  • Ajax,UTF-8還是GB2312 eval 還是execScript

    Ajax,UTF-8還是GB2312 eval 還是execScript

    討厭的東西。 關(guān)于Ajax獲取HTML內(nèi)容編碼,與JavaScript載入腳本的動(dòng)態(tài)執(zhí)行問題。
    2008-11-11
  • js 學(xué)習(xí)筆記(三)

    js 學(xué)習(xí)筆記(三)

    JavaScript的對(duì)象基礎(chǔ) 本篇主要講解本地對(duì)象Array的各種方法。
    2009-12-12
  • JavaScript學(xué)習(xí)點(diǎn)滴 call、apply的區(qū)別

    JavaScript學(xué)習(xí)點(diǎn)滴 call、apply的區(qū)別

    對(duì)于apply和call兩者在作用上是相同的,但兩者在參數(shù)上有區(qū)別的。
    2010-10-10
  • JavaScript中EventLoop介紹

    JavaScript中EventLoop介紹

    本篇文章給大家詳細(xì)介紹了JavaScript中EventLoop的相關(guān)知識(shí),有這方面需要的朋友參考學(xué)習(xí)下。
    2018-01-01
  • JavaScript實(shí)現(xiàn)簡(jiǎn)易聊天對(duì)話框(加滾動(dòng)條)

    JavaScript實(shí)現(xiàn)簡(jiǎn)易聊天對(duì)話框(加滾動(dòng)條)

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)易聊天對(duì)話框,附加滾動(dòng)條功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • 最新評(píng)論