您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Capture video snapshot
// ==UserScript== // @name video-snapshot // @namespace https://ciffelia.com/ // @version 1.0.1 // @description Capture video snapshot // @author Ciffelia <[email protected]> (https://ciffelia.com/) // @license MIT // @homepage https://github.com/ciffelia/video-snapshot#readme // @supportURL https://github.com/ciffelia/video-snapshot/issues // @include * // @grant GM_registerMenuCommand // @run-at document-idle // ==/UserScript== (function () { 'use strict'; const createCanvasFromVideo = videoElm => { const canvasElm = document.createElement('canvas'); canvasElm.width = videoElm.videoWidth; canvasElm.height = videoElm.videoHeight; const ctx = canvasElm.getContext('2d'); ctx.drawImage(videoElm, 0, 0, videoElm.videoWidth, videoElm.videoHeight); return canvasElm }; const downloadBlob = (blob, filename) => { const a = document.createElement('a'); a.style.display = 'none'; a.href = URL.createObjectURL(blob); a.download = filename; document.body.appendChild(a); a.click(); document.body.removeChild(a); }; const capture = () => { const video = document.querySelector('video'); const canvas = createCanvasFromVideo(video); canvas.toBlob(blob => { downloadBlob(blob, 'snapshot.png'); }); }; GM_registerMenuCommand('Capture video snapshot', capture, 'c'); }());