经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » JavaScript » 查看文章
用JS实现简单的屏幕录像机
来源:cnblogs  作者:京东云技术团队  时间:2023/12/22 16:22:44  对本文有异议

本文将介绍如何用JS实现简单的屏幕录像机。

一、录制准备

创建一个按钮

  1. <button id="recording-toggle">Start recording</button>

书写JavaScript

  1. var RECORDING_ONGOING = false;
  2. var recordingToggle = document.getElementById("recording-toggle"); // 按钮
  3. recordingToggle.addEventListener("click", function(){
  4. RECORDING_ONGOING = !RECORDING_ONGOING; // 开始 / 停止 录制
  5. if(RECORDING_ONGOING){
  6. recordingToggle.innerHTML = "Stop Recording";
  7. startRecording(); // 开始录制
  8. } else {
  9. recordingToggle.innerHTML = "Start Recording";
  10. stopRecording(); // 停止录制
  11. }
  12. });

看起来内容很多,但实际上,只是向按钮添加一个事件侦听器来开始和停止记录并相应地更改文本。

二、开始录制

在写功能函数之前,声明 3 个全局变量(在函数之外)。

  1. var blob, mediaRecorder = null;
  2. var chunks = [];

现在,开始屏幕录制

  1. async function startRecording(){
  2. var stream = await navigator.mediaDevices.getDisplayMedia(
  3. {video: {mediaSource: "screen"}, audio: true}
  4. );
  5. deviceRecorder = new deviceRecorder(stream, {mimeType: "video/webm"});
  6. }

在用户屏幕之外创建媒体流。媒体记录器有一个mimeType. 这是你想要的输出文件类型。

可以mimeTypes 在此处阅读更多相关信息。

Edge 支持video/webmmime 类型。这是文件扩展名.webm。可以通过以下方式检查浏览器是否支持mimeType:

  1. console.log(MediaRecorder.isTypeSupported("video/webm"))
  2. console.log(MediaRecorder.isTypeSupported("video/mp4"))
  3. console.log(MediaRecorder.isTypeSupported("video/mp4;codecs=avc1"))

向该函数添加几行startRecording

  1. deviceRecorder.ondataavailable = (e) => {
  2. if(e.data.size > 0){
  3. chunks.push(e.data);
  4. }
  5. }
  6. deviceRecorder.onstop = () => {
  7. chunks = [];
  8. }
  9. deviceRecorder.start(250)

每当有数据时,都会将其添加到块数组(之前定义)中。当停止录制时,将调用该stopRecording() 函数。

三、停止录制

  1. function stopRecording(){
  2. var filename = window.prompt("File name", "video"); // Ask the file name
  3. deviceRecorder.stop(); // 停止录制
  4. blob = new Blob(chunks, {type: "video/webm"})
  5. chunks = [] // 重置数据块
  6. var dataDownloadUrl = URL.createObjectURL(blob);
  7. // 将其下载到用户的设备上
  8. let a = document.createElement('a')
  9. a.href = dataDownloadUrl;
  10. a.download = `${filename}.webm`
  11. a.click()
  12. URL.revokeObjectURL(dataDownloadUrl)
  13. }

用JS做录屏就是这么简单。如果你想要 mp4 或其他格式,则必须使用 API 进行转换或自己进行转换。

浏览器会通知是否正在共享屏幕

作者:京东保险 张洁

来源:京东云开发者社区 转载请注明来源

原文链接:https://www.cnblogs.com/jingdongkeji/p/17918329.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号