優酷全屏模式

YouTube畫面自動轉換成100高、100寬的畫面。

目前為 2022-06-15 提交的版本,檢視 最新版本

  1. // ==UserScript==
  2. // @name:ko 유튜브 풀스크린
  3. // @name Youtube Fullscreen Mode
  4. // @name:ru Youtube Полный режим
  5. // @name:ja Youtubeフルスクリーンモードの
  6. // @name:zh-CN 优酷全屏模式
  7. // @name:zh-TW 優酷全屏模式
  8.  
  9. // @description:ko 유튜브 화면을 자동으로 꽉 찬 화면으로 바꿉니다.
  10. // @description Automatically switch YouTube screens to 100 height and 100 width screens.
  11. // @description:ru Автоматическое переключение экрана на YouTube на экран высотой 100 и шириной 100.
  12. // @description:ja ユーチューブ画面を高さ100、広さ100画面に自動転換。
  13. // @description:zh-CN YouTube画面自动转换成100高、100宽的画面。
  14. // @description:zh-TW YouTube畫面自動轉換成100高、100寬的畫面。
  15.  
  16. // @namespace https://ndaesik.tistory.com/
  17. // @version 2022.06.16.08.12
  18. // @author ndaesik
  19. // @icon https://lh3.googleusercontent.com/iLZyxGK7l1343U4E7eAfgKbRWW6qhzCJq-Z92M60JzCMntFyaFF2GUQVRxPhfGcy6qRISLjHv4fX1vtq0TZkZMAzBjM
  20. // @match *://*.youtube.com/*
  21. // ==/UserScript==
  22.  
  23. const suggestBoxToDarkCSS = document.createElement('style');
  24. suggestBoxToDarkCSS.innerText = `
  25. [dark] .gstl_50.sbdd_a * {background-color:#121212!important; border-color:#303030!important}
  26. [dark] .gsfs,[dark] .sbpqs_a {color:#FFF!important}
  27. [dark] .sbqs_c:before {filter: invert(1)!important} `
  28.  
  29. const fullscreenVideoCSS = document.createElement('style');
  30. fullscreenVideoCSS.innerText = `
  31. ytd-app:not([guide-persistent-and-visible]) [theater] #player video,
  32. :is(ytd-watch-flexy[theater],ytd-watch-flexy[fullscreen]) #player-theater-container {
  33. height: 100vh!important; max-height: 100vh!important; min-height: 100vh!important} `
  34.  
  35. const autoHideTopCSS = document.createElement('style');
  36. autoHideTopCSS.innerText = `
  37. ytd-app:not([guide-persistent-and-visible]) :is(#masthead-container ytd-masthead, #masthead-container.ytd-app::after) {transform: translateY(-56px); transition: transform .1s .3s ease-out}
  38. ytd-app:not([guide-persistent-and-visible]) :is(#masthead-container:hover ytd-masthead, #masthead-container:hover.ytd-app::after, #masthead-container:focus-within ytd-masthead) {transform: translateY(0px)}
  39. ytd-app:not([guide-persistent-and-visible]) ytd-page-manager {margin-top: 0!important} `
  40. autoHideTopCSS.className = "autoHideTopCSS";
  41.  
  42. function isWatchPage() {
  43. return !(document.URL.indexOf('watch') == -1)
  44. };
  45.  
  46. function isTheaterMode() {
  47. let scrollbarWidth = window.innerWidth - document.querySelector('ytd-app').offsetWidth;
  48. let playerWidth = document.querySelector('#ytd-player')?.offsetWidth;
  49. let isWidePlayer = scrollbarWidth + playerWidth == window.innerWidth;
  50. return ( isWatchPage() && isWidePlayer )
  51. };
  52.  
  53. function alwaysTheaterMode() {
  54. let clickModeButtonRepeatly = setInterval( _ => {
  55. if ( isTheaterMode() ) {
  56. clearInterval( clickModeButtonRepeatly );
  57. } else {
  58. document.querySelectorAll('.ytp-size-button')?.forEach( e => e.click());
  59. clearInterval( clickModeButtonRepeatly );
  60. }
  61. }, 100);
  62. setTimeout( _ => {
  63. clearInterval( clickModeButtonRepeatly );
  64. }, 10000);
  65. };
  66.  
  67. ['load', 'unload'].forEach( e => {
  68. window.addEventListener( e, _ => {
  69. isWatchPage() ? document.head.appendChild(autoHideTopCSS) : false;
  70. document.head.appendChild(suggestBoxToDarkCSS);
  71. document.head.appendChild(fullscreenVideoCSS);
  72. alwaysTheaterMode();
  73. window.scrollTo(0, 0);
  74. });
  75. });
  76.  
  77. window.addEventListener('click', _ => {
  78. setTimeout( _ => {
  79. if ( !isWatchPage() || !isTheaterMode() ) {
  80. document.querySelector('.autoHideTopCSS')?.remove()
  81. } else if ( isTheaterMode() ) {
  82. document.head.appendChild(autoHideTopCSS)
  83. }
  84. }, 100);
  85. });