简易flash播放器模拟器(在线版)

将网页中的flash内容替换为ruffle模拟器进行播放,可能对某些网站无效

// ==UserScript==
// @name         简易flash播放器模拟器(在线版)
// @namespace    http://tampermonkey.net/
// @version      0.1
// @description  将网页中的flash内容替换为ruffle模拟器进行播放,可能对某些网站无效
// @author       梅塔的长名字
// @icon         
// @match        *://*/*
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    const ruffleScriptSrc = 'https://unpkg.com/@ruffle-rs/ruffle';

    const addRufflePlayer = (container, width, height, swfSrc) => {
        const ruffleDiv = document.createElement('div');
        ruffleDiv.setAttribute('data-ruffle', ruffleScriptSrc);
        ruffleDiv.style.width = width;
        ruffleDiv.style.height = height;

        container.appendChild(ruffleDiv);

        // Ensure Ruffle is initialized correctly
        if (typeof window.RufflePlayer !== 'undefined') {
            const ruffle = window.RufflePlayer.newest();
            const player = ruffle.createPlayer();
            player.style.width = width;
            player.style.height = height;
            player.load(swfSrc);
            container.appendChild(player);
        } else {
            console.error('Ruffle Player not defined yet.');
        }
    };

    const replaceFlashWithRuffle = (element) => {
        const src = element.getAttribute('src');
        if (src && src.endsWith('.swf')) {
            const container = element.parentNode;
            const width = element.getAttribute('width') || '100%';
            const height = element.getAttribute('height') || '100%';

            // Remove the old Flash element
            element.parentNode.removeChild(element);

            // Add the Ruffle player
            addRufflePlayer(container, width, height, src);
        }
    };

    const loadRuffleScript = () => {
        const script = document.createElement('script');
        script.src = ruffleScriptSrc;
        script.onload = () => {
            console.log('Ruffle script loaded.');

            // Replace Flash content after Ruffle script has loaded
            const elementsToCheck = ['object', 'embed', 'iframe'];
            elementsToCheck.forEach(tagName => {
                const elements = document.getElementsByTagName(tagName);
                for (let i = 0; i < elements.length; i++) {
                    replaceFlashWithRuffle(elements[i]);
                }
            });

            // MutationObserver to handle dynamic content
            const observer = new MutationObserver(() => {
                elementsToCheck.forEach(tagName => {
                    const elements = document.getElementsByTagName(tagName);
                    for (let i = 0; i < elements.length; i++) {
                        replaceFlashWithRuffle(elements[i]);
                    }
                });
            });

            // Configuration of the observer:
            const config = { childList: true, subtree: true };

            // Start observing the document with the configured parameters
            observer.observe(document.body, config);

            // Optionally, stop observing when done
            // observer.disconnect();
        };
        script.onerror = () => {
            console.error('Failed to load Ruffle script.');
        };
        document.head.appendChild(script);
    };

    // Load Ruffle script first
    loadRuffleScript();
})();