您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
WebMをページ内で再生しちゃう
当前为
// ==UserScript== // @name futaba WebM inline player // @namespace https://github.com/himuro-majika // @description WebMをページ内で再生しちゃう // @author himuro_majika // @include http://may.2chan.net/webm/* // @require https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js // @version 1.2 // @grant none // @run-at document-idle // @license MIT // @icon  // ==/UserScript== this.$ = this.jQuery = jQuery.noConflict(true); (function ($) { /** * 設定 */ // ループ再生を有効にする var USE_LOOP = true; init(); function init() { var AKAHUKU = false, FUTAKURO = false; // 赤福が有効か if ($("#akahuku_thumbnail").length) { AKAHUKU = true; } // ふたクロが有効か if ($("#master").length) { FUTAKURO = true; } getImgNodeThread(); getImgNodeRes(); if (AKAHUKU || FUTAKURO) { observeInserted(); } // スレ画 function getImgNodeThread() { var $sure_a = $("body > form > a > img"); if (FUTAKURO) { // ふたクロ $sure_a = $("#master > a > img"); } $sure_a.each(function() { replaceNode($(this)); }); } // レス画像 function getImgNodeRes() { var $res_a = $(".rtd > a > img"); $res_a.each(function() { replaceNode($(this)); }); } // 続きを読むで挿入される要素を監視 function observeInserted() { var target = $("html > body > form[action]:not([enctype])").get(0); var observer = new MutationObserver(function(mutations) { mutations.forEach(function(mutation) { var $nodes = $(mutation.addedNodes); replaceNodeInserted($nodes); }); }); observer.observe(target, { childList: true }); } // 挿入されたレス function replaceNodeInserted($nodes) { var $res_inserted; if (AKAHUKU) { $res_inserted = $nodes.find("td > a > img"); if ($res_inserted.length) { replaceNode($res_inserted); } } else if (FUTAKURO) { $res_inserted = $nodes.find("td > a > img"); $res_inserted.each(function(){ replaceNode($(this)); }); } } // ノードの書き換え function replaceNode(node) { var href = node.parent().attr("href"); if (!href.match(/\.webm$/)) { // 拡張子.webm以外 return; } var width = node.attr("width"); var height = node.attr("height"); // マウスオーバーで読み込み node.hover(function(){ var $video = $("<video>", { controls: "", loop: USE_LOOP, class: "GM_fwip_player", css: { "width": width, "height": height, "margin": "0 20px", "float": "left", "clear": "left", }, }).append( $("<source>", { src: href, type: "video/webm", }) ); // サムネイル画像を隠す node.hide(); node.parent().replaceWith($video); }); } } })(jQuery);