// ==UserScript== // @name [VIP影视解析工具]红狐弹幕播放器 // @namespace http://tampermonkey.net/ // @version 0.5.1 // @description 基于红狐弹幕解析编写的脚本,支持解析:腾讯视频、爱奇艺、优酷、芒果TV、PPTV、Bilibili等 // @author Aomine // @match *.rdfplayer.mrgaocloud.com/* // @match *v.qq.com/x* // @match *v.qq.com/p* // @match *v.qq.com/cover* // @match *v.qq.com/tv/* // @match *.youku.com/v* // @match *m.youku.com/* // @match *.iqiyi.com/v_* // @match *.iqiyi.com/w_* // @match *.iqiyi.com/a_* // @match *.iq.com/play/* // @match *.bilibili.com/video/* // @match *.bilibili.com/anime/* // @match *.bilibili.com/bangumi/play/* // @match *.bilibili.com/s/* // @match *.pptv.com/show/* // @match *.mgtv.com/b/* // @license GPL License // @icon data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/PgoNPCEtLSBVcGxvYWRlZCB0bzogU1ZHIFJlcG8sIHd3dy5zdmdyZXBvLmNvbSwgR2VuZXJhdG9yOiBTVkcgUmVwbyBNaXhlciBUb29scyAtLT4KPHN2ZyB3aWR0aD0iODAwcHgiIGhlaWdodD0iODAwcHgiIHZpZXdCb3g9IjAgMCA5MSA5MSIgaWQ9IkxheWVyXzEiIHZlcnNpb249IjEuMSIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+Cg08c3R5bGUgdHlwZT0idGV4dC9jc3MiPg0KCS5zdDB7ZmlsbDojNEU3QTlFO30NCgkuc3Qxe2ZpbGw6I0YwQURBQjt9DQo8L3N0eWxlPgoNPGc+Cg08Zz4KDTxnPgoNPHBhdGggY2xhc3M9InN0MCIgZD0iTTU1LjQsNTMuNmMyLjEtMi4xLDMuMi00LjgsMS43LThjLTIuMy00LjctMTAuMy01LjUtMTMuMy0xLjNjLTAuNiwwLjgsMC4xLDEuOCwwLjgsMi4xICAgICBjMi4zLDAuOCw1LjMtMSw3LjQsMC40YzMuNiwyLjMtMC44LDUuMi0zLjIsNS45Yy0yLjcsMC44LTEuNiw0LjksMS4yLDQuMmMzLjctMC45LDYuMSwyLjgsNC40LDZjLTEuNywzLTUuMywzLjItOCwxLjcgICAgIGMtMy43LTItOC4xLDMuMS00LjYsNmMyLjgsMi40LDcuNiwxLjcsMTAuOCwwLjNjMy4xLTEuNCw1LjctNCw2LjYtNy40QzYwLjEsNTkuNiw1OC40LDU1LjYsNTUuNCw1My42eiIvPgoNPHBhdGggY2xhc3M9InN0MCIgZD0iTTMzLjIsMjAuOWMtMi44LDEuNS01LjEsMy45LTcuMSw2LjRjLTIuNC0zLjEtNS42LTYuMi05LjMtNi4zYy0xLjcsMC0yLjUsMi4xLTEuMywzLjJjMi45LDMsNiw1LjMsOC4zLDguOSAgICAgYzEuMSwxLjgsMy40LDEuNiw0LjYsMGMyLjMtMy4xLDUuMy01LjMsOC4zLTcuOEMzOS4xLDIzLjIsMzUuOSwxOS40LDMzLjIsMjAuOXoiLz4KDTxwYXRoIGNsYXNzPSJzdDAiIGQ9Ik03MS45LDIxLjdjLTIuOCwxLjUtNS4xLDMuOS03LjEsNi40Yy0yLjQtMy4xLTUuNi02LjItOS4zLTYuM2MtMS43LDAtMi41LDIuMS0xLjMsMy4yYzIuOSwzLDYsNS4zLDguMyw4LjkgICAgIGMxLjEsMS44LDMuNCwxLjYsNC42LDBjMi4zLTMuMSw1LjMtNS4zLDguMy03LjhDNzcuOSwyNCw3NC43LDIwLjIsNzEuOSwyMS43eiIvPgoNPC9nPgoNPHBhdGggY2xhc3M9InN0MSIgZD0iTTEwLjQsNTIuMWMxLjQtMS40LDIuOC0yLjcsNC4yLTQuMWMxLjQtMS40LDMuNC0yLjcsMy40LTQuOGMwLTEuMi0xLTIuMi0yLjItMi4yYy0yLjMsMC4xLTMuNSwyLjItNC44LDMuOCAgICBjLTEuMiwxLjYtMi4yLDMuNS0zLjIsNS4zQzcuMSw1MS43LDkuMSw1My41LDEwLjQsNTIuMUwxMC40LDUyLjF6Ii8+Cg08cGF0aCBjbGFzcz0ic3QxIiBkPSJNMjEuMiw1Mi44YzEuNC0xLjEsMi44LTIuMiw0LjItMy4zYzEuMy0xLjEsMy4xLTIuMiwzLjgtMy44YzEtMi4yLTEuMS00LjktMy41LTMuNWMtMS43LDAuOS0yLjYsMi45LTMuNiw0LjQgICAgYy0xLDEuNS0yLDMuMS0yLjksNC43QzE4LjMsNTIuNSwyMC4xLDUzLjYsMjEuMiw1Mi44TDIxLjIsNTIuOHoiLz4KDTxwYXRoIGNsYXNzPSJzdDEiIGQ9Ik02NS42LDUyLjFjMS40LTEuNCwyLjgtMi43LDQuMi00LjFjMS40LTEuNCwzLjQtMi43LDMuNC00LjhjMC0xLjItMS0yLjItMi4yLTIuMmMtMi4zLDAuMS0zLjUsMi4yLTQuOCwzLjggICAgYy0xLjIsMS42LTIuMiwzLjUtMy4yLDUuM0M2Mi4zLDUxLjcsNjQuMyw1My41LDY1LjYsNTIuMUw2NS42LDUyLjF6Ii8+Cg08cGF0aCBjbGFzcz0ic3QxIiBkPSJNNzYuNCw1Mi44YzEuNC0xLjEsMi44LTIuMiw0LjItMy4zYzEuMy0xLjEsMy4xLTIuMiwzLjgtMy44YzEtMi4yLTEuMS00LjktMy41LTMuNWMtMS43LDAuOS0yLjYsMi45LTMuNiw0LjQgICAgYy0xLDEuNS0yLDMuMS0yLjksNC43QzczLjUsNTIuNSw3NS4zLDUzLjYsNzYuNCw1Mi44TDc2LjQsNTIuOHoiLz4KDTwvZz4KDTwvZz4KDTwvc3ZnPg== // @grant GM_addStyle // @downloadURL none // ==/UserScript== (function() { 'use strict'; // 弹幕解析功能 var am = false; var moving = false; var logo = "data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/PgoNPCEtLSBVcGxvYWRlZCB0bzogU1ZHIFJlcG8sIHd3dy5zdmdyZXBvLmNvbSwgR2VuZXJhdG9yOiBTVkcgUmVwbyBNaXhlciBUb29scyAtLT4KPHN2ZyB3aWR0aD0iODAwcHgiIGhlaWdodD0iODAwcHgiIHZpZXdCb3g9IjAgMCA5MSA5MSIgaWQ9IkxheWVyXzEiIHZlcnNpb249IjEuMSIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+Cg08c3R5bGUgdHlwZT0idGV4dC9jc3MiPg0KCS5zdDB7ZmlsbDojNEU3QTlFO30NCgkuc3Qxe2ZpbGw6I0YwQURBQjt9DQo8L3N0eWxlPgoNPGc+Cg08Zz4KDTxnPgoNPHBhdGggY2xhc3M9InN0MCIgZD0iTTU1LjQsNTMuNmMyLjEtMi4xLDMuMi00LjgsMS43LThjLTIuMy00LjctMTAuMy01LjUtMTMuMy0xLjNjLTAuNiwwLjgsMC4xLDEuOCwwLjgsMi4xICAgICBjMi4zLDAuOCw1LjMtMSw3LjQsMC40YzMuNiwyLjMtMC44LDUuMi0zLjIsNS45Yy0yLjcsMC44LTEuNiw0LjksMS4yLDQuMmMzLjctMC45LDYuMSwyLjgsNC40LDZjLTEuNywzLTUuMywzLjItOCwxLjcgICAgIGMtMy43LTItOC4xLDMuMS00LjYsNmMyLjgsMi40LDcuNiwxLjcsMTAuOCwwLjNjMy4xLTEuNCw1LjctNCw2LjYtNy40QzYwLjEsNTkuNiw1OC40LDU1LjYsNTUuNCw1My42eiIvPgoNPHBhdGggY2xhc3M9InN0MCIgZD0iTTMzLjIsMjAuOWMtMi44LDEuNS01LjEsMy45LTcuMSw2LjRjLTIuNC0zLjEtNS42LTYuMi05LjMtNi4zYy0xLjcsMC0yLjUsMi4xLTEuMywzLjJjMi45LDMsNiw1LjMsOC4zLDguOSAgICAgYzEuMSwxLjgsMy40LDEuNiw0LjYsMGMyLjMtMy4xLDUuMy01LjMsOC4zLTcuOEMzOS4xLDIzLjIsMzUuOSwxOS40LDMzLjIsMjAuOXoiLz4KDTxwYXRoIGNsYXNzPSJzdDAiIGQ9Ik03MS45LDIxLjdjLTIuOCwxLjUtNS4xLDMuOS03LjEsNi40Yy0yLjQtMy4xLTUuNi02LjItOS4zLTYuM2MtMS43LDAtMi41LDIuMS0xLjMsMy4yYzIuOSwzLDYsNS4zLDguMyw4LjkgICAgIGMxLjEsMS44LDMuNCwxLjYsNC42LDBjMi4zLTMuMSw1LjMtNS4zLDguMy03LjhDNzcuOSwyNCw3NC43LDIwLjIsNzEuOSwyMS43eiIvPgoNPC9nPgoNPHBhdGggY2xhc3M9InN0MSIgZD0iTTEwLjQsNTIuMWMxLjQtMS40LDIuOC0yLjcsNC4yLTQuMWMxLjQtMS40LDMuNC0yLjcsMy40LTQuOGMwLTEuMi0xLTIuMi0yLjItMi4yYy0yLjMsMC4xLTMuNSwyLjItNC44LDMuOCAgICBjLTEuMiwxLjYtMi4yLDMuNS0zLjIsNS4zQzcuMSw1MS43LDkuMSw1My41LDEwLjQsNTIuMUwxMC40LDUyLjF6Ii8+Cg08cGF0aCBjbGFzcz0ic3QxIiBkPSJNMjEuMiw1Mi44YzEuNC0xLjEsMi44LTIuMiw0LjItMy4zYzEuMy0xLjEsMy4xLTIuMiwzLjgtMy44YzEtMi4yLTEuMS00LjktMy41LTMuNWMtMS43LDAuOS0yLjYsMi45LTMuNiw0LjQgICAgYy0xLDEuNS0yLDMuMS0yLjksNC43QzE4LjMsNTIuNSwyMC4xLDUzLjYsMjEuMiw1Mi44TDIxLjIsNTIuOHoiLz4KDTxwYXRoIGNsYXNzPSJzdDEiIGQ9Ik02NS42LDUyLjFjMS40LTEuNCwyLjgtMi43LDQuMi00LjFjMS40LTEuNCwzLjQtMi43LDMuNC00LjhjMC0xLjItMS0yLjItMi4yLTIuMmMtMi4zLDAuMS0zLjUsMi4yLTQuOCwzLjggICAgYy0xLjIsMS42LTIuMiwzLjUtMy4yLDUuM0M2Mi4zLDUxLjcsNjQuMyw1My41LDY1LjYsNTIuMUw2NS42LDUyLjF6Ii8+Cg08cGF0aCBjbGFzcz0ic3QxIiBkPSJNNzYuNCw1Mi44YzEuNC0xLjEsMi44LTIuMiw0LjItMy4zYzEuMy0xLjEsMy4xLTIuMiwzLjgtMy44YzEtMi4yLTEuMS00LjktMy41LTMuNWMtMS43LDAuOS0yLjYsMi45LTMuNiw0LjQgICAgYy0xLDEuNS0yLDMuMS0yLjksNC43QzczLjUsNTIuNSw3NS4zLDUzLjYsNzYuNCw1Mi44TDc2LjQsNTIuOHoiLz4KDTwvZz4KDTwvZz4KDTwvc3ZnPg==";; // 如果当前网址是 https://rdfplayer.mrgaocloud.com/,不创建图标 if (window.location.hostname !== 'rdfplayer.mrgaocloud.com') { // 使用DOMContentLoaded确保DOM完全加载 if (document.readyState === 'complete' || document.readyState === 'interactive') { createButton(); } else { document.addEventListener('DOMContentLoaded', createButton); } function createButton() { // 检查是否已存在按钮,避免重复创建 if (document.getElementById('imgid')) return; // 拖拽功能 var startDrag = function(target) { var getCss = function(o, key) { return o.currentStyle ? o.currentStyle[key] : document.defaultView.getComputedStyle(o, false)[key]; }; var params = { left: 0, top: 0, currentX: 0, currentY: 0, rectLeft: 0, rectTop: 0, rectRight: 0 }; if (getCss(target, "position") === "static") { target.style.position = "relative"; } if (getCss(target, "left") !== "auto") { params.left = getCss(target, "left"); } if (getCss(target, "top") !== "auto") { params.top = getCss(target, "top"); } target.addEventListener("mousedown", function(event) { moving = true; params.rectLeft = target.getBoundingClientRect().left + document.body.scrollLeft; params.rectTop = target.getBoundingClientRect().top + document.body.scrollTop; params.rectRight = document.documentElement.clientWidth - target.getBoundingClientRect().right; if (event.preventDefault) { event.preventDefault(); } else { event.returnValue = false; } var e = event; params.currentX = e.clientX; params.currentY = e.clientY; document.addEventListener("mousemove", function(event) { if (moving == false) { return 0; } am = true; var e = event ? event : window.event; var nowX = e.clientX, nowY = e.clientY; var disX = nowX - params.currentX, disY = nowY - params.currentY; if (disX < 0 && Math.abs(disX) > params.rectLeft) { disX = -params.rectLeft; } if (disY < 0 && Math.abs(disY) > params.rectTop) { disY = -params.rectTop; } if (disX > 0 && disX > params.rectRight) { disX = params.rectRight; } target.style.left = parseInt(params.left) + disX + "px"; target.style.top = parseInt(params.top) + disY + "px"; }); document.addEventListener("mouseup", function() { moving = false; setTimeout(function() { am = false; }, 50); if (getCss(target, "left") !== "auto") { params.left = getCss(target, "left"); } if (getCss(target, "top") !== "auto") { params.top = getCss(target, "top"); } }); }); }; // 创建图标 var ele = document.createElement("img"); ele.id = "imgid"; ele.style = "margin: 150px 0px 0px 10px;width:60px;position: fixed;top:0px;z-index: 99999;"; ele.src = logo; document.body.appendChild(ele); startDrag(document.getElementById('imgid')); // 跳转解析站并传递B站地址的函数 function jumpToPlayer() { if (am == false) { // 重置状态 hasPlayed = false; moving = false; // 直接打开带URL参数的解析站 var videoUrl = encodeURIComponent(window.location.href); var targetUrl = `https://rdfplayer.mrgaocloud.com/?url=${videoUrl}`; // 打开新页面 window.open(targetUrl, "_blank"); } } // 点击事件 document.getElementById("imgid").addEventListener("click", jumpToPlayer); // 键盘快捷键事件 document.addEventListener("keydown", function(e) { // 检测是否按下 Shift + F9 if (e.shiftKey && e.key === "F9") { jumpToPlayer(); } }); } } // 创建自定义提示框 const customHint = document.createElement('div'); customHint.style.position = 'fixed'; // 固定位置,脱离父元素限制 customHint.style.top = '50%'; customHint.style.left = '50%'; customHint.style.transform = 'translate(-50%, -50%)'; customHint.style.backgroundColor = 'rgba(0, 0, 0, 0.7)'; customHint.style.color = 'white'; customHint.style.padding = '5px 10px'; customHint.style.borderRadius = '5px'; customHint.style.display = 'none'; customHint.style.zIndex = '9999'; // 确保在最上层 // 初始挂载(先加到 body) document.body.appendChild(customHint); // 监听全屏变化,确保提示框始终添加在全屏容器中 document.addEventListener('fullscreenchange', () => { const fsElement = document.fullscreenElement; if (fsElement && !fsElement.contains(customHint)) { fsElement.appendChild(customHint); } else if (!fsElement && !document.body.contains(customHint)) { document.body.appendChild(customHint); } }); // 快进/快退90s控制:Ctrl+←& Ctrl+→ document.addEventListener('keydown', function(e) { // 只处理Ctrl+方向键的组合 if (!e.ctrlKey || (e.code !== 'ArrowLeft' && e.code !== 'ArrowRight')) return; // 排除输入框的情况 if (e.target.tagName === 'INPUT' || e.target.tagName === 'TEXTAREA') return; // 获取视频元素 const video = document.querySelector('video'); if (!video) { console.warn('未找到video元素'); return; } const seekAmount = 85; // 快进/快退的秒数 let feedbackText = ''; if (e.code === 'ArrowLeft') { video.currentTime = Math.max(0, video.currentTime - seekAmount); feedbackText = `后退90秒,当前: ${formatTime(video.currentTime - 5)}`; } else if (e.code === 'ArrowRight') { video.currentTime = Math.min(video.duration, video.currentTime + seekAmount); feedbackText = `快进90秒,当前: ${formatTime(video.currentTime + 5)}`; } // 显示反馈提示 customHint.textContent = feedbackText; customHint.style.display = 'block'; setTimeout(() => customHint.style.display = 'none', 2000); }); // 格式化时间的函数 function formatTime(seconds) { const minutes = Math.floor(seconds / 60); const secs = Math.floor(seconds % 60); return `${minutes}:${secs < 10 ? '0' + secs : secs}`; } // 限定网页生效的条件 if (window.location.hostname.includes('rdfplayer.mrgaocloud.com') || window.location.pathname.includes('/player/')) { // 第一步:通过GM_addStyle强制注入CSS(最高优先级) GM_addStyle(` .sidebar { width: 350px !important; min-width: 350px !important; max-width: 350px !important; } `); // 第二步:DOM加载后再次强制设置内联样式 window.addEventListener('DOMContentLoaded', function() { const sidebar = document.querySelector('.sidebar'); if (sidebar) { // 添加调试标记 sidebar.dataset.widthForced = 'true'; // 内联样式覆盖 sidebar.style.setProperty('width', '350px', 'important'); sidebar.style.setProperty('min-width', '350px', 'important'); sidebar.style.setProperty('max-width', '350px', 'important'); console.log('侧边栏宽度已强制锁定为350px'); console.log('实际宽度:', sidebar.offsetWidth + 'px'); } }); // 第三步:3秒后最终确认(应对动态加载) setTimeout(() => { const sidebar = document.querySelector('.sidebar'); if (sidebar && sidebar.offsetWidth !== 350) { sidebar.style.cssText = 'width: 350px !important; min-width: 350px !important; max-width: 350px !important;'; console.warn('检测到宽度被修改,已重新强制设置'); } }, 3000); // 样式优化 const style = document.createElement('style'); style.textContent = ` .shortcut-hint { position: fixed; left: 20px; bottom: 60px; background: rgba(0,0,0,0.85); color: white; padding: 12px; border-radius: 8px; font-family: Arial, sans-serif; font-size: 14px; z-index: 9999 pointer-events: none; opacity: 0; transition: opacity 0.3s; box-shadow: 0 2px 8px rgba(0,0,0,0.3); } .hint-visible { opacity: 1 !important; pointer-events: auto; } `; document.head.appendChild(style); // 创建提示元素(直接附加到body) const hint = document.createElement('div'); hint.className = 'shortcut-hint'; hint.innerHTML = `