您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Removes the left nav bar entirely and stretches the twitch player to use as much space as possible.
当前为
// ==UserScript== // @name Bigger Twitch // @author Remos // @version 1.04 // @description Removes the left nav bar entirely and stretches the twitch player to use as much space as possible. // @include http://*.twitch.tv/* // @include http://twitch.tv/* // @include http://*.twitch.tv/*/c/* // @include http://*.twitch.tv/*/b/* // @exclude http://www.twitch.tv/*/chat?popout= // @exclude http://www.twitch.tv/*/popout // @exclude http://www.twitch.tv/*/dashboard // @exclude http://www.twitch.tv/inbox* // @exclude http://www.twitch.tv/subscriptions* // @exclude http://store.twitch.tv // @exclude http://api.twitch.tv/* // @exclude https://api.twitch.tv/* // @require http://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js // @grant GM_addStyle // @grant GM_getValue // @grant GM_setValue // @copyright 2014, Remos // @run-at document-end // @icon https://monkeyguts.com/icon/288.png // @namespace 41229d0298d2565bc814c34b46b9158b // ==/UserScript== // Icons used from http://icomoon.io/ GM_addStyle("#left_col.bigttv { visibility: hidden !important; }"); GM_addStyle("#main_col.bigttv { margin-left: 0px !important; }"); GM_addStyle(".ember-view.ember-chat.bigttv { min-width: 0px !important; }"); GM_addStyle(".player-column #player.bigttv, .archive_site_player_container.bigttv, .target-player.bigttv { position: fixed !important; top: 0px !important; left: 0px !important; z-index: 99999; }"); GM_addStyle(".bigttv-button.bigttv-contract { background-image: url(); }"); GM_addStyle(".bigttv-button { cursor: pointer; position: absolute; bottom: 0px; left: 160px; padding: 3px; width: 21px; height: 21px; background-repeat: no-repeat; background-position: 3px; background-size: 18px; background-image: url(); }"); GM_addStyle(".js-new-channel-ad { visibility: hidden !important; }"); GM_addStyle("#channel.bigttv { padding: 0 }"); GM_addStyle(".target-player { position: relative; }"); var chatWidth = GM_getValue('chatwidth', 340); var buttonClickNum = 2; var buttonTitle = "Middle click to set chat width."; // Chrome doesn't like us using right click. if(navigator.userAgent.toLowerCase().indexOf('firefox') != -1) { // Firefox doesn't like letting us use middle click. buttonTitle = "Right click to set chat width."; buttonClickNum = 3; } var biggerttvEnabled = false; var selfTriggered = false; var currentPlayer; function updateSizes(player) { player = (typeof player === 'undefined') ? currentPlayer : player; var columnVisible = $('#right_col').is(':visible'); if(biggerttvEnabled) { var windowWidth = $(window).width(); var windowHeight = $(window).height(); var playerWidth = windowWidth; if(columnVisible) playerWidth = windowWidth - chatWidth; //$('#player, .archive_site_player_container, .target-player').attr('style', 'height: ' + windowHeight + 'px !important; width: ' + playerWidth + 'px !important;'); $(player).attr('style', 'height: ' + windowHeight + 'px !important; width: ' + playerWidth + 'px !important;'); $('[id$=flash-player], #archive_site_player_flash').attr('style', 'height: 100% !important; width: 100% !important; visibility: inherit !important'); if(columnVisible) $('#main_col').css('margin-right', chatWidth); else $('#main_col').css('margin-right', 0); $('#main_col').width('auto'); $('#right_col').width(chatWidth); $('#right_col').width(chatWidth); $('#right_nav').parent().width(chatWidth); $('#right_nav').width(chatWidth - 19); $('#chat').width(chatWidth); $('.js-new-channel-ad').width(chatWidth); currentPlayer = player; } else { currentPlayer = null; $(player).attr('style', ''); var resetChatWidth = 340; if(!columnVisible && !$('#right_col').hasClass('ember-view')) resetChatWidth = 0; $('#right_col').width(resetChatWidth); $('#chat').width(340); $('#main_col').css('margin-right', ''); selfTriggered = true; window.dispatchEvent(new Event('resize')); selfTriggered = false; } } function toggleBigger(enable, target) { if(typeof enable != 'boolean') enable = !biggerttvEnabled; biggerttvEnabled = enable; $('#channel').toggleClass('bigttv', enable); $('#main_col').toggleClass('bigttv', enable); $('#left_col').toggleClass('bigttv', enable); $('.ember-view.ember-chat').toggleClass('bigttv', enable); $(target).parent().toggleClass('bigttv', enable); //$('#player, .archive_site_player_container').toggleClass('bigttv', enable); $('.bigttv-button').toggleClass('bigttv-contract', enable); updateSizes($(target).parent()); } function createButton() { var button = $('<a title="' + buttonTitle + '" class="bigttv-button bigttv-expand"> </a>'); button.unbind().click(function(e) { if(e.which == 1) { toggleBigger(null, e.target); return false; } }).mousedown(function(e) { if(e.which == buttonClickNum) { var newWidth = window.prompt("Enter new chat width:", GM_getValue('chatwidth', 340)); if($.isNumeric(newWidth)) { chatWidth = parseInt(newWidth); GM_setValue('chatwidth', chatWidth); updateSizes($(e.target).parent()); } return false; } }); return button; } var resizeTimer; $(window).resize(function() { if(selfTriggered) return; clearTimeout(resizeTimer); resizeTimer = setTimeout(updateSizes, (typeof BTTVLOADED === 'undefined') ? 0 : 1500); }); function addButton(items) { items.each(function(index) { if($(this).has('.bigttv-button').length == 0) $(this).append(createButton()); }); } $('#player, .archive_site_player_container, .target-player').ready(function() { addButton($('#player, .archive_site_player_container, .target-player')) }); waitForKeyElements('.target-player', addButton); unsafeWindow.bigbutton = createButton; // ====================================== function waitForKeyElements ( selectorTxt, /* Required: The jQuery selector string that specifies the desired element(s). */ actionFunction, /* Required: The code to run when elements are found. It is passed a jNode to the matched element. */ bWaitOnce, /* Optional: If false, will continue to scan for new elements even after the first match is found. */ iframeSelector /* Optional: If set, identifies the iframe to search. */ ) { var targetNodes, btargetsFound; if (typeof iframeSelector == "undefined") targetNodes = $(selectorTxt); else targetNodes = $(iframeSelector).contents () .find (selectorTxt); if (targetNodes && targetNodes.length > 0) { btargetsFound = true; /*--- Found target node(s). Go through each and act if they are new. */ targetNodes.each ( function () { var jThis = $(this); var alreadyFound = jThis.data ('alreadyFound') || false; if (!alreadyFound) { //--- Call the payload function. var cancelFound = actionFunction (jThis); if (cancelFound) btargetsFound = false; else jThis.data ('alreadyFound', true); } } ); } else { btargetsFound = false; } //--- Get the timer-control variable for this selector. var controlObj = waitForKeyElements.controlObj || {}; var controlKey = selectorTxt.replace (/[^\w]/g, "_"); var timeControl = controlObj [controlKey]; //--- Now set or clear the timer as appropriate. if (btargetsFound && bWaitOnce && timeControl) { //--- The only condition where we need to clear the timer. clearInterval (timeControl); delete controlObj [controlKey] } else { //--- Set a timer, if needed. if ( ! timeControl) { timeControl = setInterval ( function () { waitForKeyElements ( selectorTxt, actionFunction, bWaitOnce, iframeSelector ); }, 300 ); controlObj [controlKey] = timeControl; } } waitForKeyElements.controlObj = controlObj; }