用JS实现简单的屏幕录像机 | 京东云技术团队
本文将介绍如何用JS实现简单的屏幕录像机。
一、录制准备
创建一个按钮
<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(); // 停止录制 } });
看起来内容很多,但实际上,只是向按钮添加一个事件侦听器来开始和停止记录并相应地更改文本。
二、开始录制
在写功能函数之前,声明 3 个全局变量(在函数之外)。
var blob, mediaRecorder = null; var chunks = [];
现在,开始屏幕录制
async function startRecording(){ var stream = await navigator.mediaDevices.getDisplayMedia( {video: {mediaSource: "screen"}, audio: true} ); deviceRecorder = new deviceRecorder(stream, {mimeType: "video/webm"}); }
在用户屏幕之外创建媒体流。媒体记录器有一个mimeType. 这是你想要的输出文件类型。
可以mimeTypes 在此处阅读更多相关信息。
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"))
向该函数添加几行startRecording
deviceRecorder.ondataavailable = (e) => { if(e.data.size > 0){ chunks.push(e.data); } } deviceRecorder.onstop = () => { chunks = []; } deviceRecorder.start(250)
每当有数据时,都会将其添加到块数组(之前定义)中。当停止录制时,将调用该stopRecording() 函数。
三、停止录制
function stopRecording(){ var filename = window.prompt("File name", "video"); // Ask the file name deviceRecorder.stop(); // 停止录制 blob = new Blob(chunks, {type: "video/webm"}) chunks = [] // 重置数据块 var dataDownloadUrl = URL.createObjectURL(blob); // 将其下载到用户的设备上 let a = document.createElement('a') a.href = dataDownloadUrl; a.download = `${filename}.webm` a.click() URL.revokeObjectURL(dataDownloadUrl) }
用JS做录屏就是这么简单。如果你想要 mp4 或其他格式,则必须使用 API 进行转换或自己进行转换。
浏览器会通知是否正在共享屏幕
作者:京东保险 张洁
来源:京东云开发者社区 转载请注明来源

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
现代 CPU 技术发展 | 京东云技术团队
介绍 这篇文章主要是介绍CPU技术的发展,包括最近几十年CPU性能提升和半导体工艺发展,当前技术发展方向。希望可以帮助软件开发者理解CPU指令集和组成运行原理、CPU性能提升的现状和瓶颈、CPU技术发展方向会如何影响软件开发/设计的框架和编程思想。 提示:因为是面向软件开发者,所以会忽略掉一些电路设计、制造工艺等底层的硬件知识。同时也不会特别深入的介绍每个知识点,只是提供一个概览。 CPU 指令集和运行原理 当前使用最广泛的指令集是x86、ARM、RISC-V,指令集对于CPU性能和软件开发有多大的影响,指令集的发展方向是什么。现代CPU内部微架构、流水线是如何设计的,为什么CPU的控制单元和缓存相比GPU复杂很多。 CPU 性能提升和未来方向 近些年CPU性能提升遇到了功耗墙的问题导致提升速度放缓,为什么以前的优化技术都遇到了瓶颈,同时当前有哪些新的技术方向用于提高CPU的性能。 CPU 技术方向对软件开发技术的影响 软件最终会在CPU上运行,更好的利用CPU提供的能力进行编程才能带来更好的性能。一部分CPU优化技术是内部微架构调整对软件开发者是透明的,例如时钟频率和IPC的提升。但...
- 下一篇
使用 Taro 开发鸿蒙原生应用 —— 探秘适配鸿蒙 ArkTS 的工作原理
背景 在上一篇文章中,我们已经了解到华为即将发布的鸿蒙操作系统纯血版本——鸿蒙 Next,以及各个互联网厂商开展鸿蒙应用开发的消息。其中,Taro作为一个重要的前端开发框架,也积极适配鸿蒙的新一代语言框架 —— ArkTS。 本文将深入探讨 Taro 适配鸿蒙 ArkTS 框架的工作原理,接下来我们先一同看看适配的整体思路。 整体思路 在适配 ArkTS 的整体思路上面,和适配小程序类似的,我们优先采用了偏运行时的适配方案,在运行时将 Taro 虚拟 DOM 树映射到对应的 ArkTS UI 组件。 选择偏运行时方案的原因 1. 前端框架 React/Vue 的 DSL 范式和 ArkTS 的 UI 范式差异较大 以 React 为例,我们在 React 和 ArkTS 两边都简单渲染一个Button组件,并给这个组件赋予一些简单的样式属性: 可以看到单纯是一个简单的Button组件例子,两边的代码结构其实就已经有较大的差异,更不用说在实际的项目中,我们还需要考虑到各种各样的循环体和表达式,如果将这些代码放在编译时去进行解析和转换,难免会出现各种各样的错误和遗漏,并且也无法保证转换后代...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- CentOS8编译安装MySQL8.0.19
- CentOS6,CentOS7官方镜像安装Oracle11G
- CentOS7,8上快速安装Gitea,搭建Git服务器
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- MySQL8.0.19开启GTID主从同步CentOS8
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- Red5直播服务器,属于Java语言的直播服务器
- CentOS6,7,8上安装Nginx,支持https2.0的开启
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7