Youtube自动选择中文翻译字幕

Youtube自动点击中文翻译字幕

目前為 2022-01-24 提交的版本,檢視 最新版本

  1. // ==UserScript==
  2. // @name Youtube自动选择中文翻译字幕
  3. // @namespace http://tampermonkey.net/
  4. // @version 4.7
  5. // @description Youtube自动点击中文翻译字幕
  6. // @author 大奶瓜
  7. // @icon 
  8. // @match https://www.youtube.com/*
  9. // @grant GM_setValue
  10. // @grant GM_getValue
  11. // @license MIT
  12. // ==/UserScript==
  13.  
  14. (() => {
  15. const lcc_log = log => { console.log(`%clcc_log--->`, "color: #66b2ff; font-style: italic; background-color: #001e3c ;padding: 5px 10px;font-size:20px;border-radius:10px"); console.log(log) };
  16. const $ = el => document.querySelector(el)
  17. const $$ = el => document.querySelectorAll(el)
  18.  
  19. const translate = () => {
  20. const trans_flag = GM_getValue("trans_flag", true)
  21.  
  22. // 设置菜单按钮点击器
  23. const clickActive = (clickBtn, role = "menuitemradio",) => {
  24. for (const node of $$(`[role=${role}]`)) {
  25. if (node.innerText.trim().includes(clickBtn)) {
  26. node.click()
  27. return
  28. }
  29. }
  30. }
  31. const ccBtnT = $('.ytp-subtitles-button[aria-pressed="true"]')
  32. const ccBtnF = $('.ytp-subtitles-button[aria-pressed="false"]')
  33. const noSub = $('.ytp-subtitles-button[aria-pressed="false"][title="无法显示字幕"]')
  34. if (noSub !== null) return
  35. if (ccBtnT === null && ccBtnF === null) return
  36. // 字幕按钮
  37. if (ccBtnF) ccBtnF.click()
  38. if (!trans_flag) return
  39. // 设置按钮
  40. $('.ytp-settings-button').click()
  41. // 设置菜单按钮
  42. clickActive("字幕", "menuitem")
  43. clickActive("中文(简体)")
  44. clickActive("中文(台湾)")
  45. clickActive("中文(中国)")
  46. clickActive("自动翻译")
  47. clickActive("中文(简体)")
  48. }
  49. // 创建一个循环定时器
  50. const trans_interval = setInterval(() => {
  51. // 一直循环,一直到找到video元素为止,然后把事件添加上去
  52. const videoNode = $('video')
  53. if (videoNode) {
  54. clearInterval(trans_interval)
  55. translate()
  56. videoNode.addEventListener('loadeddata', translate, false)
  57. }
  58. }, 500)
  59. // 创建一个循环定时器
  60. const btn_interval = setInterval(() => {
  61. const menu_container = $("#menu-container")
  62. if (menu_container) {
  63. clearInterval(btn_interval)
  64. const trans_flag = GM_getValue("trans_flag", true)
  65. const change_trans = document.createElement('div')
  66. const change_input = document.createElement('input')
  67. const change_lable = document.createElement('lable')
  68. Object.assign(change_trans.style, { paddingTop: "10px", display: "flex", paddingRight: "8px" })
  69. change_trans.id = "change_trans"
  70. change_input.type = "checkbox"
  71. if (trans_flag) {
  72. change_input.checked = true
  73. change_lable.innerHTML = "翻译开启"
  74. } else {
  75. change_input.checked = false
  76. change_lable.innerHTML = "翻译关闭"
  77. }
  78. change_trans.onclick = e => {
  79. const trans_flag = GM_getValue("trans_flag", true)
  80. if (trans_flag != change_input.checked) {
  81. GM_setValue("trans_flag", change_input.checked)
  82. if (!trans_flag) {
  83. change_input.checked = true
  84. change_lable.innerHTML = "翻译开启"
  85. } else {
  86. change_input.checked = false
  87. change_lable.innerHTML = "翻译关闭"
  88. }
  89. window.location.reload()
  90. //if(confirm("是否更新当前视频的翻译状态?\n点击确定:当前网页会刷新,当前视频翻译状态会切换\n点击取消:不会刷新,翻译状态从下一个视频生效")) window.location.reload()
  91. }
  92. }
  93. change_trans.appendChild(change_input)
  94. change_trans.appendChild(change_lable)
  95. menu_container.parentNode.insertBefore(change_trans, menu_container)
  96. }
  97. }, 1000)
  98. })()

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址