Greasy Fork is available in English.

bilibili弹幕隐藏快捷键(临时隐藏)

bilibili弹幕隐藏快捷键(临时隐藏,默认为 N 键,不是网页自带开关机制,网页自带开关快捷键为 D 键)

// ==UserScript==
// @name         bilibili弹幕隐藏快捷键(临时隐藏)
// @namespace    tonyu_balabala_03e6ea
// @version      1.3
// @description  bilibili弹幕隐藏快捷键(临时隐藏,默认为 N 键,不是网页自带开关机制,网页自带开关快捷键为 D 键)
// @author       Tony
// @icon          
// @license       MIT
// @match        *://*.bilibili.com/*
// @grant        GM_getValue
// @grant        GM_setValue
// @grant        GM_registerMenuCommand
// ==/UserScript==

(function() {
    'use strict';
    let danMuSwitchKC = GM_getValue('tony_danmu_switch_keycode', 78)
    let danMuSwitchKName = GM_getValue('tony_danmu_switch_keyname', 'n')
    let danMuSwitchMode = GM_getValue('tony_danmu_switch_mode', '1')
    function mySwitch(danMu) {
        if(danMu) {
            if(danMu.style.visibility == "") danMu.style.visibility="hidden"
            else danMu.style.visibility=""
        }
    }
    function switchDanmu() {
        let danMu1 = document.getElementsByClassName("bilibili-player-video-danmaku")[0]
        let danMu2 = document.getElementsByClassName("bilibili-player-video-adv-danmaku")[0]
        let danMu3 = document.getElementsByClassName("bilibili-player-video-bas-danmaku")[0]
        let danMu4 = document.getElementsByClassName("bpx-player-row-dm-wrap")[0]
        mySwitch(danMu1)
        mySwitch(danMu2)
        mySwitch(danMu3)
        mySwitch(danMu4)
    }
    function keydownHandler(e) {
        var target = e.target || {},
            isInput = ("INPUT" == target.tagName || "TEXTAREA" == target.tagName || "SELECT" == target.tagName || "EMBED" == target.tagName);
        // 如果是文本输入元素,或者不是一个真实的元素
        if(isInput || !target.tagName) return;
        // 如果是一个虚假的输入元素
        if(target && target.getAttribute && target.getAttribute('role') === 'textbox') return;
        if(e.keyCode == danMuSwitchKC) {
            document.removeEventListener('keydown', keydownHandler);
            switchDanmu()
        }
    }
    document.addEventListener('keydown', keydownHandler);
    document.addEventListener('keyup', function(e) {
        var target = e.target || {},
            isInput = ("INPUT" == target.tagName || "TEXTAREA" == target.tagName || "SELECT" == target.tagName || "EMBED" == target.tagName);
        // 如果是文本输入元素,或者不是一个真实的元素
        if(isInput || !target.tagName) return;
        // 如果是一个虚假的输入元素
        if(target && target.getAttribute && target.getAttribute('role') === 'textbox') return;
        if(e.keyCode == danMuSwitchKC) {
            if(danMuSwitchMode === '1') switchDanmu(e)
            document.addEventListener('keydown', keydownHandler);
        }
    });

    let hasSettingShow = false
    function showSetting() {
        if(hasSettingShow) return
        let settingBox = document.createElement("div");
        settingBox.setAttribute("style", `position: fixed !important;
        top: 10px !important;
        left: 50% !important;
        z-index:2147483647 !important;
        `)
        let contentBox = document.createElement('div')
        contentBox.setAttribute("style", `box-shadow: 0 0 10px rgba(100, 100, 100, 0.2) !important;
        max-height: calc(100vh - 60px) !important;
        max-width: 80vw !important;
        overflow: auto !important;
        background-color: rgb(235, 235, 235) !important;
        text-align: center !important;
        font-size: 13px !important;
        border-radius: 16px !important;
        white-space: nowrap;
        padding: 10px 16px 10px 16px !important;
        margin-left: -50% !important;
        margin-right: 50% !important;
        z-index:2147483647 !important;
        box-sizing: content-box !important;
        border: 2px solid rgb(100 100 100 / 10%) !important;
        `)
        if('backdropFilter' in document.documentElement.style) {
            contentBox.style.backgroundColor = 'rgba(235, 235, 235, 0.8)'
            contentBox.style.backdropFilter = 'saturate(50%) blur(14px)'
            //contentBox.style.transform = 'translateZ(0)'
        }
        if(getComputedStyle) {
            let fontFml = getComputedStyle(document.body, null)['font-family']
            if(fontFml) contentBox.style.fontFamily = fontFml
        }
        let settingContent = document.createElement('div')
        settingContent.setAttribute('style', 'font-weight: 600 !important;')

        let MemorySettingTitle = document.createElement('div')
        //MemorySettingTitle.setAttribute('style', 'margin-top:10px;')
        MemorySettingTitle.innerText = '弹幕临时隐藏开关模式'
        settingContent.appendChild(MemorySettingTitle)

        let danMuSwitchModeSelector = document.createElement('select')
        danMuSwitchModeSelector.setAttribute('style', 'margin-top:10px;padding:3px 10px;border:2px solid rgb(168,168,168);border-radius:10px;cursor:pointer;')
        let danMuSwitchModeOption1 = document.createElement('option')
        danMuSwitchModeOption1.value = '1'
        danMuSwitchModeOption1.innerText = '长按模式'
        danMuSwitchModeOption1.selected = danMuSwitchMode==='1'
        let danMuSwitchModeOption2 = document.createElement('option')
        danMuSwitchModeOption2.value = '2'
        danMuSwitchModeOption2.innerText = '敲击模式'
        danMuSwitchModeOption2.selected = danMuSwitchMode==='2'
        danMuSwitchModeSelector.appendChild(danMuSwitchModeOption1)
        danMuSwitchModeSelector.appendChild(danMuSwitchModeOption2)
        danMuSwitchModeSelector.addEventListener('change', function() {
            danMuSwitchMode = danMuSwitchModeSelector.value
            GM_setValue('tony_danmu_switch_mode', danMuSwitchMode)
        })
        settingContent.appendChild(danMuSwitchModeSelector)

        let KCSettingTitle = document.createElement('div')
        KCSettingTitle.setAttribute('style', 'margin-top:10px;')
        KCSettingTitle.innerText = '快捷键设置'
        settingContent.appendChild(KCSettingTitle)

        let KCSettingBox = document.createElement('div')
        KCSettingBox.setAttribute('style', 'margin-top:10px;')

        let KNameTitle = document.createElement('span')
        KNameTitle.innerText = '弹幕隐藏快捷键(点击修改→):'
        KNameTitle.setAttribute('style', 'margin-right:6px;')
        let KCSettingBtnBox = document.createElement('div')
        KCSettingBtnBox.setAttribute('style', 'display:none;margin-top:8px;')
        let KCSettingBtnOK = document.createElement('button')
        let KCSettingBtnCancel = document.createElement('button')
        let KName = document.createElement('button')
        KName.innerText = danMuSwitchKName
        KName.setAttribute('style', 'padding:6px 14px;border-radius:28px;color:rgb(5,107,0);background-color:rgb(240,240,240);border:2px solid rgb(150,150,150);cursor:pointer;')
        let clickSpdKC = danMuSwitchKC
        let clickSpdKName = danMuSwitchKName
        function keyupHandler(e) {
            e.stopPropagation()
            clickSpdKC = e.keyCode
            clickSpdKName = e.key
            KName.innerText = clickSpdKName
        }
        function kNameClickHandler() {
            clickSpdKC = danMuSwitchKC
            clickSpdKName = danMuSwitchKName
            KName.innerText = '请按键ヾ(•ω•`)o'
            KName.addEventListener('keydown', keyupHandler)
            KName.removeEventListener('click', kNameClickHandler)
            KCSettingBtnBox.style.display = 'block'
            KName.focus()
        }
        KName.addEventListener('click', kNameClickHandler)

        KCSettingBtnOK.innerText = '确认'
        KCSettingBtnOK.setAttribute('style', 'padding:8px 10px;border:0;color:white;background-color:rgb(25,207,20);border-radius:28px;cursor:pointer;')
        KCSettingBtnOK.addEventListener('click', function() {
            danMuSwitchKC = clickSpdKC
            danMuSwitchKName = clickSpdKName
            GM_setValue('tony_danmu_switch_keycode', clickSpdKC)
            GM_setValue('tony_danmu_switch_keyname', clickSpdKName)
            KName.innerText = danMuSwitchKName
            KName.removeEventListener('keydown', keyupHandler)
            KName.addEventListener('click', kNameClickHandler)
            KCSettingBtnBox.style.display = 'none'
        })

        KCSettingBtnCancel.innerText = '取消'
        KCSettingBtnCancel.setAttribute('style', 'margin-right:6px;padding:8px 10px;border:0;color:white;background-color:rgb(243,97,128);border-radius:28px;cursor:pointer;')
        KCSettingBtnCancel.addEventListener('click', function() {
            KName.innerText = danMuSwitchKName
            //                     let clickSpdKC = spdKCSettings[i]
            //                     let clickSpdKName = spdKNames[i]
            KName.removeEventListener('keydown', keyupHandler)
            KName.addEventListener('click', kNameClickHandler)
            KCSettingBtnBox.style.display = 'none'
        })
        KCSettingBox.appendChild(KNameTitle)
        KCSettingBox.appendChild(KName)
        KCSettingBtnBox.appendChild(KCSettingBtnCancel)
        KCSettingBtnBox.appendChild(KCSettingBtnOK)
        KCSettingBox.appendChild(KCSettingBtnBox)

        settingContent.appendChild(KCSettingBox)

        let hideBtnBox = document.createElement('div')
        hideBtnBox.setAttribute('style', 'margin-top:10px;')
        let hideBtn = document.createElement('button')
        hideBtn.innerText = '关闭面板'
        hideBtn.setAttribute('style', 'padding:8px 10px;border:0;color:white;background-color:rgb(50,130,236);border-radius:28px;cursor:pointer;')
        hideBtn.addEventListener('click', function() {
            document.documentElement.removeChild(settingBox)
            hasSettingShow = false
        })
        hideBtnBox.appendChild(hideBtn)
        settingContent.appendChild(hideBtnBox)

        let appreciateBtnBox = document.createElement('div')
        appreciateBtnBox.setAttribute('style', 'margin-top:10px;')
        let appreciateImg
        let appreciateBtn = document.createElement('button')
        appreciateBtn.innerText = '支持作者'
        appreciateBtn.setAttribute('style', 'padding:8px 10px;border:0;color:white;background-color:rgb(213, 183, 123);border-radius:28px;cursor:pointer;cursor:pointer;')
        let appreciateCancelBtnBox = document.createElement('div')
        appreciateCancelBtnBox.setAttribute('style', 'margin-top:10px;')
        let appreciateCancelBtn = document.createElement('button')
        appreciateCancelBtn.innerText = '∧'
        appreciateCancelBtn.setAttribute('style', 'padding:5px 10px;border:0;color:white;background-color:rgb(160, 160, 160);border-radius:28px;cursor:pointer;cursor:pointer;')
        appreciateCancelBtnBox.appendChild(appreciateCancelBtn)
        function appreciateCancelBtnClickHandler() {
            settingContent.removeChild(appreciateImg)
            settingContent.removeChild(appreciateCancelBtnBox)
            appreciateBtn.addEventListener('click', appreciateBtnClickHandler)
        }
        appreciateCancelBtn.addEventListener('click', appreciateCancelBtnClickHandler)
        function appreciateBtnClickHandler() {
            appreciateImg = document.createElement('img')
            appreciateImg.src = ''
            appreciateImg.alt = '支持作者'
            appreciateImg.setAttribute('style', 'margin-top:10px;max-width:240px;max-height:320px;min-width:180px;min-height:240px;border-radius:10px;')
            settingContent.insertBefore(appreciateImg, settingTip)
            settingContent.insertBefore(appreciateCancelBtnBox, settingTip)
            appreciateBtn.removeEventListener('click', appreciateBtnClickHandler)
        }
        appreciateBtn.addEventListener('click', appreciateBtnClickHandler)
        appreciateBtnBox.appendChild(appreciateBtn)
        settingContent.appendChild(appreciateBtnBox)

        let settingTip = document.createElement('div')
        settingTip.setAttribute('style', 'margin-top:10px;')
        settingTip.innerText = '设置完成后刷新页面,以确保生效'
        settingContent.appendChild(settingTip)

        contentBox.appendChild(settingContent)
        settingBox.appendChild(contentBox)
        document.documentElement.appendChild(settingBox)
        hasSettingShow = true
    }
    GM_registerMenuCommand('设置',showSetting)

})();