炸裂,用JS创建一个录屏功能

然后在创建 index.js,监听按钮的点击:

let btn = document.querySelector(“.record-btn”);

btn.addEventListener(“click”, function () {

console.log(“hello”);

});

在浏览器中打开 html文件,点击按钮,我们可以在控制台看到打印的 hello

011.png

现在把打印去掉,换成如下的内容:

let btn = document.querySelector(“.record-btn”);

btn.addEventListener(“click”, async function () {

let stream = await navigator.mediaDevices.getDisplayMedia({

video: true

});

});

现在点击按钮,会弹出屏幕选择框:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-q3I3Ckpv-1636589217256)(https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/8b337d89faf9436aa751888a3ed922c4~tplv-k3u1fbpfcp-watermark.image?)]

因为,我现在用的是两个屏幕,所以会出现两个选择。

现在你可能认为选择一个屏幕,然后点击分享,就开始录制了。非也,这个比我们想象中的复杂点。我们要使用 MediaRecorder 来录制我们的视频。

let btn = document.querySelector(“.record-btn”)

btn.addEventListener(“click”, async function () {

let stream = await navigator.mediaDevices.getDisplayMedia({

video: true

})

// 需要更好的浏览器支持

const mime = MediaRecorder.isTypeSupported(“video/webm; codecs=vp9”)

? “video/webm; codecs=vp9”
“video/webm”

let mediaRecorder = new MediaRecorder(stream, {

mimeType: mime

})

// 必须手动启动

mediaRecorder.start()

})

当我们的屏幕被录制下来时,mediaRecorder 会给我们提供分块的数据,我们需要将这些数据存储在一个变量中。

let btn = document.querySelector(“.record-btn”)

btn.addEventListener(“click”, async function () {

let stream = await navigator.mediaDevices.getDisplayMedia({

video: true

})

// 需要更好的浏览器支持

const mime = MediaRecorder.isTypeSupported(“video/webm; codecs=vp9”)

? “video/webm; codecs=vp9”
“video/webm”

let mediaRecorder = new MediaRecorder(stream, {

mimeType: mime

})

let chunks = []

mediaRecorder.addEventListener(‘dataavailable’, function(e) {

chunks.push(e.data)

})

// 必须手动启动

mediaRecorder.start()

})

现在,当我们点击停止共享按钮时,希望在我们的 video元素中播放录制的视频,可以这么做:

let btn = document.querySelector(“.record-btn”)

btn.addEventListener(“click”, async function () {

let stream = await navigator.mediaDevices.getDisplayMedia({

video: true

})

// 需要更好的浏览器支持

const mime = MediaRecorder.isTypeSupported(“video/webm; codecs=vp9”)

? “video/webm; codecs=vp9”
“video/webm”

let mediaRecorder = new MediaRecorder(stream, {

mimeType: mime

})

let chunks = []

mediaRecorder.addEventListener(‘dataavailable’, function(e) {

chunks.push(e.data)

})

mediaRecorder.addEventListener(‘stop’, function(){

let blob = new Blob(chunks, {

type: chunks[0].type

})

let video = document.querySelector(“.video”)

video.src = URL.createObjectURL(blob)

})

// 必须手动启动

mediaRecorder.start()

文末

篇幅有限没有列举更多的前端面试题,小编把整理的前端大厂面试题PDF分享出来,一共有269页

  • 8
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用JavaCv实现录屏功能,需要使用FFmpeg进行视频编码,以下是一个简单的实现示例: 首先,需要引入JavaCv和FFmpeg的库文件,例如: ```xml <dependency> <groupId>org.bytedeco</groupId> <artifactId>javacv</artifactId> <version>1.5.3</version> </dependency> <dependency> <groupId>org.bytedeco</groupId> <artifactId>ffmpeg</artifactId> <version>4.4</version> </dependency> ``` 然后,创建一个FFmpegFrameRecorder对象,设置视频编码器、视频格式、视频帧率等参数: ```java FFmpegFrameRecorder recorder = new FFmpegFrameRecorder("output.mp4", width, height); recorder.setVideoCodec(avcodec.AV_CODEC_ID_H264); recorder.setFormat("mp4"); recorder.setFrameRate(fps); recorder.setPixelFormat(avutil.AV_PIX_FMT_YUV420P); recorder.start(); ``` 接着,使用Java.awt.Robot类进行屏幕捕获,获取屏幕上的图像: ```java Robot robot = new Robot(); Rectangle screenRect = new Rectangle(Toolkit.getDefaultToolkit().getScreenSize()); BufferedImage image = robot.createScreenCapture(screenRect); ``` 将图像转换为JavaCv的Frame对象,写入到视频文件中: ```java Frame frame = converter.convert(image); recorder.record(frame); ``` 最后,当录屏完成时,需要停止录制并释放资源: ```java recorder.stop(); recorder.release(); ``` 完整的代码示例如下: ```java import org.bytedeco.ffmpeg.global.avcodec; import org.bytedeco.ffmpeg.global.avutil; import org.bytedeco.javacv.FFmpegFrameRecorder; import org.bytedeco.javacv.Frame; import org.bytedeco.javacv.Java2DFrameConverter; import java.awt.*; import java.awt.image.BufferedImage; public class ScreenRecorder { public static void main(String[] args) throws Exception { int width = 1920; int height = 1080; int fps = 30; FFmpegFrameRecorder recorder = new FFmpegFrameRecorder("output.mp4", width, height); recorder.setVideoCodec(avcodec.AV_CODEC_ID_H264); recorder.setFormat("mp4"); recorder.setFrameRate(fps); recorder.setPixelFormat(avutil.AV_PIX_FMT_YUV420P); recorder.start(); Java2DFrameConverter converter = new Java2DFrameConverter(); Robot robot = new Robot(); Rectangle screenRect = new Rectangle(Toolkit.getDefaultToolkit().getScreenSize()); long startTime = System.currentTimeMillis(); while (System.currentTimeMillis() - startTime < 60 * 1000) { BufferedImage image = robot.createScreenCapture(screenRect); Frame frame = converter.convert(image); recorder.record(frame); } recorder.stop(); recorder.release(); } } ``` 注意,由于录制屏幕需要操作系统的权限,所以需要以管理员身份运行程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值