TimeHookerLite

Set adjustable playback speed on selected websites

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         TimeHookerLite
// @namespace    https://cozian.timehooker.com
// @version      1.4
// @description  Set adjustable playback speed on selected websites
// @author       cozian
// @license      MIT
// @include      *
// @run-at       document-start
// @grant        GM_registerMenuCommand
// @grant        GM_getValue
// @grant        GM_setValue
// ==/UserScript==

(function() {
    'use strict';

    // Retrieve include list and playback speed, or initialize defaults
    let includeList = GM_getValue("includeList", []);
    let playbackSpeed = GM_getValue("playbackSpeed", 10); // Default speed of 10x

    // Function to add the current site to the include list
    function addToIncludeList() {
        const currentSite = window.location.hostname;
        if (!includeList.includes(currentSite)) {
            includeList.push(currentSite);
            GM_setValue("includeList", includeList);
            alert(`Added ${currentSite} to include list.`);
        } else {
            alert(`${currentSite} is already in the include list.`);
        }
    }

    // Function to set a new playback speed
    function setPlaybackSpeed() {
        const newSpeed = prompt("Enter the new playback speed (e.g., 10 for 10x):", playbackSpeed);
        if (newSpeed && !isNaN(newSpeed)) {
            playbackSpeed = parseFloat(newSpeed);
            GM_setValue("playbackSpeed", playbackSpeed);
            alert(`Playback speed set to ${playbackSpeed}x.`);
        } else {
            alert("Invalid speed value. Please enter a numeric value.");
        }
    }

    // Register menu commands for adding sites and setting playback speed
    GM_registerMenuCommand("Add this site to TimeHookerLite Include List", addToIncludeList);
    GM_registerMenuCommand("Set TimeHookerLite Playback Speed", setPlaybackSpeed);

    // Check if the current site is in the include list before running the script
    if (!includeList.includes(window.location.hostname)) {
        return;
    }

    // Override setInterval to accelerate intervals based on the playback speed
    const originalSetInterval = window.setInterval;
    window.setInterval = function(callback, delay, ...args) {
        return originalSetInterval(callback, delay / playbackSpeed, ...args);
    };

    // Override setTimeout to accelerate timeouts based on the playback speed
    const originalSetTimeout = window.setTimeout;
    window.setTimeout = function(callback, delay, ...args) {
        return originalSetTimeout(callback, delay / playbackSpeed, ...args);
    };

    // Override Date.now to simulate accelerated time
    const originalDateNow = Date.now;
    Date.now = function() {
        return originalDateNow() * playbackSpeed;
    };

    // Override performance.now to simulate accelerated time
    const originalPerformanceNow = performance.now.bind(performance);
    performance.now = function() {
        return originalPerformanceNow() * playbackSpeed;
    };
})();