用JS實現(xiàn)簡單的屏幕錄像機功能
一、錄制準(zhǔn)備
創(chuàng)建一個按鈕
<button id="recording-toggle">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)容很多,但實際上,只是向按鈕添加一個事件偵聽器來開始和停止記錄并相應(yīng)地更改文本。
二、開始錄制
在寫功能函數(shù)之前,聲明 3 個全局變量(在函數(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)建媒體流。媒體記錄器有一個mimeType. 這是你想要的輸出文件類型。
可以mimeTypes 在此處閱讀更多相關(guān)信息。
Edge 支持video/webmmime 類型。這是文件擴展名.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ù)組(之前定義)中。當(dāng)停止錄制時,將調(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 進行轉(zhuǎn)換或自己進行轉(zhuǎn)換。

瀏覽器會通知是否正在共享屏幕
以上就是用JS實現(xiàn)簡單的屏幕錄像機功能的詳細內(nèi)容,更多關(guān)于JS屏幕錄像機的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
微信小程序js文件改變參數(shù)并在視圖上及時更新【推薦】
這篇文章主要介紹了微信小程序js文件改變參數(shù)并在視圖上及時更新的實現(xiàn)代碼,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友參考下吧2018-06-06
Javascript拖拽系列文章1之offsetParent屬性
這個系列文章主要是講述實現(xiàn)Javascript拖拽功能的基礎(chǔ)知識,并將在最后給出一個完整的示例。適合對拖拽完全不懂的人閱讀2008-09-09
關(guān)于vite?+?ts?找不到模塊@/xxxx?或其相應(yīng)的類型聲明問題
這篇文章主要介紹了vite?+?ts?找不到模塊@/xxxx?或其相應(yīng)的類型聲明,本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-06-06
JavaScript新功能介紹之findLast()和findLastIndex()
最近工作中遇到了一個關(guān)于查找數(shù)組里面的目標(biāo)元素的方法,所以下面這篇文章主要給大家介紹了關(guān)于JavaScript新功能之findLast()?和findLastIndex()的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下2022-04-04

