Greasy Fork is available in English.

哔哩哔哩(B站|Bilibili)全屏直播净化

1. 去掉B站(live.bilibili.com)网页全屏或者全屏时出现的讨厌的打赏工具栏的小工具,2. 去掉直播间左下或者右下马赛克的功能

// ==UserScript==
// @name         哔哩哔哩(B站|Bilibili)全屏直播净化
// @namespace    https://github.com/afyi/bliveclear
// @version      1.3.6.10
// @description  1. 去掉B站(live.bilibili.com)网页全屏或者全屏时出现的讨厌的打赏工具栏的小工具,2. 去掉直播间左下或者右下马赛克的功能
// @author       猫东东 <blog.del.pub>
// @match        *://live.bilibili.com/*
// @website      https://greasyfork.org/zh-CN/scripts/483878-b%E7%AB%99%E7%9B%B4%E6%92%AD%E5%85%A8%E5%B1%8F%E6%97%B6%E5%B7%A5%E5%85%B7%E6%A0%8F%E6%B8%85%E7%90%86
// @icon         
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    if (/live.bilibili.com/.test(location.host)) {
        console.log("B站直播全屏时工具栏清理");
        const observer = new MutationObserver((mutationsList) => {
            for (let mutation of mutationsList) {
                if (mutation.type === 'attributes' && mutation.attributeName === 'class') {
                    // console.log('body类名发生了改变');
                    // 这里可以添加处理逻辑
                    let classList = Object.values(document.querySelector('body').classList);
                    // 查看一下对应的值
                    // console.log(typeof classList, classList);
                    // 判定是否有播放器全屏的样式
                    if (classList.includes("player-full-win") || classList.includes("fullscreen-fix")) {
                        document.getElementById("web-player__bottom-bar__container").style = "display:none; width: 0;";
                    } else {
                        document.getElementById("web-player__bottom-bar__container").style = "display:block; width:100%;";
                    }
                }
            }
        });
        // 配置观察选项
        const config = { attributes: true };
        // 开始观察目标节点(body)及其子节点的变动
        observer.observe(document.querySelector('body'), config);
        
        // 定义一个变量来跟踪检测次数
        let checkCount = 0, isRemoved = false, reTry = 5;
            
        // 定义一个方法,来指定次数移除遮罩层
        let checkAndRemoveMask = function () {
            // 最多执行{$reTry}次就停止
            if (checkCount >= reTry || isRemoved) {
                console.log("检测结束,一共执行了", checkCount, "次,但未能找到遮罩层...");
                return; // 停止执行
            }
            // 获取遮罩层节点
            let mask = document.querySelector(".web-player-module-area-mask");
            if (mask) {
                console.log('找到遮罩层,正在删除...');
                mask.parentNode.removeChild(mask);
                console.log('遮罩层已移除,脚本停止。');
                isRemoved = true;
                return;
            } 
            // 增加次数
            checkCount++;
            // 如果节点未被删除,设置定时器1秒后再次执行该函数
            if (!mask && !isRemoved) setTimeout(checkAndRemoveMask, 1000);
        }
        // 初次执行
        checkAndRemoveMask();
    }
})();