Xbox Cloud Gaming 云游戏语言本地化

将 Xbox Cloud Gaming 的游戏设置为浏览器首选语言

目前为 2022-11-22 提交的版本。查看 最新版本

  1. // ==UserScript==
  2. // @name Xbox Cloud Gaming Localization
  3. // @name:zh-CN Xbox Cloud Gaming 云游戏语言本地化
  4. // @name:zh-TW Xbox Cloud Gaming 雲端游戲語言本地化
  5. // @namespace http://tampermonkey.net/
  6. // @version 0.3
  7. // @description Set Xbox Cloud Gaming' game language to your browser's preferred language.
  8. // @description:zh-CN 将 Xbox Cloud Gaming 的游戏设置为浏览器首选语言
  9. // @description:zh-TW 將 Xbox Cloud Gaming 的遊戲設定為瀏覽器首選語言
  10. // @author TGSAN
  11. // @match https://www.xbox.com/*/play*
  12. // @icon 
  13. // @inject-into page
  14. // @run-at document-start
  15. // @grant unsafeWindow
  16. // ==/UserScript==
  17.  
  18. (function() {
  19. 'use strict';
  20.  
  21. if (self.unsafeWindow) {
  22. console.log("[Xbox Cloud Gaming Localization] use unsafeWindow mode");
  23. } else {
  24. console.log("[Xbox Cloud Gaming Localization] use window mode (your userscript extensions not support unsafeWindow)");
  25. self.unsafeWindow = self.window;
  26. }
  27.  
  28. // Your code here...
  29. let allLanguages = [];
  30. let selectedLanguage = "";
  31.  
  32. allLanguages.push(navigator.language);
  33. navigator.languages.forEach(language => {
  34. allLanguages.push(language);
  35. });
  36. for (let language of allLanguages) {
  37. const reg = /^[a-z]{2}-[A-Z]{2}$/;
  38. const isFullLanguage = reg.test(language);
  39. if (isFullLanguage) {
  40. selectedLanguage = language;
  41. break;
  42. }
  43. }
  44.  
  45. const originFetch = fetch;
  46. unsafeWindow.fetch = (...arg) => {
  47. // console.log('fetch arg', ...arg);
  48.  
  49. let arg0 = arg[0];
  50. let url = "";
  51. let isRequest = false;
  52. switch (typeof arg0) {
  53. case "object":
  54. url = arg0.url;
  55. isRequest = true;
  56. break;
  57. case "string":
  58. url = arg0;
  59. break;
  60. default:
  61. break;
  62. }
  63.  
  64. if (url.indexOf('/v5/sessions/cloud/play') > -1) {
  65. // Start Configuration
  66. return new Promise((resolve, reject) => {
  67. if (isRequest && arg0.method == "POST") {
  68. arg0.json().then(json => {
  69. if (selectedLanguage != "") {
  70. console.log("Selected: " + selectedLanguage);
  71. json["settings"]["locale"] = selectedLanguage;
  72. } else {
  73. console.log("Use default language");
  74. }
  75. let body = JSON.stringify(json);
  76. arg[0] = new Request(url, {
  77. method: arg0.method,
  78. headers: arg0.headers,
  79. body: body,
  80. mode: arg0.mode,
  81. credentials: arg0.credentials,
  82. cache: arg0.cache,
  83. redirect: arg0.redirect,
  84. referrer: arg0.referrer,
  85. integrity: arg0.integrity
  86. });
  87. originFetch(...arg).then(res => {
  88. resolve(res);
  89. }).catch(err => {
  90. reject(err);
  91. });
  92. });
  93. } else {
  94. console.error("[ERROR] Not a request.");
  95. return originFetch(...arg);
  96. }
  97. });
  98. } else if (url.indexOf('/v2/login/user') > -1) {
  99. // Area Select
  100. return new Promise((resolve, reject) => {
  101. originFetch(...arg).then(res => {
  102. res.json().then(json => {
  103. // console.error(json);
  104. json["offeringSettings"]["allowRegionSelection"] = true;
  105. let body = JSON.stringify(json);
  106. let newRes = new Response(body, {
  107. status: res.status,
  108. statusText: res.statusText,
  109. headers: res.headers
  110. })
  111. resolve(newRes);
  112. }).catch(err => {
  113. reject(err);
  114. });
  115. }).catch(err => {
  116. reject(err);
  117. });
  118. });
  119. } else {
  120. return originFetch(...arg);
  121. }
  122.  
  123. }
  124. })();

QingJ © 2025

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