您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
youtube video progressbar outline & color replacement
// ==UserScript== // @name YouTube restyle // @namespace http://tampermonkey.net/ // @version 1.0 // @description youtube video progressbar outline & color replacement // @author Roman Sergeev aka naxombl4 aka Brutal Doomer // @match https://www.youtube.com/* // @grant GM_addStyle // @license MIT // ==/UserScript== /** * v1.0 added comments, added --vars, removed timeout function changing svg path fill * added surveyLoadProgresses from another script * added replacer of YT logos * v0.1 original script */ (function() { 'use strict'; // replace youtube logo on the browser tab with image of corresponding color (changing the theme, you have to upload your own) document.getElementsByTagName('link')[1].setAttribute("href", "https://dl.dropboxusercontent.com/s/9avoipkut6ydydu/32.png"); document.getElementsByTagName('link')[2].setAttribute("href", "https://dl.dropboxusercontent.com/s/8mujk3poo7nvxsm/48.png"); document.getElementsByTagName('link')[3].setAttribute("href", "https://dl.dropboxusercontent.com/s/5zrmlvm9uy1zran/96.png"); document.getElementsByTagName('link')[4].setAttribute("href", "https://dl.dropboxusercontent.com/s/6goosuv17qzvgit/144.png"); //var notificationImageSrc = "https://www.dropbox.com/scl/fi/uxal14y48igxdp02hy8n9/notification.png"; // dropbox has changed their storing method, yet old links still work. You can't modify links due to CORB policy, so... // Here's the replacement image in Base64, size 64x64px. If you change the theme - change this as well // Original image is at https://www.gstatic.com/images/branding/product/2x/youtube_96in128dp.png var notificationImageSrc64 = ""; var colour = "#558", darken = "#447", bright = "#669", prgbar = "#0f06", prgend = "#0f0"; GM_addStyle(` :root { --colour: `+colour+`; --darken: `+darken+`; --bright: `+bright+`; --prgbar: `+prgbar+`; --prgend: `+prgend+`; } html[refresh], [refresh] { --yt-spec-static-brand-red: var(--colour); --yt-spec-red-indicator: var(--colour); } span.mention.yt-live-chat-text-message-renderer { background: var(--colour) !important; /* live chat mention background replacement (doesn't work) */ } div.ytp-chapter-hover-container, div.ytp-chapter-hover-container>div { outline: none; } div.ytp-load-progress { background-color: var(--prgbar); } div.ytp-load-progress div.progressBarAfter { position: absolute; height: 100%; right: 0; background-color: var(--prgend); } .ytp-hover-progress.ytp-hover-progress-light { background-color: var(--prgbar); } div.ytp-swatch-background-color, button.ytp-settings-button.ytp-hd-quality-badge::after { background-color: var(--darken); } html:not(.style-scope)[dark], :not(.style-scope)[dark] { --yt-spec-static-overlay-background-brand: var(--colour); --yt-spec-brand-button-background: var(--darken); --yt-spec-light-blue: var(--colour); --yt-spec-call-to-action: var(--colour); --yt-live-chat-mention-background-color: var(--colour); } sup.ytp-swatch-color { color: var(--colour); } div.ytp-cairo-refresh-signature-moments .ytp-play-progress { background: var(--colour); } span.badge-style-type-live-now.ytd-badge-supported-renderer { --yt-spec-brand-link-text: var(--bright); } span.mention.style-scope.yt-live-chat-text-message-renderer, .mention.yt-live-chat-text-message-renderer { background: var(--colour) !important; } ytd-thumbnail-overlay-resume-playback-renderer[enable-refresh-signature-moments-web] #progress.ytd-thumbnail-overlay-resume-playback-renderer { background: linear-gradient(to right, var(--darken) 80%, var(--colour) 100%); } span.mention.yt-live-chat-text-message-renderer { background: none; border: 2px solid var(--colour); border-radius: 9px; } .guide-entry-badge.ytd-guide-entry-renderer { --yt-spec-static-brand-red: #77a; } #newness-dot.ytd-guide-entry-renderer { --yt-spec-themed-blue: var(--colour); } yt-icon#logo-icon svg>g:first-child>path:first-child { fill: var(--colour); } svg>g>g.style-scope.ytd-topbar-logo-renderer>path { fill: var(--colour); } div#title-container svg>path:first-child { fill: var(--colour); } button.ytp-live-badge[disabled]:before { background: var(--colour); } #progress.ytd-thumbnail-overlay-resume-playback-renderer { --yt-spec-static-brand-red: var(--colour); } .ytp-menuitem[aria-checked="true"] .ytp-menuitem-toggle-checkbox { background: var(--colour); } .badge-style-type-live-now.ytd-badge-supported-renderer { --yt-spec-brand-link-text: var(--bright); } ytd-thumbnail-overlay-toggle-button-renderer[aria-label="Добавить в очередь"] { display: none !important; pointer-events: none !important; } .yt-spec-avatar-shape--cairo-refresh.yt-spec-avatar-shape--live-ring::after { background: linear-gradient(to top right, var(--darken) 60%, var(--bright) 85%); } .yt-spec-avatar-shape--cairo-refresh .yt-spec-avatar-shape__live-badge { background: var(--darken); } .yt-spec-icon-badge-shape--type-notification-refresh .yt-spec-icon-badge-shape__badge { background: var(--darken); } /*#item-scroller path.style-scope.yt-icon { fill: var(--colour); }*/`); // update marker position function surveyLoadProgresses() { var targets = Array.from(document.getElementsByClassName("ytp-load-progress")); for (var i = 0; i < targets.length; i++) { var target = targets[i]; if (target.children.length == 0) { var div = document.createElement("div"); div.className = "progressBarAfter"; target.appendChild(div); } div = target.children[0]; var progress = /\d+(\.\d+)?/.exec(target.style.transform)[0]; div.style.width = (7 / progress) + "px"; // I don't remember why, but ok if (progress == 0 || progress == 1 && i != targets.length - 1) div.style.width = 0; } //console.log(targets.map(x => /\d+(\.\d+)?/.exec(x.style.transform)[0]).join(" ")); } setInterval(surveyLoadProgresses, 1000); var imagesFetched = 0; function surveyYTImages() { var list = document.querySelectorAll('[id=img]'); for (var i = imagesFetched; i < list.length; ++i) if (list[i].src.startsWith("https://www.gstatic.com/images/branding/product/")) list[i].src = notificationImageSrc64; //imagesFetched = Math.max(imagesFetched, list.length); // sometimes is skipped } setInterval(surveyYTImages, 1000); })();