当前位置: 首页 > news >正文

视频进度控制脚本

// 视频进度控制脚本 - 直接复制到浏览器控制台运行 // 支持左右箭头键快进/快退视频 (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('⌨️ 键盘控制已启动'); })();
http://www.cnnetsun.cn/news/43201.html

相关文章:

  • 90%前端都踩过的JS内存黑洞:从《你不知道的JavaScript》解锁底层逻辑与避坑指南
  • 阿里Qoder IDE革新编程范式:自然语言驱动的全流程AI开发平台
  • Flutter + FastAPI 30天速成计划自用并实践-第10天-组件化开发实践
  • 本地化部署腾讯混元大模型并集成Elasticsearch构建智能检索系统全攻略
  • 【面板数据】全球稀土贸易数据(2018-2024年)
  • 【后端】【Java】一文详解Spring Boot 统一日志与链路追踪实践
  • 无需运动恢复结构(SfM)的层级训练三维高斯溅射(3D Gaussian Splatting)
  • CS配合CrossC2插件,实现MacOS/Linux上线
  • 4、Puppet 入门:从基础使用到主从架构搭建
  • 线性代数(五)向量空间与子空间
  • matlab debug 调试程序
  • VibeVoice-Large-Q8:语音模型存储与性能的革命性突破——8位选择性量化技术深度解析
  • 腾讯开源双引擎AI模型:混元3D开创多模态创作新纪元,千倍效率革命重塑数字内容生产
  • Csharp学习笔记——常用类、集合框架、泛型、字典精华总结
  • 下载神器downkyi:5分钟掌握任务优先级管理技巧
  • 63.测试策略-领域模型测试集成测试实操方法-附测试框架选择
  • 1.2 主流大模型初探:解锁OpenAI、Gemini、Claude的强大能力
  • Ring-mini-linear-2.0:融合线性注意力与稀疏专家的下一代高效大语言模型
  • MFC消息处理机制
  • 商业级图像合成引擎6.0版本重磅发布:解锁跨场景视觉创作新范式
  • MyBatis-Plus与Spring整合(02--Service的代理)
  • 11、渗透测试实战:目标探索、利用与攻击行动
  • 16、攻击收尾:报告与撤离
  • 20、树莓派的替代项目探索
  • 事件查看器-事件ID
  • 单步出图革命:Consistency Model如何以100倍效率重构AI绘画产业格局
  • 搭建鸿蒙PC命令行适配环境测试hello程序
  • 编辑相似度(Edit Similarity):原理、演进与多模态扩展
  • 【深度解析】MiniCPM 2.0:端侧大模型的技术性进展与技术革新
  • ClickHouse 快速入门