YouTube 视频长按二倍速播放

在 YouTube 鼠标长按视频时启用二倍速播放功能

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name         YouTube 视频长按二倍速播放
// @namespace    http://tampermonkey.net/
// @version      1.1
// @description  在 YouTube 鼠标长按视频时启用二倍速播放功能
// @author       Sulley-naer
// @license      MIT
// @match        https://www.youtube.com/*
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    let isLongPress = false;
    let longPressTimer;
    let video;

    function enable2xPlayback() {
        if (video.playbackRate === 1) {
            video.playbackRate = 2;
        } else {
            video.playbackRate = 1;
        }
    }

    function handleKeyDown(event) {
        if (event.key === 'ArrowRight') {
            longPressTimer = setTimeout(() => {
                isLongPress = true;
                enable2xPlayback();
            }, 1000); // Adjust the duration for long press as needed (in milliseconds)
        }
    }

    function handleKeyUp(event) {
        if (event.key === 'ArrowRight') {
            clearTimeout(longPressTimer);
            isLongPress = false;
        }
    }

    function init() {
        video = document.querySelector('video');
        if (!video) {
            console.error('Video element not found');
            return;
        }

        document.addEventListener('keydown', handleKeyDown);
        document.addEventListener('keyup', handleKeyUp);
        video.addEventListener('keydown', (event) => {
            if (event.key === 'ArrowRight') {
                event.preventDefault();
            }
        });
    }

    window.addEventListener('DOMContentLoaded', init);
})();