您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Provides a button to pop out the YouTube video in a separate window.
当前为
- // ==UserScript==
- // @name YouTube Popout Button
- // @description Provides a button to pop out the YouTube video in a separate window.
- // @version 1.1.1
- // @author joeytwiddle
- // @contributor Alek_T, tehnicallyrite
- // @license ISC
- // @include http://*.youtube.com/watch*
- // @include http://youtube.com/watch*
- // @include https://*.youtube.com/watch*
- // @include https://youtube.com/watch*
- // @grant none
- // @namespace https://greasyfork.org/users/8615
- // ==/UserScript==
- // This is a combination of two scripts I found:
- // - http://userscripts-mirror.org/scripts/show/75815#YouTube:_Pop-out_Video
- // - http://userscripts-mirror.org/scripts/show/69687#YouTube_Popout
- // For a while I think I hosted it at:
- // - http://userscripts-mirror.org/scripts/source/150631.user.js
- // Need to delay, or the target div won't be rendered yet
- setTimeout(function() {
- // Create Button
- var divWatchHeadline = document.evaluate("//div[@id='watch-actions']", document, null, XPathResult.ANY_UNORDERED_NODE_TYPE, null).singleNodeValue;
- divWatchHeadline = divWatchHeadline || document.getElementById("watch7-secondary-actions");
- divWatchHeadline = divWatchHeadline || document.getElementById("watch8-secondary-actions");
- divWatchHeadline = divWatchHeadline || document.querySelector("#menu .ytd-video-primary-info-renderer");
- //divWatchHeadline = divWatchHeadline || document.querySelector("#top-level-buttons");
- var buttonPopout = document.createElement("button");
- buttonPopout.title = "Pop-out Video";
- //buttonPopout.setAttribute("class", "yt-uix-button yt-uix-button-default yt-uix-tooltip");
- buttonPopout.style.background = 'transparent';
- buttonPopout.style.border = 'none';
- buttonPopout.style.cursor = 'pointer';
- buttonPopout.setAttribute("data-tooltip-title", "Pop-out Video");
- var popoutImage = document.createElement("img");
- var offButton = "";
- var overButton = "";
- popoutImage.src = offButton;
- popoutImage.setAttribute("alt", "External link icon");
- popoutImage.setAttribute("style", "padding:0px 0px 2px 1px;");
- buttonPopout.appendChild(popoutImage);
- // The other buttons don't change these days, so we won't either
- //buttonPopout.addEventListener("mouseover", function() { popoutImage.src = overButton; }, false);
- //buttonPopout.addEventListener("mouseout", function() { popoutImage.src = offButton; }, false);
- //divWatchHeadline.appendChild(document.createTextNode("\n"));
- //divWatchHeadline.appendChild(buttonPopout);
- divWatchHeadline.insertBefore(buttonPopout, divWatchHeadline.lastElementChild);
- //divWatchHeadline.appendChild(document.createTextNode("\n"));
- buttonPopout.addEventListener("click", popOutVideo, false);
- function popOutVideo() {
- // Grabbing Video Id
- function gup(name) {
- name = name.replace(/[\[]/, "\\\[").replace(/[\]]/, "\\\]");
- var regexS = "[\\?&]" + name + "=([^&#]*)";
- var regex = new RegExp(regexS);
- var results = regex.exec(window.location.href);
- return results && results[1];
- }
- var ytvidid = gup('v');
- if (ytvidid) {
- //var link = "http://www.youtube.com/watch_popup?v=";
- //var flink = link+ytvidid;
- // The above URL gets redirected to https://www.youtube.com/embed/bNcWVUfwmS4&autoplay=1#at=6
- // And the redirect causes autoplay to not work. So let's go directly to the target URL.
- var flink = "https://www.youtube.com/embed/" + ytvidid + "?autoplay=1";
- var lcheck = location.href;
- // I think this used to prevent infinite loops when the script was auto-forwarding
- if (lcheck !== flink) {
- try {
- var player = window.document.getElementById('movie_player');
- if (player) {
- // If we are in Greasemonkey's sandbox, we need to get out!
- if (player.wrappedJSObject) {
- player = player.wrappedJSObject;
- }
- player.pauseVideo();
- var time = player.getCurrentTime();
- flink += "#at=" + (time | 0);
- }
- } catch (e) {
- console.error("" + e);
- }
- // window.location = flink;
- // Change "YoutubePopout" to "_blank" if you want new popouts to appear in a separate window from the existing popout.
- window.open(flink, "YoutubePopout", "menubar=no,location=no,resizable=yes,status=no,toolbar=no,personalbar=no");
- }
- }
- }
- }, 4000);