🎉 欢迎访问GreasyFork.Org 镜像站!本镜像站由公众号【爱吃馍】搭建,用于分享脚本。联系邮箱📮

Greasy fork 爱吃馍镜像

Greasy Fork is available in English.

📂 缓存分发状态(共享加速已生效)
🕒 页面同步时间:2026/01/05 06:46:38
🔄 下次更新时间:2026/01/05 07:46:38
手动刷新缓存

Assistente do YouTube

YouTube 1. Playback de loop de vídeo.

Você precisará instalar uma extensão como Tampermonkey, Greasemonkey ou Violentmonkey para instalar este script.

You will need to install an extension such as Tampermonkey to install this script.

Você precisará instalar uma extensão como Tampermonkey ou Violentmonkey para instalar este script.

Você precisará instalar uma extensão como Tampermonkey ou Userscripts para instalar este script.

Você precisará instalar uma extensão como o Tampermonkey para instalar este script.

Você precisará instalar um gerenciador de scripts de usuário para instalar este script.

(Eu já tenho um gerenciador de scripts de usuário, me deixe instalá-lo!)

🚀 安装遇到问题?关注公众号获取帮助

公众号二维码

扫码关注【爱吃馍】

回复【脚本】获取最新教程和防失联地址

Você precisará instalar uma extensão como o Stylus para instalar este estilo.

Você precisará instalar uma extensão como o Stylus para instalar este estilo.

Você precisará instalar uma extensão como o Stylus para instalar este estilo.

Você precisará instalar um gerenciador de estilos de usuário para instalar este estilo.

Você precisará instalar um gerenciador de estilos de usuário para instalar este estilo.

Você precisará instalar um gerenciador de estilos de usuário para instalar este estilo.

(Eu já possuo um gerenciador de estilos de usuário, me deixar fazer a instalação!)

🚀 安装遇到问题?关注公众号获取帮助

公众号二维码

扫码关注【爱吃馍】

回复【脚本】获取最新教程和防失联地址

// ==UserScript==
// @name              YouTube Helper
// @name:ar           مساعد يوتيوب
// @name:bg           YouTube асистент
// @name:cs           Asistent YouTube
// @name:da           YouTube -assistent
// @name:de           YouTube -Assistent
// @name:el           Βοηθός του YouTube
// @name:en           YouTube Assistant
// @name:eo           YouTube -Asistanto
// @name:es           Asistente de YouTube
// @name:fi           YouTube -avustaja
// @name:fr           Assistant YouTube
// @name:fr-CA        Assistant YouTube
// @name:he           עוזר YouTube
// @name:hr           YouTube pomoćnik
// @name:hu           YouTube asszisztens
// @name:id           Asisten YouTube
// @name:it           Assistente YouTube
// @name:ja           YouTubeアシスタント
// @name:ka           YouTube ასისტენტი
// @name:ko           YouTube Assistant
// @name:nb           YouTube -assistent
// @name:nl           YouTube -assistent
// @name:pl           Asystent YouTube
// @name:pt-BR        Assistente do YouTube
// @name:ro           Asistent YouTube
// @name:ru           YouTube Assistant
// @name:sk           Asistent YouTube
// @name:sr           ИоуТубе асистент
// @name:sv           YouTube Assistant
// @name:th           ผู้ช่วย YouTube
// @name:tr           YouTube Assistant
// @name:ug           YouTube ياردەمچىسى
// @name:uk           Асистент YouTube
// @name:vi           Trợ lý YouTube
// @name:zh           YouTube 小助手
// @name:zh-CN        YouTube 小助手
// @name:zh-HK        YouTube 小助手
// @name:zh-SG        YouTube 小助手
// @name:zh-TW        YouTube 小助手
// @description       YouTube 1.Loop playback of YouTube videos 2.screenshot download 3.themed progress bar.
// @description:ar    YouTube 1. تشغيل حلقة الفيديو 2. تنزيل لقطة الشاشة 3.
// @description:bg    YouTube 1. Възпроизвеждане на видео контур 2. Изтегляне на екранна снимка 3. Бар за напредък на темата
// @description:cs    YouTube 1.. Přehrávání video smyčky 2.
// @description:da    YouTube 1. Video Loop Playback 2.. Skærmbillede Download 3. Tema -statuslinje
// @description:de    YouTube 1. Video Loop -Wiedergabe 2. Screenshot Download 3. Thema Fortschrittsleiste
// @description:el    YouTube 1. Αναπαραγωγή βρόχου βίντεο 2. ΠΕΡΙΕΧΟΜΕΝΟ ΣΤΟΙΧΕΙΑ 3.
// @description:en    YouTube 1. Video loop playback 2. Screenshot download 3. Theme progress bar
// @description:eo    YouTube 1. Video Loop Playback 2.
// @description:es    YouTube 1. Video Loop Playback 2. Descarga de captura de pantalla 3. Barra de progreso del tema
// @description:fi    YouTube 1.
// @description:fr    YouTube 1. Playback de boucle vidéo 2. Capture d’écran Télécharger 3. Bar de progression du thème
// @description:fr-CA YouTube 1. Playback de boucle vidéo 2. Capture d’écran Télécharger 3. Bar de progression du thème
// @description:he    YouTube 1. השמעת לולאת וידאו 2. הורדת צילום מסך 3. סרגל התקדמות נושא
// @description:hr    YouTube 1. Video petlja reprodukcija 2. Snimka zaslona Preuzmite 3.
// @description:hu    YouTube 1. Video hurok lejátszása 2. képernyőkép letöltése 3. Téma előrehaladási sáv
// @description:id    YouTube 1. Video Loop Playback 2. Screenshot Unduh 3. Tema Kemajuan Bilah
// @description:it    YouTube 1. Riproduzione del loop video 2. Screenshot Download 3. Barra di avanzamento del tema
// @description:ja    YouTube1。ビデオループ再生2。スクリーンショットダウンロード3。テーマの進行状況バー
// @description:ka    YouTube 1. ვიდეო მარყუჟის დაკვრა 2. სკრინშოტის ჩამოტვირთვა 3. თემის პროგრესის ბარი
// @description:ko    YouTube 1. 비디오 루프 재생 2. 스크린 샷 다운로드 3. 테마 진행률 바
// @description:nb    YouTube 1. Video Loop Playback 2. Skjermbilde nedlasting 3. Tema Progress Bar
// @description:nl    YouTube 1. Video Loop Playback 2. Screenshot Download 3. Theme voortgangsbalk
// @description:pl    YouTube 1. Pętla wideo odtwarzanie 2. Pobierz zrzut ekranu 3.
// @description:pt-BR YouTube 1. Playback de loop de vídeo.
// @description:ro    YouTube 1. Redarea buclelor video 2. Descărcare de ecran 3. Tema Progress Bar
// @description:ru    YouTube 1. Playback Video Playback 2. Скачать экрана 3.
// @description:sk    YouTube 1. Prehrávanie video slučky 2. Screenshot Stiahnutie 3.
// @description:sr    ИоуТубе 1. Репродукција видео петље 2. Сцреенсхот Довнлоад 3. Тхеме Топресс Бар
// @description:sv    YouTube 1. Video Loop Playback 2. Skärmdump nedladdning 3. Theme Progress Bar
// @description:th    YouTube 1. การเล่นวิดีโอลูป 2. การดาวน์โหลดภาพหน้าจอ 3. ธีมความคืบหน้าแถบ
// @description:tr    YouTube 1. Video Döngüsü Oynatma 2. Ekran Görüntüsü İndir 3. Tema İlerleme Çubuğu
// @description:ug    YouTube 1. سىن ئايلانما قويۇش 2. ئېكران رەسىمى 3 نى چۈشۈرۈڭ. باشتېمىنى ئىلگىرى سۈرۈش بالدىقى
// @description:uk    YouTube 1. Відеокласник відеокліту
// @description:vi    YouTube 1. Video Loop Playback 2. Ảnh chụp màn hình tải xuống 3. Thanh tiến trình chủ đề
// @description:zh    YouTube 1.视频循环播放 2.截图下载 3.主题进度条
// @description:zh-CN YouTube 1.视频循环播放 2.截图下载 3.主题进度条
// @description:zh-HK YouTube 1.視頻循環播放 2.截圖下載 3.主題進度條
// @description:zh-SG YouTube 1.视频循环播放 2.截图下载 3.主题进度条
// @description:zh-TW YouTube 1.視頻循環播放 2.截圖下載 3.主題進度條
// @author            Carokahn,bernzrdo,FunnyMonkey,人民的勤务员 <[email protected]>
// @namespace         https://github.com/ChinaGodMan/UserScripts
// @supportURL        https://github.com/ChinaGodMan/UserScripts/issues
// @homepageURL       https://github.com/ChinaGodMan/UserScripts
// @license           MIT
// @icon              https://www.youtube.com/s/desktop/ee47b5e0/img/logos/favicon_144x144.png
// @match             https://www.youtube.com/*
// @match             https://m.youtube.com/*
// @compatible        chrome
// @compatible        firefox
// @compatible        edge
// @compatible        opera
// @compatible        safari
// @compatible        kiwi
// @compatible        qq
// @compatible        via
// @compatible        brave
// @version           2025.03.15.0436
// @grant             GM_addStyle
// @created           2025-03-14 20:36:01
// @modified          2025-03-14 20:36:01
// ==/UserScript==
/**
 * File: youtube-helper.user.js
 * Project: UserScripts
 * File Created: 2025/03/15,Saturday 04:36:02
 * Author: 人民的勤务员@ChinaGodMan ([email protected])
 * -----
 * Last Modified: 2025/03/15,Saturday 05:57:23
 * Modified By: 人民的勤务员@ChinaGodMan ([email protected])
 * -----
 * License: MIT License
 * Copyright © 2024 - 2025 ChinaGodMan,Inc
 */
const directDownload = true
const infiniteLool = true





const loopVideo = () => {
    const video = document.querySelector('video')
    if (video && !video.loop) {
        video.loop = true
    }
}
const ThemeProgressbar = () => {
    const css_248z = '.html5-play-progress,.ytp-play-progress{background:url("") repeat-x!important;background:linear-gradient(180deg,red 0,red 16.5%,#f90 0,#f90 33%,#ff0 0,#ff0 50%,#3f0 0,#3f0 66%,#09f 0,#09f 83.5%,#63f 0,#63f)!important;background:-webkit-linear-gradient(top,red,red 16.5%,#f90 0,#f90 33%,#ff0 0,#ff0 50%,#3f0 0,#3f0 66%,#09f 0,#09f 83.5%,#63f 0,#63f)!important;background:-moz-linear-gradient(top,red 0,red 16.5%,#f90 16.5%,#f90 33%,#ff0 33%,#ff0 50%,#3f0 50%,#3f0 66%,#09f 66%,#09f 83.5%,#63f 83.5%,#63f 100%)!important}.html5-load-progress,.ytp-load-progress{background:url("")!important}.html5-scrubber-button,.ytp-scrubber-button{background:url("")!important;border:none!important;height:21px!important;margin-left:-18px!important;margin-top:0!important;transform:scale(.8);-webkit-transform:scale(.8);-moz-transform:scale(.8);-ms-transform:scale(.8);width:34px!important}.ytp-progress-bar-container:hover .ytp-load-progress,.ytp-progress-bar-container:hover .ytp-scrubber-button{image-rendering:pixelated}.html5-progress-bar-container,.ytp-progress-bar-container{height:12px!important}.html5-progress-bar,.ytp-progress-bar{margin-top:12px!important}.html5-progress-list,.video-ads .html5-progress-list.html5-ad-progress-list,.video-ads .ytp-progress-list.ytp-ad-progress-list,.ytp-progress-list{height:12px!important}.ytp-volume-slider-track{background:#0c4177!important}'
    GM_addStyle(css_248z)
}

let escapeHTMLPolicy = 'trustedTypes' in window
    ? trustedTypes.createPolicy('forceInner', { createHTML: html => html })
    : { createHTML: html => html }
function screenBtnUpdate() {
    let $miniplayerBtn = document.querySelector('button.ytp-miniplayer-button')
    if ($miniplayerBtn && !document.getElementById('ytp-screenshot-button')) {
        const $btn = document.createElement('button')
        $btn.id = 'ytp-screenshot-button'
        $btn.classList.add('ytp-screenshot-button', 'ytp-button')
        $btn.dataset.priority = '5'
        $btn.dataset.tooltipTargetId = 'ytp-screenshot-button'
        $btn.dataset.titleNoTooltip = 'Screenshot'
        $btn.ariaLabel = 'Screenshot'
        $btn.title = 'Screenshot'
        $btn.innerHTML = escapeHTMLPolicy.createHTML(`<svg height="100%" version="1.1" viewBox="-300 -1260 1560 1560" width="100%">
            <use class="ytp-svg-shadow" xlink:href="#ytp-id-screenshot-svg"></use>
            <path
                d="M200-120q-33 0-56.5-23.5T120-200v-560q0-33 23.5-56.5T200-840h560q33 0 56.5 23.5T840-760v560q0 33-23.5 56.5T760-120H200Zm0-80h560v-560H200v560Zm40-80h480L570-480 450-320l-90-120-120 160Zm-40 80v-560 560Z"
                fill="#fff" id="ytp-id-screenshot-svg"></path>
        </svg>`)
        $btn.addEventListener('click', screenshot)

        insertBefore($btn, $miniplayerBtn)
    }

    requestAnimationFrame(screenBtnUpdate)
}
function insertBefore($element, $sibling) {
    $sibling.parentElement.insertBefore($element, $sibling)
}
function screenshot() {

    const $video = document.querySelector('#player video')
    if (!$video) {
        console.error('No video found to screenshot!')
        return
    }

    let wasPlaying = !$video.paused
    if (wasPlaying) $video.pause()

    const $canvas = document.createElement('canvas')
    $canvas.width = $video.videoWidth
    $canvas.height = $video.videoHeight

    let oldCss = $video.style.cssText
    $video.style.width = $video.videoWidth + 'px'
    $video.style.height = $video.videoHeight + 'px'

    const ctx = $canvas.getContext('2d')
    ctx.drawImage($video, 0, 0, $video.videoWidth, $video.videoHeight)

    $canvas.toBlob(blob => {

        if (directDownload) {
            const a = document.createElement('a')
            a.href = URL.createObjectURL(blob)
            a.download = `${getFileName()}.png`
            a.click()
        } else {
            const item = new ClipboardItem({ 'image/png': blob })
            navigator.clipboard.write([item])
        }

        $video.style.cssText = oldCss
        $canvas.remove()
        if (wasPlaying) $video.play()

    })

}
function getFileName() {
    const safeFileName = document.title.replace(/[\\/:*?"<>|]/g, '').replace(' - YouTube', '')
    return safeFileName
}
if (infiniteLool) {
    const observer = new MutationObserver(loopVideo)
    observer.observe(document.body, { childList: true, subtree: true })
}

requestAnimationFrame(screenBtnUpdate)
ThemeProgressbar()