我目前能够录制一个标签页,并从其流创建一个媒体录制器。我希望能够切换到另一个标签页并在另一个标签页上继续进行同样的录制,然后最后提供一个拼接好的视频。我该如何实现这个?
你可以将此作为你想要做的示例:
let currentStream = null; let mediaRecorder = null; let recordedChunks = []; // 开始为新标签页录制 function startRecording(stream) { currentStream = stream; mediaRecorder = new MediaRecorder(stream); mediaRecorder.ondataavailable = (event) => { if (event.data.size > 0) { recordedChunks.push(event.data); } }; mediaRecorder.start(); } // 停止当前标签页的录制 function stopRecording() { if (mediaRecorder) { mediaRecorder.stop(); currentStream.getTracks().forEach(track => track.stop()); currentStream = null; mediaRecorder = null; } } // 连接录制的视频 function concatenateVideos() { const finalBlob = new Blob(recordedChunks, { type: 'video/webm' }); // 现在,您可以使用finalBlob作为连接后的视频 } // 示例用法 startRecording(firstTabStream); // 切换到另一个标签页并使用新标签页的流调用startRecording stopRecording(); // 切换标签页或结束录制时 concatenateVideos(); // 获取最终连接的视频
你可以将此作为你想要做的示例: