油猴脚本开发 | 视频录屏
一、Tampermonkey
二、代码
代码=>网页游戏、网页视频录屏
// ==UserScript==
// @name 网页游戏、网页直播录屏
// @namespace http://tampermonkey.net/
// @version 0.1
// @description try to take over the world!
// @author echohye
// @match *://*/*
// @icon 
// @grant GM_download
// @grant GM_addStyle
// ==/UserScript==
(function () {
'use strict';
// 用于等待网页及代码全部执行完毕再执行脚本内容
let readyState = false;
window.onload = () => {
let interval;
let i = 0;
interval = setInterval(() => {
i++;
if (i > 30 || readyState) {
clearInterval(interval);
} else {
loadReady();
}
}, 1000)
}
// 脚本内容
function loadReady() {
readyState = true;
// js
let video = document.querySelector('video')
if (!video) return;
// css
var domHead = document.getElementsByTagName('head')[0];
var domStyle = document.createElement('style');
domStyle.type = 'text/css';
domStyle.rel = 'stylesheet';
let cssStyle = `
.recorder {
width: 30px;
background-color: #aaa;
z-index: 99999;
position: fixed;
border: solid 1px #222;
border-top-right-radius: 3px;
border-bottom-right-radius: 3px;
user-select: none;
left: 0;
top: 40%;
font-size: 12px;
color:#111;
}
.r-btn {
width: 30px;
height: 20px;
line-height: 20px;
background-color: #fff;
border-radius: 2px;
cursor: pointer;
}
.r-btn:hover {
opacity: .9;
}
.r-div {
text-align: center;
}
`
domStyle.appendChild(document.createTextNode(cssStyle));
domHead.appendChild(domStyle);
// html
let domBody = document.body;
let rbtn = document.createElement('div');
rbtn.setAttribute('class', 'recorder');
rbtn.innerHTML = `<div class="r-div r-btn">开始</div><div class="r-div r-time"></div>`;
domBody.appendChild(rbtn);
// js
let btn = document.querySelector('.r-btn');
btn.addEventListener('click', function () {
if (this.innerText === '开始') {
rstart()
} else {
rstop()
}
})
let timeOut;
let mediaRecorder;
let interval;
function rstart() {
btn.innerText = '结束';
// 计算时间
let time = 0;
let domTime = document.querySelector('.r-time');
domTime.innerText = '0s';
timeOut = setInterval(() => {
time++;
let text = `${time}s`;
if (time > 60 && time < 3600) {
text = `${parseInt(time / 60)}m${time % 60}s`;
}
domTime.innerText = text
}, 1000)
// 录制
const mime = MediaRecorder.isTypeSupported("video/webm; codecs=vp9")
? "video/webm; codecs=vp9"
: "video/webm";
mediaRecorder = new MediaRecorder(video.captureStream(), {
mimeType: mime
})
let chunks = [];
mediaRecorder.addEventListener('stop', function () {
btn.innerText = '开始';
clearInterval(timeOut);
clearInterval(interval);
document.querySelector('.r-time').innerText = '';
mediaRecorder = null;
let blob = new Blob(chunks, {
type: chunks[0].type
})
let url = URL.createObjectURL(blob);
let a = document.createElement('a');
a.href = url;
a.download = `${document.title}.mp4`;
a.click();
URL.revokeObjectURL(url);
})
mediaRecorder.addEventListener('dataavailable', function (e) {
chunks.push(e.data)
})
mediaRecorder.start();
interval = setInterval(() => {
mediaRecorder.requestData();
}, 5000)
}
function rstop() {
mediaRecorder.stop();
}
}
})();
三、演示
1.随便打开一个含有视频的网页,脚本会自动检测是否支持,支持的话,左边会显示一个“开始”的按钮
2.点击按钮,则开始录制
3.再次点击按钮,则录屏结束
代码有待优化,仅供参考!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!