Bilibili跳过片头片尾

墨 燝 最后更新于 2024-11-04 113 次阅读


因为有看切片剧的需求,所以用chatgpt改了别人的代码,添加了几个按钮就不会绑定奇怪的键盘按键还忘了功能是啥了。不过目前没有做本地的跳过时长存储,应该也不需要吧(大概

// ==UserScript==
// @name         BiliBili跳过片头片尾
// @namespace    http://tampermonkey.net/
// @version      2024-11-04
// @description  添加控制按钮用于跳过片头片尾设置
// @match        *://www.bilibili.com/*
// @icon         
// @grant        none
// ==/UserScript==

let skip_IntroLength = 0;
let skip_OutroLength = 0;

(function() {
    'use strict';

    // 创建按钮容器
    const buttonContainer = document.createElement("div");
    buttonContainer.style.position = "fixed";
    buttonContainer.style.bottom = "20px";
    buttonContainer.style.right = "20px";
    buttonContainer.style.display = "flex";
    buttonContainer.style.flexDirection = "column";
    buttonContainer.style.gap = "10px";
    buttonContainer.style.zIndex = "9999";
    document.body.appendChild(buttonContainer);

    // 创建手动设置按钮
    const manualButton = document.createElement("button");
    manualButton.textContent = "手动设置时长";
    manualButton.style.padding = "10px";
    manualButton.style.backgroundColor = "#6DD3CE";
    manualButton.style.color = "#fff";
    manualButton.style.border = "none";
    manualButton.style.borderRadius = "5px";
    manualButton.style.cursor = "pointer";
    buttonContainer.appendChild(manualButton);

    // 创建设定片头按钮
    const setIntroButton = document.createElement("button");
    setIntroButton.textContent = "设为片头时间";
    setIntroButton.style.padding = "10px";
    setIntroButton.style.backgroundColor = "#C8E9A0";
    setIntroButton.style.color = "#fff";
    setIntroButton.style.border = "none";
    setIntroButton.style.borderRadius = "5px";
    setIntroButton.style.cursor = "pointer";
    buttonContainer.appendChild(setIntroButton);

    // 创建设定片尾按钮
    const setOutroButton = document.createElement("button");
    setOutroButton.textContent = "设为片尾时间";
    setOutroButton.style.padding = "10px";
    setOutroButton.style.backgroundColor = "#F7A278";
    setOutroButton.style.color = "#fff";
    setOutroButton.style.border = "none";
    setOutroButton.style.borderRadius = "5px";
    setOutroButton.style.cursor = "pointer";
    buttonContainer.appendChild(setOutroButton);

    // 手动设置跳过时长
    manualButton.addEventListener("click", () => {
        const newIntroLength = prompt("请输入片头跳过时间(秒):", skip_IntroLength);
        const newOutroLength = prompt("请输入片尾跳过时间(秒):", skip_OutroLength);

        if (!isNaN(parseFloat(newIntroLength))) {
            skip_IntroLength = parseFloat(newIntroLength);
        }
        if (!isNaN(parseFloat(newOutroLength))) {
            skip_OutroLength = parseFloat(newOutroLength);
        }
    });

    // 设置当前播放时间为片头时长
    setIntroButton.addEventListener("click", () => {
        const video = document.querySelector("#bilibili-player video");
        if (video) {
            skip_IntroLength = video.currentTime;
            alert(`片头时长已设置为:${skip_IntroLength.toFixed(2)} 秒`);
        } else {
            alert("未找到视频元素!");
        }
    });

    // 设置当前播放时间为片尾时长
    setOutroButton.addEventListener("click", () => {
        const video = document.querySelector("#bilibili-player video");
        if (video) {
            skip_OutroLength = video.duration - video.currentTime;
            alert(`片尾时长已设置为:${skip_OutroLength.toFixed(2)} 秒`);
        } else {
            alert("未找到视频元素!");
        }
    });

    // 定时跳过片头和片尾
    setInterval(() => {
        const video = document.querySelector("#bilibili-player video");
        if (video && !isNaN(video.duration)) {
            const currentTime = video.currentTime;
            if (currentTime < skip_IntroLength) {
                video.currentTime = skip_IntroLength;
            } else if (currentTime > (video.duration - skip_OutroLength) && currentTime < (video.duration - 2)) {
                video.currentTime = video.duration;
            }
        }
    }, 2000);
})();
此作者没有提供个人介绍
最后更新于 2024-11-04