您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Добавляет ссылку на видео файл и если браузер поддерживает воспроизведение mp4, то добавляет видеоплеер.
当前为
// ==UserScript== // @name Bashtube HTML5 Player and Downloader // @description Добавляет ссылку на видео файл и если браузер поддерживает воспроизведение mp4, то добавляет видеоплеер. // @namespace 2k1dmg@userscript // @match http://bashtube.ru/video/* // @version 32 // @author 2k1dmg // @grant none // ==/UserScript== // 2014-09-27 (function(window) { 'use strict'; if (!window || (window && window.self !== window.top)) { return; } var document = window.document; var styleSheetLoader = function(canPlay, flash) { var cssStyle = document.createElement('style'); cssStyle.type = 'text/css'; cssStyle.textContent = '#bt-html5video-panel {\n' + ' width: 640px;\n' + ' height: 25px;\n' + ' padding: 15px 0 10px 0;\n' + '}\n' + '#bt-html5video-panel > a {\n' + ' margin-right: 20px;\n' + ' float: right;\n' + '}\n' + '#bt-html5video-panel > img {\n' + ' margin: 0 0 -3px 20px;\n' + '}\n'; if (canPlay) cssStyle.textContent += (flash ? '#bt-html5video-panel > button {\n' : '#bt-html5video-panel > sub {\n') + ' margin-left: 10px;\n' + ' margin-right: 10px;\n' + '}\n' + '#bt-html5video-panel > span {\n' + ' font-size: 90%;\n' + '}\n' + '#bt-html5video-panel > SPAN.supstr {\n' + ' vertical-align: top; \n' + ' font-size: 65%;\n' + '}\n' + '#bt-html5video-wrapper {\n' + ' z-index: 50;\n' + ' background: #000;\n' + ' top: 0;\n' + ' left: 0;\n' + ' width: 100%;\n' + ' height: 100%;\n' + ' opacity: 0;\n' + ' transition: opacity 500ms ease-out;\n' + ' box-shadow: 0 0 10px 1px #000 inset;\n' + '}\n' + '#bt-html5video-wrapper.playing {\n' + ' opacity: .7;\n' + '}\n' + '\n' + '#bt-html5video-player-container,\n' + '#bt-html5video-player {\n' + ' position: relative;\n' + ' z-index: 100;\n' + '}\n' + '#bt-html5video-panel button {\n' + ' border: 1px solid #aaa;\n' + ' background: #eee;\n' + '}\n' + '#bt-html5video-player-container {\n' + ' /*outline: 1px solid green;*/\n' + ' display: inline-block;\n' + '}\n' + '#bt-html5video-player {\n' + ' box-shadow: 0 0 5px 1px #000;\n' + '}\n' + '#bt-html5video-player.playing {\n' + ' box-shadow: 0 0 5px 1px #fff;\n' + '}\n' + '#bt-html5video-player-container > #bt-html5video-player {\n' + ' transition: all 300ms ease-in;\n' + '}\n' + '#bt-html5video-player-container.sizeLarge > #bt-html5video-player {\n' + ' width: 960px;\n' + ' height: 540px;\n' + '}\n' + '#bt-html5video-player-controls {\n' + ' position: absolute;\n' + ' z-index: 150;\n' + ' width: 100%;\n' + ' height: 28px;\n' + ' background-color: rgba(35,31,32,.74);\n' + ' opacity: 0;\n' + ' color: #ddd;\n' + '}\n' + '#bt-html5video-player-container:hover #bt-html5video-player-controls {\n' + ' opacity: 1;\n' + '} \n' + '#bt-html5video-player-size-btn {\n' + ' cursor: pointer;\n' + ' background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADwAAAAbCAYAAAAgVez8AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6NzUyQjZBRDEzRTgxMTFFNEE4QzFFRTlDNDAzNkJBNDkiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6NzUyQjZBRDIzRTgxMTFFNEE4QzFFRTlDNDAzNkJBNDkiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDo3NTJCNkFDRjNFODExMUU0QThDMUVFOUM0MDM2QkE0OSIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDo3NTJCNkFEMDNFODExMUU0QThDMUVFOUM0MDM2QkE0OSIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PhVpoj0AAACESURBVHja7JgxDoAgDACp8UfOfkffhLM/ceZNOLESMDVQuFshKdc2KanEGN1MLG4yEEYYYYRNsWbOvFKM04pwa/wfiS4Rvj4GPKy1dCI0fuNTeX+32tKJW1OYsYQwwuN+PEaZx9XCngr3OX+LkMyKZ1OKEXrKorDTQhhhhBFGuB9eAQYAbtsR3i9+1uIAAAAASUVORK5CYII=) no-repeat;\n' + ' width: 30px;\n' + ' height: 27px;\n' + '}\n' + '#bt-html5video-player-container.sizeLarge #bt-html5video-player-size-btn {\n' + ' background-position: -30px 0;\n' + '}\n' + '.content > .right {\n' + ' opacity: 1;\n' + ' transition: all 300ms ease-in;\n' + '}\n' + '.content > .right.sizeLarge {\n' + ' position: relative;\n' + ' z-index: -1;\n' + ' opacity: 0;\n' + '}\n' + '#bt-html5video-player-controls > * {\n' + ' display: inline-block;\n' + ' vertical-align: middle;\n' + ' margin: 0 2px;\n' + '}'; document.head.appendChild(cssStyle); }; var eventSetter = { buttonOnClick: { init: function(button, html5ImageColored, html5Image) { var onClick = function(event) { if (!this.uppod && !this.btHTML5videoPlayer) { try { this.uppod = document.getElementById('uppod'); this.btHTML5videoPlayer = document.getElementById('bt-html5video-player'); var btHTML5videoPanel = document.getElementById('bt-html5video-panel'); var images = btHTML5videoPanel.getElementsByTagName('img'); this.image = images[0]; } catch (ex) { return; }; } this.onclick = function() { if (this.uppod.style.display == 'none') { this.uppod.style.removeProperty('display'); this.btHTML5videoPlayer.style.display = 'none'; this.textContent = 'HTML5'; this.image.src = html5Image; this.btHTML5videoPlayer.pause(); this.screenButton.style.display = 'none'; } else { this.btHTML5videoPlayer.style.removeProperty('display'); this.uppod.style.display = 'none'; this.textContent = 'FLASH'; this.image.src = html5ImageColored; this.screenButton.style.removeProperty('display'); } }; return this.onclick(); }; button.onclick = onClick; } }, linkOnClick: { init: function(link) { var onClick = function(event) { if (event && event.button === 0) { event.preventDefault(); event.stopPropagation(); } }; link.onclick = onClick; link.title = 'Скачивать правой кнопкой мыши!\nИ выбрать: "Сохранить объект как…" или т.п'; } }, playerOnData: { init: function(btHTML5videoPlayer) { btHTML5videoPlayer.addEventListener('loadedmetadata', function(e) { var width = this.videoWidth, height = this.videoHeight; var btHTML5videoPanel = document.getElementById('bt-html5video-panel'); var spans = btHTML5videoPanel.getElementsByTagName('span'); if (spans[0]) { spans[0].textContent = width + 'x'; spans[1].style.color = 'black'; spans[1].textContent = height; if (height >= 720) { spans[2].className = 'supstr' spans[2].textContent = ' HD'; } } }, false); } } }; var createLink = function(params) { var file = params.file; var poster = params.poster; var flash = params.flash; var videoInfos = document.getElementsByClassName('video-info'); var videoInfo = videoInfos[0]; var canPlay = (function() { try { var v = document.createElement('video'); return v.canPlayType('video/mp4') !== ''; } catch (ex) { return false; } }()); var addHTML5video = function() { var btHTML5videoPlayer = document.createElement('video'); var playerParams = [ ['id', 'bt-html5video-player'], ['width', 640], ['height', 360], ['volume', 0.5], ['controls', 'controls'], ['poster', poster] ]; playerParams.forEach(function(param) { btHTML5videoPlayer[param[0]] = param[1]; }); btHTML5videoPlayer.innerHTML = '<source src="' + file + '" type="video/mp4">'; var btHTML5videoPlayerContainer = document.createElement('div'); btHTML5videoPlayerContainer.id = 'bt-html5video-player-container'; var btHTML5videoPlayerControls = document.createElement('div'); var btHTML5videoPlayerBtn = document.createElement('div'); btHTML5videoPlayerBtn.id = 'bt-html5video-player-size-btn'; btHTML5videoPlayerBtn.title = 'Размер видеоплеера'; btHTML5videoPlayerBtn.onclick = function() { if (!this.rights && !this.btHTML5videoPlayer) { try { var btHTML5videoPlayer = this.btHTML5videoPlayer = document.getElementById('bt-html5video-player'); var contents = document.getElementsByClassName('content'); var rights = contents[0].getElementsByClassName('right'); if (rights[1]) { this.rights = rights[1]; } } catch (ex) { return; }; } //if (this.rights.style.display == 'none') { if (this.rights.classList.contains('sizeLarge')) { //this.rights.style.removeProperty('display'); this.rights.classList.remove('sizeLarge'); btHTML5videoPlayerContainer.classList.remove('sizeLarge'); } else { //this.rights.style.display = 'none'; this.rights.classList.add('sizeLarge'); btHTML5videoPlayerContainer.classList.add('sizeLarge'); } }; var btHTML5videoPlayerControls = document.createElement('div'); btHTML5videoPlayerControls.id = 'bt-html5video-player-controls'; btHTML5videoPlayerControls.appendChild(btHTML5videoPlayerBtn); var btHTML5videoPlayerLoopBox = document.createElement('div'); //btHTML5videoPlayerLoopBox.style.display = 'inline-block'; btHTML5videoPlayerLoopBox.title = 'Повторять это видео'; var btHTML5videoPlayerLoop = document.createElement('input'); btHTML5videoPlayerLoop.type = 'checkbox'; btHTML5videoPlayerLoop.name = 'video-loop'; btHTML5videoPlayerLoop.value = 'false'; btHTML5videoPlayerLoop.onchange = function() { if (this.checked) { btHTML5videoPlayer.setAttribute('loop', ''); } else if (btHTML5videoPlayer.loop) { btHTML5videoPlayer.removeAttribute('loop'); } }; btHTML5videoPlayerLoopBox.appendChild(btHTML5videoPlayerLoop); //btHTML5videoPlayerLoopBox.textContent = 'Loop'; btHTML5videoPlayerLoopBox.insertAdjacentHTML('beforeend', 'Loop'); btHTML5videoPlayerControls.appendChild(btHTML5videoPlayerLoopBox); btHTML5videoPlayerContainer.appendChild(btHTML5videoPlayerControls); btHTML5videoPlayerContainer.appendChild(btHTML5videoPlayer); videoInfo.parentNode.insertBefore(btHTML5videoPlayerContainer, videoInfo); var btHTML5videoWrapper = document.createElement('div'); btHTML5videoWrapper.id = 'bt-html5video-wrapper'; document.body.appendChild(btHTML5videoWrapper); btHTML5videoPlayer.onplay = function() { if (typeof this.updateTimeoutID == 'number') { window.clearTimeout(this.updateTimeoutID); this.updateTimeoutID = null; } if (typeof btHTML5videoWrapper.updateTimeoutID == 'number') { window.clearTimeout(btHTML5videoWrapper.updateTimeoutID); btHTML5videoWrapper.updateTimeoutID = null; } this.updateTimeoutID = window.setTimeout(function() { var btHTML5videoWrapper = document.getElementById('bt-html5video-wrapper'); btHTML5videoWrapper.classList.add('playing'); btHTML5videoPlayer.classList.add('playing'); btHTML5videoWrapper.style.position = 'fixed'; }, 50); }; btHTML5videoPlayer.onpause = function() { if (typeof this.updateTimeoutID == 'number') { window.clearTimeout(this.updateTimeoutID); this.updateTimeoutID = null; } if (typeof btHTML5videoWrapper.updateTimeoutID == 'number') { window.clearTimeout(btHTML5videoWrapper.updateTimeoutID); btHTML5videoWrapper.updateTimeoutID = null; } this.updateTimeoutID = window.setTimeout(function() { var btHTML5videoWrapper = document.getElementById('bt-html5video-wrapper'); btHTML5videoWrapper.classList.remove('playing'); btHTML5videoPlayer.classList.remove('playing'); btHTML5videoWrapper.updateTimeoutID = window.setTimeout(function() { btHTML5videoWrapper.style.removeProperty('position'); }, 500); }, 50); }; btHTML5videoPlayer.onseeking = function() { if (this.currentTime == 0) return; if (typeof this.updateTimeoutID == 'number') { window.clearTimeout(this.updateTimeoutID); this.updateTimeoutID = null; } }; btHTML5videoWrapper.onclick = function() { btHTML5videoPlayer.pause(); //btHTML5videoWrapper.className = ''; }; eventSetter.playerOnData.init(btHTML5videoPlayer); var uppod = document.getElementById('uppod'); uppod.style.display = 'none'; var flashBtn = btHTML5videoPanel.getElementsByClassName('flash'); if (flashBtn[0]) { eventSetter.buttonOnClick.init(flashBtn[0], html5ImageColored, html5Image); } var links = btHTML5videoPanel.getElementsByTagName('a'); if (links[0]) { eventSetter.linkOnClick.init(links[0]); } }; var btHTML5videoPanel = document.createElement('div'); btHTML5videoPanel.id = 'bt-html5video-panel'; var html5ImageColored = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAATdJREFUeNpifOqtlsDAwDCfgQwgvfUWIxOQfsBAAWCiQO8BEMECxBdgIvypVQzc/vF4db2tjGX4efkUnM8C9McHYDiAOf++fgbTv+9dZ/gPZaODfwjxDzAXYICvmxYyfNuznpAXLiIbAPKGwa/LJ4FUDgOXcxADs5gMVl2fl01G4bMgOwcG2HTNwBgd/H31FNmABxhe+H3vBjiQsAHh9sUMf18+RRZCMeAgEDv8+/oJJYThcc3NR3w6kNpyk0F83j4GdqgXmMWlGThdAsHsP69wu+ADIpo+AQNQGuxkjDBA8gIw+h+gxwIYvM4LYOCwcAG7AESDDPxxYi/Dj+N7GH5h8R4LNlu+blwIxnjABfQwADlnAZEZC6R5IozDiC4LTNYGoBgBYn8oDQqfDdCY2gBK+sjqAQIMACfPddVHcozkAAAAAElFTkSuQmCC'; var html5Image = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAA/klEQVR42sWTqw6DMBSGeYQ9wh5hj7BHqeCuFjRiBotFLsEiZrAEiQSNWYImmcN2/ZudpjA6mNqfHNPT851ba/m+z8Iw5EEQ/GSIsSDbts9/AXieV0sAY+xAgKqq+JbSNJ0DIAKUZSkvDcPA+75ftSRJCHA3AvI832xBDP+qAILW4hDlQcgE2JqZALUOMGkcRx3APgBRFEnImlFlBMD2FADlfOsX4N0AKpXWFccxL4pCnjdNowBi/UcFcF33Qo5pmowz0Ido6UI55KCMXdfJIACROcsy2comYM8fwNpnAPQj2rgJx2PHH2hnK1zKcZwTZoLVvl/oE3AE4d8s778Aj+4t+EF6GnYAAAAASUVORK5CYII='; if (canPlay) { btHTML5videoPanel.innerHTML = '<img src="' + html5ImageColored + '" width="16" height="16" alt="">' + (flash ? '<button class="flash">FLASH</button>' : '<sub>HTML5</sub>') + '<span></span>' + '<span></span>' + '<span></span>' + '<a href="' + file + '" title="Скачивать правой кнопкой мыши!' + 'И выбрать: "Сохранить объект как…" или т.п">Скачать</a>'; addHTML5video(); } else { btHTML5videoPanel.innerHTML = '<a href="' + file + '"> Скачать</a>'; } styleSheetLoader(canPlay, flash); videoInfo.parentNode.insertBefore(btHTML5videoPanel, videoInfo); }; var addSearchInGoogleBtn = function() { var videoPages = document.getElementsByClassName('video-page'); var videoPage = videoPages[0]; var videoPageH1 = videoPage.getElementsByTagName('h1'); //var searchInGoogle = '<button style="margin-left:10px;color: #555; border: 1px solid #aaa;display:inline;" onclick="javascript:window.open("https://www.google.ru/search?q=" + encodeURIComponent(this.parentNode.firstChild.textContent));void 0;">искать в Google</button>'; var searchInGoogle = document.createElement('button'); searchInGoogle.setAttribute('style', 'cursor:pointer;display:inline;margin-left:10px;color:#555;background:#eee;border:1px solid #aaa;'); searchInGoogle.setAttribute('onclick', 'javascript:window.open("https://www.google.ru/search?q="+encodeURIComponent(this.parentNode.firstChild.textContent));void 0;'); searchInGoogle.textContent = 'искать в Google'; if (videoPageH1[0]) { videoPageH1[0].appendChild(searchInGoogle); } }; var getParams = function() { addSearchInGoogleBtn(); var getScriptContent = function() { var lastSibling = uppod.nextSibling; var targetContent; for (var i = 0; i < 15; i++) { if (lastSibling.nodeType === 1 && /.*file:\s'(http:[^']*).*/m.test(lastSibling.textContent)) { targetContent = lastSibling; break; } lastSibling = lastSibling.nextSibling; } if (targetContent) { return targetContent.textContent; } else { return null; } }; var getPageBodyParams = function() { var bodyContent = getScriptContent() || document.body.innerHTML; var matchBodyContent = bodyContent.match(/.*file:\s'(http:[^']*).*/m); var matchBodyContentPoster = bodyContent.match(/.*poster:\s'(http:[^']*).*/m); if (matchBodyContent[1]) { file = matchBodyContent[1]; poster = matchBodyContentPoster[1] ? matchBodyContentPoster[1] : ''; return {'file': file, 'poster': poster, 'flash': false}; } }; var getUppodParams = function() { var matchFlashvars = flashvars.match(/.*file=(http:[^&]*).*/m); var matchPoster = flashvars.match(/.*poster=(http:[^&]*).*/m); if (matchFlashvars[1]) { file = matchFlashvars[1]; poster = matchPoster[1] ? matchPoster[1] : ''; return {'file': file, 'poster': poster, 'flash': true}; } }; var uppod = document.getElementById('uppod'); var uppodParams = uppod.getElementsByTagName('param'); var flashvars; var file; var poster; var params; if ('flashvars' in uppodParams && uppodParams['flashvars'].value) { flashvars = uppodParams['flashvars'].value; params = getUppodParams(); } else { params = getPageBodyParams(); } if (params) { return params; } }; var params; if (document.readyState === 'complete') { params = getParams(); if (params) createLink(params); } else { window.addEventListener('load', function pageLoaded(e) { window.removeEventListener('load', pageLoaded, false); var params = getParams(); if (params) createLink(params); }, false); } })(window);