油猴脚本开发 | 视频录屏

一、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.再次点击按钮,则录屏结束

代码有待优化,仅供参考!

posted @ 2022-12-09 14:39  槑孒  阅读(200)  评论(0编辑  收藏  举报