作者:京東保險(xiǎn) 張潔
本文將介紹如何用JS實(shí)現(xiàn)簡(jiǎn)單的屏幕錄像機(jī)。
一、錄制準(zhǔn)備
創(chuàng)建一個(gè)按鈕
Start recording/button?>
書(shū)寫(xiě)JavaScript
var RECORDING_ONGOING = false;
var recordingToggle = document.getElementById("recording-toggle"); // 按鈕
recordingToggle.addEventListener("click", function(){
RECORDING_ONGOING = !RECORDING_ONGOING; // 開(kāi)始 / 停止 錄制
if(RECORDING_ONGOING){
recordingToggle.innerHTML = "Stop Recording";
startRecording(); // 開(kāi)始錄制
} else {
recordingToggle.innerHTML = "Start Recording";
stopRecording(); // 停止錄制
}
});
看起來(lái)內(nèi)容很多,但實(shí)際上,只是向按鈕添加一個(gè)事件偵聽(tīng)器來(lái)開(kāi)始和停止記錄并相應(yīng)地更改文本。
二、開(kāi)始錄制
在寫(xiě)功能函數(shù)之前,聲明 3 個(gè)全局變量(在函數(shù)之外)。
var blob, mediaRecorder = null; var chunks = [];
現(xiàn)在,開(kāi)始屏幕錄制
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. 這是你想要的輸出文件類(lèi)型。
可以mimeTypes 在此處閱讀更多相關(guān)信息。
Edge 支持video/webmmime 類(lèi)型。這是文件擴(kuò)展名.webm??梢酝ㄟ^(guò)以下方式檢查瀏覽器是否支持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做錄屏就是這么簡(jiǎn)單。如果你想要 mp4 或其他格式,則必須使用 API 進(jìn)行轉(zhuǎn)換或自己進(jìn)行轉(zhuǎn)換。
? 瀏覽器會(huì)通知是否正在共享屏幕
審核編輯 黃宇
-
錄像機(jī)
+關(guān)注
關(guān)注
1文章
94瀏覽量
28663 -
JS
+關(guān)注
關(guān)注
0文章
78瀏覽量
18698
發(fā)布評(píng)論請(qǐng)先 登錄
SGTools--動(dòng)畫(huà)控件--屏幕實(shí)現(xiàn)動(dòng)畫(huà)顯示 就是這么簡(jiǎn)單
藍(lán)牙串口模塊技術(shù)在NVR(網(wǎng)絡(luò)視頻錄像機(jī))中的應(yīng)用方案
松下系列錄像機(jī)機(jī)械結(jié)構(gòu)原理檢修與實(shí)例
不同類(lèi)型的UTP電纜的功能一樣嗎
松下NV一G30錄像機(jī)常見(jiàn)故障檢修實(shí)例
AIWA HS-JS415維修手冊(cè)
GS1-N2:雙核心異構(gòu) AI 硬盤(pán)錄像機(jī)
NV-C2P10:雙核心異構(gòu) AI 硬盤(pán)錄像機(jī)
AWTK-WEB 快速入門(mén)(4) - JS Http 應(yīng)用程序
一款支持USB攝像頭輸入錄像的高清錄播機(jī)
AWTK-WEB 快速入門(mén)(2) - JS 應(yīng)用程序
Node.js小科普和Node.js安裝常見(jiàn)管理工具

用JS實(shí)現(xiàn)簡(jiǎn)單的屏幕錄像機(jī)
評(píng)論