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

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()

})

现在基本就可以完成了,可以在润色下,如自动下载录制的视频,可以这么做:

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 url = URL.createObjectURL(blob)

let video = document.querySelector(“video”)

video.src = url

let a = document.createElement(‘a’)

a.href = url

a.download = ‘video.webm’

a.click()

})

// 必须手动启动

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值