// 视频进度控制脚本 - 直接复制到浏览器控制台运行 // 支持左右箭头键快进/快退视频 (function () { 'use strict'; // 配置 const SEEK_SECONDS = 5; // 每次跳转的秒数 const LONG_SEEK_SECONDS = 10; // 长按Shift时跳转的秒数 console.log('🎬 视频键盘控制已启用'); console.log(`← 左箭头: 后退 ${SEEK_SECONDS} 秒`); console.log(`→ 右箭头: 前进 ${SEEK_SECONDS} 秒`); console.log(`Shift + ← / →: 前进/后退 ${LONG_SEEK_SECONDS} 秒`); console.log(`空格键: 播放/暂停`); console.log(`↑ / ↓: 音量增减`); // 查找页面上的视频元素 function getVideoElement() { // 优先查找正在播放的视频 const videos = document.querySelectorAll('video'); for (let video of videos) { if (!video.paused || video.currentTime > 0) { return video; } } // 如果没有正在播放的,返回第一个视频 return videos[0] || null; } // 显示提示信息 function showToast(message) { const existingToast = document.getElementById('video-seek-toast'); if (existingToast) { existingToast.remove(); } const toast = document.createElement('div'); toast.id = 'video-seek-toast'; toast.textContent = message; toast.style.cssText = ` position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); background: rgba(0, 0, 0, 0.8); color: white; padding: 15px 30px; border-radius: 8px; font-size: 18px; font-weight: bold; z-index: 999999; pointer-events: none; animation: fadeInOut 1s ease-in-out; `; // 添加动画样式 if (!document.getElementById('video-seek-toast-style')) { const style = document.createElement('style'); style.id = 'video-seek-toast-style'; style.textContent = ` @keyframes fadeInOut { 0% { opacity: 0; transform: translate(-50%, -50%) scale(0.8); } 20% { opacity: 1; transform: translate(-50%, -50%) scale(1); } 80% { opacity: 1; transform: translate(-50%, -50%) scale(1); } 100% { opacity: 0; transform: translate(-50%, -50%) scale(0.8); } } `; document.head.appendChild(style); } document.body.appendChild(toast); setTimeout(() => toast.remove(), 1000); } // 格式化时间 function formatTime(seconds) { const h = Math.floor(seconds / 3600); const m = Math.floor((seconds % 3600) / 60); const s = Math.floor(seconds % 60); if (h > 0) { return `${h}:${m.toString().padStart(2, '0')}:${s.toString().padStart(2, '0')}`; } return `${m}:${s.toString().padStart(2, '0')}`; } // 键盘事件处理 function handleKeyPress(e) { const video = getVideoElement(); if (!video) { console.warn('未找到视频元素'); return; } // 如果焦点在输入框上,不处理 const activeElement = document.activeElement; if (activeElement && ( activeElement.tagName === 'INPUT' || activeElement.tagName === 'TEXTAREA' || activeElement.isContentEditable )) { return; } let seekAmount = e.shiftKey ? LONG_SEEK_SECONDS : SEEK_SECONDS; let handled = false; switch (e.key) { case 'ArrowLeft': // 左箭头 - 后退 video.currentTime = Math.max(0, video.currentTime - seekAmount); showToast(`⏪ ${formatTime(video.currentTime)}`); handled = true; break; case 'ArrowRight': // 右箭头 - 前进 video.currentTime = Math.min(video.duration, video.currentTime + seekAmount); showToast(`⏩ ${formatTime(video.currentTime)}`); handled = true; break; case ' ': // 空格 - 播放/暂停 if (video.paused) { video.play(); showToast('▶️ 播放'); } else { video.pause(); showToast('⏸️ 暂停'); } handled = true; break; case 'ArrowUp': // 上箭头 - 增加音量 video.volume = Math.min(1, video.volume + 0.1); showToast(`🔊 音量: ${Math.round(video.volume * 100)}%`); handled = true; break; case 'ArrowDown': // 下箭头 - 减少音量 video.volume = Math.max(0, video.volume - 0.1); showToast(`🔉 音量: ${Math.round(video.volume * 100)}%`); handled = true; break; case 'f': case 'F': // F键 - 全屏 if (document.fullscreenElement) { document.exitFullscreen(); } else { video.requestFullscreen().catch(err => { console.error('无法全屏:', err); }); } handled = true; break; case 'm': case 'M': // M键 - 静音 video.muted = !video.muted; showToast(video.muted ? '🔇 静音' : '🔊 取消静音'); handled = true; break; } if (handled) { e.preventDefault(); e.stopPropagation(); } } // 移除旧的监听器(如果存在) if (window.videoSeekControlListener) { document.removeEventListener('keydown', window.videoSeekControlListener); } // 添加新的监听器 window.videoSeekControlListener = handleKeyPress; document.addEventListener('keydown', handleKeyPress, true); console.log('✅ 键盘控制已激活!'); // 显示启动提示 showToast('⌨️ 键盘控制已启动'); })();视频进度控制脚本
张小明
前端开发工程师
像素级革命:ImageGPT视觉大模型的技术演进与产业落地指南
像素级革命:ImageGPT视觉大模型的技术演进与产业落地指南 【免费下载链接】imagegpt-medium 项目地址: https://ai.gitcode.com/hf_mirrors/openai/imagegpt-medium 在深度学习技术迅猛发展的今天,Transformer架构正以前所未有的速度重塑计算机视…
16、利用 AWK 和 Python 进行数据处理与脚本编写
利用 AWK 和 Python 进行数据处理与脚本编写 1. 基于字段数量的条件处理 当用户直接登录服务器的物理控制台,而非通过远程或图形伪终端登录时, lastlog 输出将不显示主机字段。例如,在 CentOS 主机上直接登录到 tty1 控制台并避免使用 GUI,之前 AWK 控制文件的输出显…
黑科技软件,确实牛X!
软件介绍 今天介绍三款软件,一款是电脑马赛克,一款是微博下载工具,一款是 第一款:pixel(电脑屏幕马赛克) 问问大家,你离开电脑时,是让电脑屏幕常亮着,还是用“Win键L”锁…
DeepSeek-V2-Chat-0628强势登顶开源模型榜首,三大核心能力改写行业竞争格局
DeepSeek-V2-Chat-0628强势登顶开源模型榜首,三大核心能力改写行业竞争格局 【免费下载链接】DeepSeek-V2-Chat-0628 DeepSeek-V2-Chat-0628,开源创新之作,AI聊天机器人性能卓越,编码能力出众。在LMSYS Chatbot Arena榜单脱颖而出…
结构体设计艺术:Host侧Tiling数据结构定义详解
目录 摘要 1 引言:Tiling数据结构——连接Host与Device的桥梁 1.1 Tiling数据的本质价值 1.2 设计哲学:从硬件约束到数据结构 2 Tiling数据结构基础原理 2.1 内存模型与对齐约束 2.1.1 内存对齐的数学基础 2.1.2 结构体字段布局优化 2.2 基础Ti…