作者:京東保險(xiǎn) 張潔
本文將介紹如何用JS實(shí)現(xiàn)簡單的屏幕錄像機(jī)。
一、錄制準(zhǔn)備
創(chuàng)建一個(gè)按鈕
Start recording/button?>
書寫JavaScript
var RECORDING_ONGOING = false; var recordingToggle = document.getElementById("recording-toggle"); // 按鈕 recordingToggle.addEventListener("click", function(){ RECORDING_ONGOING = !RECORDING_ONGOING; // 開始 / 停止 錄制 if(RECORDING_ONGOING){ recordingToggle.innerHTML = "Stop Recording"; startRecording(); // 開始錄制 } else { recordingToggle.innerHTML = "Start Recording"; stopRecording(); // 停止錄制 } });
看起來內(nèi)容很多,但實(shí)際上,只是向按鈕添加一個(gè)事件偵聽器來開始和停止記錄并相應(yīng)地更改文本。
二、開始錄制
在寫功能函數(shù)之前,聲明 3 個(gè)全局變量(在函數(shù)之外)。
var blob, mediaRecorder = null; var chunks = [];
現(xiàn)在,開始屏幕錄制
async function startRecording(){ var stream = await navigator.mediaDevices.getDisplayMedia( {video: {mediaSource: "screen"}, audio: true} ); deviceRecorder = new deviceRecorder(stream, {mimeType: "video/webm"}); }
在用戶屏幕之外創(chuàng)建媒體流。媒體記錄器有一個(gè)mimeType. 這是你想要的輸出文件類型。
可以mimeTypes 在此處閱讀更多相關(guān)信息。
Edge 支持video/webmmime 類型。這是文件擴(kuò)展名.webm??梢酝ㄟ^以下方式檢查瀏覽器是否支持mimeType:
console.log(MediaRecorder.isTypeSupported("video/webm")) console.log(MediaRecorder.isTypeSupported("video/mp4")) console.log(MediaRecorder.isTypeSupported("video/mp4;codecs=avc1"))
向該函數(shù)添加幾行startRecording
deviceRecorder.ondataavailable = (e) => { if(e.data.size > 0){ chunks.push(e.data); } } deviceRecorder.onstop = () => { chunks = []; } deviceRecorder.start(250)
每當(dāng)有數(shù)據(jù)時(shí),都會(huì)將其添加到塊數(shù)組(之前定義)中。當(dāng)停止錄制時(shí),將調(diào)用該stopRecording() 函數(shù)。
三、停止錄制
function stopRecording(){ var filename = window.prompt("File name", "video"); // Ask the file name deviceRecorder.stop(); // 停止錄制 blob = new Blob(chunks, {type: "video/webm"}) chunks = [] // 重置數(shù)據(jù)塊 var dataDownloadUrl = URL.createObjectURL(blob); // 將其下載到用戶的設(shè)備上 let a = document.createElement('a') a.href = dataDownloadUrl; a.download = `${filename}.webm` a.click() URL.revokeObjectURL(dataDownloadUrl) }
用JS做錄屏就是這么簡單。如果你想要 mp4 或其他格式,則必須使用 API 進(jìn)行轉(zhuǎn)換或自己進(jìn)行轉(zhuǎn)換。
? 瀏覽器會(huì)通知是否正在共享屏幕
審核編輯 黃宇
-
錄像機(jī)
+關(guān)注
關(guān)注
1文章
89瀏覽量
28037 -
JS
+關(guān)注
關(guān)注
0文章
78瀏覽量
18183
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
AWTK-WEB 快速入門(4) - JS Http 應(yīng)用程序
![AWTK-WEB 快速入門(4) - <b class='flag-5'>JS</b> Http 應(yīng)用程序](https://file.elecfans.com/web2/M00/50/DA/pYYBAGLH6TyAB71EAAAPQ7KgtYA038.png)
一款支持USB攝像頭輸入錄像的高清錄播機(jī)
![一款支持USB攝像頭輸入<b class='flag-5'>錄像</b>的高清錄播<b class='flag-5'>機(jī)</b>](https://file1.elecfans.com/web3/M00/03/A1/wKgZO2dqafeAH1HzAABm8kQU-kA088.png)
AWTK-WEB 快速入門(2) - JS 應(yīng)用程序
![AWTK-WEB 快速入門(2) - <b class='flag-5'>JS</b> 應(yīng)用程序](https://file.elecfans.com/web2/M00/50/DA/pYYBAGLH6TyAB71EAAAPQ7KgtYA038.png)
Node.js小科普和Node.js安裝常見管理工具
![Node.<b class='flag-5'>js</b>小科普和Node.<b class='flag-5'>js</b>安裝常見管理工具](https://file1.elecfans.com//web1/M00/F5/B1/wKgaoWdAW-uAMTp1AAEY6_6a3RI911.png)
aic3104 adc錄像白躁音很大怎么解決?
鴻蒙跨端實(shí)踐-JS虛擬機(jī)架構(gòu)實(shí)現(xiàn)
![鴻蒙跨端實(shí)踐-<b class='flag-5'>JS</b>虛擬機(jī)架構(gòu)<b class='flag-5'>實(shí)現(xiàn)</b>](https://file1.elecfans.com//web2/M00/08/BC/wKgZomb6SCqAaKbAAACBgMlQU1Y485.png)
聚徽-影響 LED 屏幕清晰度的因素有哪些
推薦一個(gè)支持js的嵌入式設(shè)備開發(fā)平臺(tái)
公交車安全與監(jiān)控:車載監(jiān)控的應(yīng)用與發(fā)展
可編程振蕩器替換SiTime應(yīng)用于NVR(網(wǎng)絡(luò)視頻錄像機(jī))
![可編程振蕩器替換SiTime應(yīng)用于NVR(網(wǎng)絡(luò)視頻<b class='flag-5'>錄像機(jī)</b>)](https://file1.elecfans.com/web2/M00/B0/D0/wKgZomVYGKGABF_PAABeovgKZMs950.png)
車載硬盤錄像機(jī):移動(dòng)監(jiān)控的新里程碑
![車載硬盤<b class='flag-5'>錄像機(jī)</b>:移動(dòng)監(jiān)控的新里程碑](https://file1.elecfans.com/web2/M00/DF/44/wKgaomYvY8eAfkopAA-aw2dHUNg406.png)
請(qǐng)問大伙labview調(diào)用???b class='flag-5'>錄像機(jī)無法回放的問題
淺談S-VIDEO接口靜電浪涌防護(hù)
![淺談S-VIDEO接口靜電浪涌防護(hù)](https://file.elecfans.com/web2/M00/11/AF/pYYBAGEjX2CAcHQBAAAbjMuxM3k247.jpg)
評(píng)論