disable autoplay and unload player
当前为
// ==UserScript==
// @name click_to_play@youtube
// @namespace click_to_play@youtube
// @namespace https://greasyfork.org/ja/scripts/9886
// @homepageURL https://greasyfork.org/ja/scripts/9886
// @license http://creativecommons.org/licenses/by-nc-sa/4.0/
// @description disable autoplay and unload player
// @include http://*
// @include https://*
// @exclude https://www.youtube.com/*
// @author noi
// @version 1.02
// @grant GM_log
// ==/UserScript==
/**************************************************************
[about]
Stop youtube video autoplay, and unload the players.
It will display a thumbnail image instead.
youtubeの埋め込み動画を読みこまないように変更し、
代わりにサムネイル画像を表示します。
Firefoxのプラグイン「click-to-play」はHTML5をブロックしないので、
スクリプトを作成。
****************************
history
05/15/2015 - v1.02 v1.01のバグ修正
05/15/2015 - v1.01 再生ボタンを変更
05/15/2015 - v1.00 release
**************************************************************/
"use strict";
var number = 0;
var xpath = [
'//iframe[contains(@src,"youtube.com/embed/")]|',
'//iframe[contains(@src,"youtube.com/v/")]|',
'//embed[contains(@src,"youtube.com/v/") and not(ancestor::object)]|',
'//object[./param[contains(@value,"youtube.com/v/")]]',
].join('');
var playButton = '<div style="width:100%;height:100%;background:url(\'\') no-repeat center center;"></div>';
var blockEmbed = function(node){
var result = document.evaluate(xpath, node, null, XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE, null);
for(var i=0,j=result.snapshotLength;i<j;i++){
var ele = result.snapshotItem(i);
if(ele.hasAttribute('c2p')) continue;
var url = ele.src; //iframe or embed
//object
if(!url){
for(var x=0,y=ele.childNodes.length; x<y; x++){
var param = ele.childNodes[x];
if(param.nodeName == "PARAM" && param.getAttribute("name") == "movie"){
url = param.getAttribute("value");
break;
}
}
}
if(!url) continue;
var parent = ele.parentNode;
var id = url.match(/(embed|v)\/(.+?)(\?|&|$)/)[2];
var movieUrl = "https://www.youtube.com/watch?v=" + id;
var src = location.protocol + '//img.youtube.com/vi/' + id + '/mqdefault.jpg';
var thumbnail = document.createElement("div");
thumbnail.className = 'c2p_thumbnail';
thumbnail.setAttribute('num',number);
thumbnail.innerHTML = playButton;
thumbnail.style = 'min-width:320px;min-height:180px;width:'+ ele.offsetWidth +'px;height:'+ ele.offsetHeight +'px;background:url(' + src + ') no-repeat center center ; background-size: 100% 100%;';
thumbnail.title = 'click to play!';
var block = document.createElement("div");
block.id = 'c2p_' + number;
block.className = 'c2p_block';
block.appendChild(ele);
block.innerHTML = '<!-- ' + block.innerHTML + ' -->';
var unBlock = function(e){
var thumb = e.target;
if(!thumb.id.match(/^c2p_/)) thumb = thumb.parentNode;
thumb.removeEventListener('click',unBlock,false);
thumb.parentNode.removeChild(thumb);
var num = thumb.getAttribute('num');
var blocked = document.getElementById('c2p_' + num);
var strTxt = blocked.innerHTML.replace(/(^\<\!\-\- | \-\-\>$)/g,'').replace(/(.*?)\>/,'$1 c2p="done">');
var addObj = document.createElement("div");
blocked.parentNode.replaceChild(addObj,blocked);
addObj.innerHTML = strTxt;
};
thumbnail.addEventListener('click',unBlock,false);
parent.appendChild(thumbnail);
// thumbnail.insertAdjacentHTML('beforebegin','<a class="c2p_embedUrl" href="' + movieUrl + '" target="_blank">' + movieUrl + '</a>');
parent.appendChild(block);
number++;
}
};
blockEmbed(document.documentElement);
var observer = new MutationObserver(function(mutations){
for(var i=0,j=mutations.length;i<j;i++){
var m = mutations[i];
if(m.type != "childList") return;
for(var x=0,y=m.addedNodes.length;x<y;x++){
blockEmbed(m.addedNodes[x]);
}
}
});
observer.observe(document.body, {childList: true,subtree: true});
var onEventUnload = function(){
window.removeEventListener("beforeunload", onEventUnload,false);
observer.disconnect();
observer = xpath = blockEmbed = null;
};
window.addEventListener('beforeunload',onEventUnload, false);