// ==UserScript== // @name 任意视频倍速播放 // @namespace http://tampermonkey.net/ // @version 0.5 // @description 任意浏览器视频倍速播放,按键调速。 // @author shandianchengzi // @include * // @icon  // @license MIT // @grant GM_registerMenuCommand // @grant GM_getValue // @grant GM_setValue // @downloadURL none // ==/UserScript== // 默认按键配置 const DEFAULT_KEYS = { speedUp: 'w', speedDown: 's', forward: 'ArrowRight', backward: 'ArrowLeft', volumeUp: 'ArrowUp', volumeDown: 'ArrowDown', normalSpeed: '1', doubleSpeed: '2', tripleSpeed: '3', quadrupleSpeed: '4', speedList: { normalSpeed: 1.0, doubleSpeed: 2.0, tripleSpeed: 3.0, quadrupleSpeed: 4.0 } }; const JS_name = "VIDEOSPEED_keys"; // 获取配置 function getConfig() { const savedKeys = GM_getValue(JS_name); return savedKeys ? {...DEFAULT_KEYS, ...savedKeys} : DEFAULT_KEYS; } // 轻提醒 function Toast(msg, duration) { duration = isNaN(duration) ? 3000 : duration; var m = document.createElement('div'); m.innerHTML = msg; m.style.cssText = "font-family:siyuan;max-width:60%;min-width: 150px;padding:0 14px;height: 40px;color: rgb(255, 255, 255);line-height: 40px;text-align: center;border-radius: 4px;position: fixed;top: 50%;left: 50%;transform: translate(-50%, -50%);z-index: 999999;background: rgba(0, 0, 0,.7);font-size: 16px;"; document.body.appendChild(m); setTimeout(function() { var d = 0.5; m.style.webkitTransition = '-webkit-transform ' + d + 's ease-in, opacity ' + d + 's ease-in'; m.style.opacity = '0'; setTimeout(function() { document.body.removeChild(m) }, d * 1000); }, duration); } // 配置快捷键 function configureShortcuts() { const keys = getConfig(); const configWindow = document.createElement('div'); configWindow.style.position = 'fixed'; configWindow.style.top = '50%'; configWindow.style.left = '50%'; configWindow.style.transform = 'translate(-50%, -50%)'; configWindow.style.backgroundColor = '#fff'; configWindow.style.padding = '20px'; configWindow.style.border = '1px solid #ddd'; configWindow.style.borderRadius = '8px'; configWindow.style.boxShadow = '0 6px 12px rgba(0, 0, 0, 0.3)'; configWindow.style.zIndex = '10000'; configWindow.style.width = '500px'; configWindow.style.maxHeight = '80vh'; configWindow.style.overflowY = 'auto'; configWindow.style.fontFamily = 'Arial, sans-serif'; // 创建表单内容 let formHTML = `

配置快捷键

`; // 添加快捷键输入字段 const keyLabels = { speedUp: '加速键 (默认: w)', speedDown: '减速键 (默认: s)', forward: '前进5秒键 (默认: →)', backward: '后退5秒键 (默认: ←)', volumeUp: '增加音量键 (默认: ↑)', volumeDown: '降低音量键 (默认: ↓)' }; const speedLabels = { normalSpeed: '倍速键 (默认: 1)', doubleSpeed: '倍速键 (默认: 2)', tripleSpeed: '倍速键 (默认: 3)', quadrupleSpeed: '倍速键 (默认: 4)' }; for (const [key, label] of Object.entries(keyLabels)) { formHTML += ` `; } for (const [key, label] of Object.entries(speedLabels)) { formHTML += ` `; } formHTML += `

倍速调节范围:0.1~16
具体的键位与名称的对应关系可以查询:https://developer.mozilla.org/zh-CN/docs/Web/API/KeyboardEvent/code

`; configWindow.innerHTML = formHTML; document.body.appendChild(configWindow); // 添加事件监听器 document.getElementById('saveShortcuts').addEventListener('click', () => { const newKeys = {}; for (const key of Object.keys(keyLabels)) { newKeys[key] = document.getElementById(key).value.trim() || keys[key]; } GM_setValue(JS_name, newKeys); document.body.removeChild(configWindow); Toast('快捷键配置已保存,刷新页面后生效', 2000); }); document.getElementById('cancelShortcuts').addEventListener('click', () => { document.body.removeChild(configWindow); }); // 添加ESC键关闭功能 const closeOnEsc = (e) => { if (e.key === 'Escape') { document.body.removeChild(configWindow); document.removeEventListener('keydown', closeOnEsc); } }; document.addEventListener('keydown', closeOnEsc); } // 显示当前配置 function showCurrentConfig() { const keys = getConfig(); const configText = ` 当前快捷键配置: 加速: ${keys.speedUp} 减速: ${keys.speedDown} 前进5秒: ${keys.forward} 后退5秒: ${keys.backward} 增加音量: ${keys.volumeUp} 降低音量: ${keys.volumeDown} 正常速度: ${keys.normalSpeed} 2倍速: ${keys.doubleSpeed} 3倍速: ${keys.tripleSpeed} 4倍速: ${keys.quadrupleSpeed} `.trim(); alert(configText); } // 重置为默认配置 function resetToDefault() { if (confirm('确定要重置为默认快捷键配置吗?')) { GM_setValue(JS_name, DEFAULT_KEYS); Toast('已重置为默认配置,刷新页面后生效', 2000); } } async function mainFunc(){ const keys = getConfig(); document.body.onkeydown = function(ev) { var e = ev || event; // 避免短时间重复触发同一按键 this.lastKey = this.lastKey || ''; this.lastTime = this.lastTime || 0; if(this.lastKey === e.key) { if((new Date()).getTime() - this.lastTime < 100) { return; } } this.lastKey = e.key; this.lastTime = (new Date()).getTime(); let video = document.getElementsByTagName('video')[0]; if(video){ switch(e.key){ case keys.speedUp: // 加速 video.playbackRate += 0.25; Toast(video.playbackRate.toFixed(2), 100); break; case keys.speedDown: // 减速 video.playbackRate -= 0.25; Toast(video.playbackRate.toFixed(2), 100); break; case keys.forward: // 前进5秒 video.currentTime += 5; break; case keys.backward: // 后退5秒 video.currentTime -= 5; break; case keys.volumeUp: // 增加音量 video.volume = Math.min(video.volume + 0.1, 1); Toast(video.volume.toFixed(1), 100); break; case keys.volumeDown: // 降低音量 video.volume = Math.max(video.volume - 0.1, 0); Toast(video.volume.toFixed(1), 100); break; case keys.normalSpeed: // 正常速度 video.playbackRate = 1; Toast(video.playbackRate, 100); break; case keys.doubleSpeed: // 2倍速 video.playbackRate = 2; Toast(video.playbackRate, 100); break; case keys.tripleSpeed: // 3倍速 video.playbackRate = 3; Toast(video.playbackRate, 100); break; case keys.quadrupleSpeed: // 4倍速 video.playbackRate = 4; Toast(video.playbackRate, 100); break; default: return; } } } } // 注册菜单命令 GM_registerMenuCommand('配置快捷键', configureShortcuts); GM_registerMenuCommand('查看当前配置', showCurrentConfig); GM_registerMenuCommand('重置为默认配置', resetToDefault); (function() { 'use strict'; window.onhashchange=mainFunc; mainFunc(); // 这个代码不管用,会导致所有的都运行不了。建议编辑脚本,设置-通用-仅在顶层页面(框架)运行-是 // if(window.top === window.self){ // } })();