【工具】JS脚本|网页任意视频倍速播放(包括MOOC、本地视频、其他的视频)

news2025/1/22 20:48:03

  只要浏览器播放视频时用的是<video>,而且当前页面只有这一个视频,就可以用这个脚本。

  刚好也是世界杯 CSDN 博客的活动了,虽然对活动没什么兴趣但是还是写一句和活动相关的话吧——世界杯为什么要看直播呢!不如一起来倍速观看世界杯吧!

  好吧,其实这是我很久以前为了倍速看MOOC视频,所以写的一个脚本,一直没有专门写博客去介绍它。刚刚,我想倍速看新闻联播,才发现忘记写博客了。

  浏览器视频倍速播放的原理非常容易,我也是看了一下网页源代码才发现的。自从发现了这一点之后,我连本地视频都特别喜欢直接用浏览器播放。

文章目录

  • 脚本链接
  • 脚本功能
  • 脚本代码
  • 脚本原理

脚本链接

Greasy Fork 链接:https://greasyfork.org/zh-CN/scripts/449828-任意视频倍速播放。

注:如果你的浏览器有可以运行 JS 脚本的扩展插件,那么点击即可安装

脚本功能

PC端,任意浏览器视频倍速播放,按键调速。

其实除了倍速播放,还有调进度、调音量的功能。这是因为我觉得挺方便,就一块儿加上了。

① +/-0.25倍速:按w/s键;
② 切换整数倍速:按1/2/3/4键;
③ +/-0.5s:按→/←键;
④ +/-10%音量:按↑/↓键。

注:目前测试了mooc、新闻联播网站、本地视频,都可以,如果有不可以的网站请反馈给我。

注:用浏览器播放本地视频,需要将扩展插件设置为“允许访问文件URL”。

脚本代码

// ==UserScript==
// @name         任意视频倍速播放
// @namespace    http://tampermonkey.net/
// @version      0.2
// @description  任意浏览器视频倍速播放,按键调速。
// @author       shandianchengzi
// @include      *
// @icon         
// @license      MIT
// @grant        none
// ==/UserScript==
 
 
//轻提醒
function Toast(msg, duration) {
    let p1 = new Promise((resolve,reject)=>{
        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);
    });
}
 
async function mainFunc(){
    document.body.onkeydown = function(ev) {
        var e = ev || event;
        let video = document.getElementsByTagName('video')[0]
        console.log('test');
        if(video){
            switch(e.keyCode){
                case 87: //w键
                    video.playbackRate += 0.25;
                    Toast(video.playbackRate,100);
                    break;
                case 83: //s键
                    video.playbackRate -= 0.25
                    Toast(video.playbackRate,100);
                    break;
                case 39: //→
                    video.currentTime += 5;
                    break;
                case 37: //←
                    video.currentTime -= 5;
                    break;
                case 38: //↑
                    video.volume += 0.1;
                    Toast(video.volume,100);
                    break;
                case 40: //↓
                    video.volume -= 0.1;
                    Toast(video.volume,100);
                    break;
                case 49: //1
                    video.playbackRate = 1;
                    Toast(video.playbackRate,100);
                    break;
                case 50: //2
                    video.playbackRate = 2;
                    Toast(video.playbackRate,100);
                    break;
                case 51: //3
                    video.playbackRate = 3;
                    Toast(video.playbackRate,100);
                    break;
                case 52: //4
                    video.playbackRate = 4;
                    Toast(video.playbackRate,100);
                    break;
                default:
                    return e;
            }
        }
    }
}
 
(function() {
    'use strict';
    window.onhashchange=mainFunc;
    mainFunc();
    // Your code here...
})();

脚本原理

  原理究极无敌简单,就是修改video这个DOM元素的playbackRate或其他属性。
  唯一体现了一点点难度的,可能就只是调整之后弹出来的Toast轻提醒,如下:

在这里插入图片描述

  我今天上号发现安装量还挺不错的~!说明蛮多人都有按键播放需求。所以来补一个博客,引一下流(bushi)。

在这里插入图片描述

如果后续代码有更新,我会优先更新 Greasy Fork 里的代码和介绍,虽说更新的几率微乎其微。转载或修改请标明出处:https://greasyfork.org/zh-CN/scripts/449828-任意视频倍速播放。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/89915.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ssm+Vue计算机毕业设计校园洗衣机预约系统(程序+LW文档)

ssmVue计算机毕业设计校园洗衣机预约系统&#xff08;程序LW文档&#xff09; 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目…

Linux内存查看通用方法(二): kernel空间

接上文&#xff1a; Linux内存查看通用方法&#xff08;一&#xff09;&#xff1a; user空间_红桃Jk的博客-CSDN博客_linux内存查看在嵌入式linux上&#xff0c;统计内存情况的一般方法https://blog.csdn.net/qq_34597963/article/details/126023451?spm1001.2014.3001.5501…

用 CSS 从零写一个时间轴效果

时间轴效果介绍 在前端开发中&#xff0c;我们会遇到一些场景特别适合用时间轴来展示&#xff0c;例如下面按照日期时间来记录发生的事件&#xff1a; 还可以做成下面这种比较流行的左右对称卡片风格的时间轴&#xff1a; 如果再稍加装饰&#xff0c;还能有更加高大上的效果&a…

跨域的部分理解

1、跨域的原理 跨域&#xff0c;是指浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的。 同源策略&#xff0c;是浏览器对 JavaScript 实施的安全限制&#xff0c;只要协议、域名、端口有任何一个不同&#xff0c;都被当作是不同的域。 跨域原理&#xff0c;即是通…

量子计算(十四):超导量子芯片

文章目录 超导量子芯片 超导量子芯片 超导量子计算是基于超导电路的量子计算方案&#xff0c;其核心器件是超导约瑟夫森结。超导量子电路在设计、制备和测量等方面&#xff0c;与现有的集成电路技术具有较高的兼容性&#xff0c;对量子比特的能级与耦合可以实现非常灵活的设计…

node.js按照和配置环境变量

下载地址 选择自己适合的版本 Download | Node.js 安装 傻瓜式安装就好了 安装完成后 查看是否安装成功 打开黑窗口 node -v npm -v 配置全局安装的模块路径和缓存路径 在nodejs根目录,创建node_global&#xff0c;node_cache文件夹 命令提示符 以管理员方式运行 我的目…

基于springboot疫情防控期间某村外出务工人员信息管理系统设计与实现的源码+文档

摘 要 网络的广泛应用给生活带来了十分的便利。所以把疫情防控期间某村外出务工人员信息管理与现在网络相结合&#xff0c;利用java技术建设疫情防控期间某村外出务工人员信息管理系统&#xff0c;实现疫情防控期间某村外出务工人员信息的信息化。则对于进一步提高疫情防控期…

Oracle建表与创建序列

目录 一、简单建表 二、查看表结构(在Xshell中输入才能够执行) 三、设置自增序列 (一)普通自增序列 1.创建序列&#xff0c;oracle中没有自增&#xff0c;创建序列相当于等差数列自增 2.删除序列 3.建表的同时设置主键自增的步骤 (二)复杂序列 1.复杂序列模板 2.复杂…

架构设计(二):数据库复制

架构设计&#xff08;二&#xff09;&#xff1a;数据库复制 作者&#xff1a;Grey 原文地址&#xff1a; 博客园&#xff1a;架构设计&#xff08;二&#xff09;&#xff1a;数据库复制 CSDN&#xff1a;架构设计&#xff08;二&#xff09;&#xff1a;数据库复制 在架…

100-数据结构与算法(下篇)

现在我们续写上一章博客的内容&#xff08;即99章博客的内容&#xff09; 快速排序&#xff1a; 同冒泡排序一样&#xff0c;快速排序也属于交换排序&#xff0c;通过元素之间的比较和交换位置来达到排序的目的 不同的是&#xff0c;冒泡排序在每一轮中只把1个元素冒泡到数列…

彻底搞懂JavaScript防抖与节流

今天为大家带来一篇JS重难点的知识体系&#xff0c;这也是前端高薪必备的重难点知识&#xff0c;而且防抖与节流在各大企业前端面试过程中经常会考到的高频面试题&#xff01; 为了更好的帮助大家理解防抖与节流&#xff0c;我们特意从我们的系统班&#xff08;星辰班&#xff…

[阶段4 企业开发进阶] 6. Dubbo

文章目录1 基础理论1.1分布式基础理论1.2 发展演变1.3 RPC2 Dubbo2.1 基本概念2.2 Dubbo架构2.3 环境搭建Windows环境安装教程Linux环境安装教程3 案例演示3.1 需求分析3.2 工程架构分包粒度3.3 创建模块3.4 使用Dubbo配置版注解版4 监控中心4.1 安装4.2 监控中心配置5 整合Spr…

Java中的成员内部类

一、什么是成员内部类 成员内部类就是定义在外部类成员位置(属性/方法的位置)的类。成员内部类就是个成员。 二、为什么要有成员内部类 使用场景&#xff1a;除了它的外部类&#xff0c;不会被其他类使用&#xff0c;就可以使用成员内部类。有两种情况&#xff1a;1.不可能有…

大数据面试之Spark Core常见题目

大数据面试之Spark Core常见题目 1 Spark任务的划分 1、Application&#xff1a;初始化一个SparkContext即生成一个Application。 2、Job&#xff1a;一个Action算子会生成一个Job&#xff0c;有多个Action算子就有多个Job。 3、Stage&#xff1a;Stage等于宽依赖的个数加1…

特殊符号(一)—反斜杠 ” \ “(旋转光标和倒计时的实现)

特殊符号一.功能1.功能一&#xff1a;续航符2.功能二&#xff1a;转义符二.旋转光标和倒计时一.功能 1.功能一&#xff1a;续航符 顾名思义&#xff0c;就是连续的意思&#xff0c;主要用于换行的时候&#xff0c;看例子 以上是一个简单的判断语句&#xff0c;如果if里面的判断…

Win10十二月更新系统讲了什么?

微软今天凌晨发布了win10系统12月最新的累积更新补丁&#xff0c;根据该公司的公告&#xff0c;更新 KB5021233 将版本号增加到构建 19042.2364 &#xff08;20H2&#xff09;、19043.2364 &#xff08;21H1&#xff09;、19044.2364 &#xff08;21H2&#xff09; 和 19045.23…

01-35-springcloud-zk-eureka-consul-cap-父工程

01-springcloud-入门理论等&#xff1a; 微服务 1、什么是微服务 微服务是一种架构风格一个应用拆分为一组小型服务每个服务运行在自己的进程内&#xff0c;也就是可独立部署和升级服务之间使用轻量级HTTP交互服务围绕业务功能拆分可以由全自动部署机制独立部署去中心化&…

产品外观设计一一素描

在反映产品外观设计时&#xff0c;应根据产品的不同功能选择反映方法&#xff0c;以便更清晰地表达创作者的设计理念。首先&#xff0c;我们应该运用透视图的规律性来构建空间框架结构&#xff0c;将镜头中的许多外观元素有机地结合起来&#xff0c;并根据设计科学地安排镜头中…

Portal数据清理过程说明

Portal门户集成平台作为统一的门户搭建和展现平台&#xff0c;提供综合门户、信息门户、应用门户、数据门户等不同类型门户的建设能力&#xff0c;可以为企业构建门户网站、内部业务中心&#xff0c;同时对企业文档资料进行整合、统一归档&#xff0c;对内部、外部提供资料。通…

基于微信小程序的劳务咨询系统设计与实现-计算机毕业设计

项目介绍 随着科学技术的飞速发展&#xff0c;各行各业都在努力与现代先进技术接轨&#xff0c;通过科技手段提高自身的优势&#xff1b;对于劳务咨询服务平台小程序当然也不能排除在外&#xff0c;随着网络技术的不断成熟&#xff0c;带动了劳务咨询服务平台小程序&#xff0…