您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
在抖音推荐和直播页面自动选择最高画质
// ==UserScript== // @name 抖音自动选择最高画质 // @namespace douyin-auto-hd // @author loerise // @version 0.4 // @description 在抖音推荐和直播页面自动选择最高画质 // @license MIT // @icon  // @match https://www.douyin.com/* // @match https://live.douyin.com/* // @grant none // @run-at document-end // ==/UserScript== (() => { "use strict"; const CONFIG = { DELAY: 300, RETRY_DELAY: 300, MAX_RETRY: 5, CONTAINER: ".basePlayerContainer", SELECTORS: [ "xg-icon.xgplayer-playclarity-setting > .gear > .virtual > .item:first-child", '[data-e2e="quality-selector"] div:first-child', ], NAV_KEYS: ["w", "W", "s", "S", "ArrowUp", "ArrowDown", "KeyW", "KeyS"], }; const log = (message) => console.log("[抖音高清]", `${message}`); let timeoutId = null; // 获取容器并查找画质选项 const findQualityTargets = () => { const containers = Array.from( document.querySelectorAll(CONFIG.CONTAINER) || [] ); return CONFIG.SELECTORS.map((selector) => { return containers.map((container) => container.querySelector(selector)); }) .flat() .filter((el) => el); }; // 查找画质选项并点击 const switchQuality = async (retry = 0) => { log(`检查画质 (第${retry + 1}次)`); const targets = findQualityTargets(); log(findQualityTargets().length); if (targets.length) { targets.forEach((target) => target.click()); log( `画质切换成功: ${targets.map((t) => t.textContent?.trim()).join(", ")}` ); return true; } if (retry < CONFIG.MAX_RETRY) { log(`未找到画质选项,${CONFIG.RETRY_DELAY}ms后重试`); await new Promise((resolve) => setTimeout(resolve, CONFIG.RETRY_DELAY)); return switchQuality(retry + 1); } log("达到最大重试次数,放弃"); return false; }; // 延时执行画质检查 const scheduleCheck = () => { if (timeoutId) clearTimeout(timeoutId); timeoutId = setTimeout(switchQuality, CONFIG.DELAY); }; // 检测导航事件 const isNavEvent = (event) => CONFIG.NAV_KEYS.includes(event.key) || CONFIG.NAV_KEYS.includes(event.code); // 事件监听 document.addEventListener("keydown", (e) => { if (isNavEvent(e)) { log(`键盘导航: ${e.key || e.code}`); scheduleCheck(); } }); document.addEventListener("wheel", (e) => { if (Math.abs(e.deltaY) > 0) { log(`滚轮导航: ${e.deltaY}`); scheduleCheck(); } }); // 初始化 log("脚本启动"); switchQuality(); })();