Video Enhancer Color Grading (Always On)

Applies a saturation(1.3) filter to all HTML5 videos.

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

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

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name        Video Enhancer Color Grading (Always On)
// @version     1.1
// @description Applies a saturation(1.3) filter to all HTML5 videos.
// @match       *://*/*
// @grant       GM_addStyle
// @run-at      document-start
// @namespace https://greasyfork.org/users/1402168
// ==/UserScript==

(function() {
    'use strict';

    const saturationFilter = 'video { filter: saturate(1.3) !important; }';

    GM_addStyle(saturationFilter);

    const styleElement = document.createElement('style');
    styleElement.textContent = saturationFilter;

    const originalAttachShadow = Element.prototype.attachShadow;
    Element.prototype.attachShadow = function(init) {
        const shadowRoot = originalAttachShadow.call(this, init);
        shadowRoot.appendChild(styleElement.cloneNode(true));
        return shadowRoot;
    };

    function applyToExistingShadows(rootNode) {
        rootNode.querySelectorAll('*').forEach(el => {
            if (el.shadowRoot) {
                el.shadowRoot.appendChild(styleElement.cloneNode(true));
                // Recurse in case of nested shadow DOMs
                applyToExistingShadows(el.shadowRoot);
            }
        });
    }

    document.addEventListener('DOMContentLoaded', () => {
        applyToExistingShadows(document.documentElement);
    });
})();