GeoGuessr Ultimate Script

GeoGuessr Ultimate Script - One Script to rule them all - Work In Progress - Adding features over time - Removes Bottom, Right and Top Bar (Options) - Pimps Data - Makes for a cleaner experience - Removes Author (Optinal - For an extra challenge) - Changes flags with numbered flags - Adjust GeoGuessr Logo position - Adjusts Data position

当前为 2020-08-08 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name GeoGuessr Ultimate Script
  3. // @version 0.4.2
  4. // @description GeoGuessr Ultimate Script - One Script to rule them all - Work In Progress - Adding features over time - Removes Bottom, Right and Top Bar (Options) - Pimps Data - Makes for a cleaner experience - Removes Author (Optinal - For an extra challenge) - Changes flags with numbered flags - Adjust GeoGuessr Logo position - Adjusts Data position
  5. // @author MrAmericanMike
  6. // @include /^(https?)?(\:)?(\/\/)?([^\/]*\.)?geoguessr\.com($|\/.*)/
  7. // @grant none
  8. // @run-at document-start
  9. // @namespace https://greasyfork.org/en/scripts/406060-geoguessr-ultimate-script
  10. // ==/UserScript==
  11.  
  12. (function() {
  13. "use strict";
  14.  
  15. console.log("GeoGuessrUltimateScript");
  16.  
  17.  
  18. // MODULES // Set from 'true' to 'false' any module that you don't need. Example: removeTopBar = false;
  19.  
  20. // REMOVE BOTTOM WHITE BAR WHILE PLAYING A MAP
  21. let removeBottomBar = true;
  22.  
  23. // REMOVE RIGHT WHITE BAR ON ROUND RESULTS SCREEN
  24. let removeRightBar = true;
  25.  
  26. // MAKE A CLEANER STREETVIEW BY REMOVING TOP BAR
  27. let removeTopBar = true;
  28.  
  29. // REPLACE FLAGS AT THE END OF A GAME WITH NUMBERED FLAGS
  30. let replaceFlags = true;
  31.  
  32. // PIMP MY DATA
  33. let pimpData = true;
  34.  
  35. let floatData = "RIGHT"; // Where to place the logo on screen (Valid options "LEFT" "RIGHT")
  36.  
  37. let dataMargin = "0.5rem"; // Horizontal margin from the side of the window [default value is "2.0rem"] (https://www.w3schools.com/cssref/css_units.asp)
  38. let topMargin = "0.5rem"; // Vertical margin from top of the window [default value is "1.0rem"] (https://www.w3schools.com/cssref/css_units.asp)
  39.  
  40. let bgColor = "rgba(255, 255, 255, 0.55)"; // RGBA COLOR (https://www.hexcolortool.com/)
  41. let titlesColor = "#6695EF"; // Titles color on the data panel in HEX
  42. let dataColor = "#EF6695"; // Data color on the data panel in HEX
  43.  
  44. // GEOGUESSR LOGO
  45. let adjustLogo = true;
  46.  
  47. let floatLogo = "LEFT"; // Where to place the logo on screen (Valid options "LEFT" "CENTER" "RIGHT")
  48. let logoTopMargin = "0.25rem"; // Margin from top of the window (https://www.w3schools.com/cssref/css_units.asp)
  49. let logoOpacity = "0.5"; // Value going from 0.0 to 1.0 (0.0 represents fully transparent)
  50.  
  51. // HIDE FOOTPRINT - (This is where photospheres author would show)
  52. let hideFootprint = true;
  53.  
  54. // HIDE COMPASS - (For an extra challenge)
  55. let hideCompass = false;
  56.  
  57.  
  58.  
  59.  
  60.  
  61.  
  62.  
  63.  
  64.  
  65.  
  66.  
  67.  
  68.  
  69. // *******************************
  70. // NO NEED TO EDIT BELOW THIS LINE
  71. // *******************************
  72.  
  73. // IMAGES
  74. const IMAGES = [
  75. '',
  76. '',
  77. '',
  78. '',
  79. ''
  80. ];
  81.  
  82. setTimeout(executeRealTime, 5);
  83. setTimeout(executeRealTime, 150);
  84. setTimeout(executeRealTime, 300);
  85. setTimeout(executeRealTime, 600);
  86. setTimeout(executeRealTime, 900);
  87. setTimeout(executeRealTime, 1200);
  88. setTimeout(executeRealTime, 1500);
  89.  
  90. // REAL TIME
  91. function executeRealTime(){
  92. if(removeBottomBar){
  93. doRemoveBottomBar();
  94. }
  95. if(removeRightBar){
  96. doRemoveRightBar();
  97. }
  98. if(removeTopBar){
  99. doRemoveTopBar();
  100. }
  101. if(pimpData){
  102. doPimpData();
  103. }
  104. if(hideFootprint){
  105. doHideFootprint();
  106. }
  107. if(hideCompass){
  108. doHideCompass();
  109. }
  110. if(adjustLogo){
  111. doAdjustLogo();
  112. }
  113. if(replaceFlags){
  114. changeFlags();
  115. }
  116. }
  117.  
  118. // BOTTOM BAR
  119. function doRemoveBottomBar(){
  120. addGlobalStyle(`
  121. .game-layout__in-game-ad {
  122. display: none;
  123. }
  124. `);
  125. }
  126.  
  127. // RIGHT BAR
  128. function doRemoveRightBar(){
  129. addGlobalStyle(`
  130. .result__right {
  131. display: none;
  132. }
  133. `);
  134. }
  135.  
  136. // TOP BAR
  137. function doRemoveTopBar(){
  138. if(window.location.pathname.includes("game") || window.location.pathname.includes("challenge")){
  139. addGlobalStyle(`
  140. .layout {
  141. --layout-header-height: 0rem;
  142. }
  143. .header__right{
  144. display: none;
  145. }
  146. .game-layout__panorama-canvas{
  147. height: 100%;
  148. }
  149. `);
  150. }
  151. else{
  152. addGlobalStyle(`
  153. .layout {
  154. --layout-header-height: 3rem;
  155. }
  156. .header__right{
  157. display: block;
  158. }
  159. `);
  160. }
  161. }
  162.  
  163. // DATA
  164. function doPimpData(){
  165.  
  166. switch(floatData){
  167. case "LEFT":
  168. addGlobalStyle(`
  169. .game-layout__status{
  170. top: ${topMargin};
  171. left: ${dataMargin};
  172. right: auto;
  173. }
  174. `);
  175. break;
  176.  
  177. case "RIGHT":
  178. addGlobalStyle(`
  179. .game-layout__status{
  180. top: ${topMargin};
  181. right: ${dataMargin};
  182. left: auto;
  183. }
  184. `);
  185. break;
  186.  
  187. default:
  188. break;
  189. }
  190.  
  191. addGlobalStyle(`
  192. .game-statuses {
  193. background: ${bgColor};
  194. }
  195. .game-status__heading{
  196. color: ${titlesColor};
  197. }
  198. .game-status__body{
  199. color: ${dataColor};
  200. }
  201. `);
  202. }
  203.  
  204. // FOOTPRINT
  205. function doHideFootprint(){
  206. addGlobalStyle(`
  207. .gmnoprint, .gm-style-cc{
  208. display: none;
  209. }
  210. `);
  211. }
  212.  
  213. // COMPASS
  214. function doHideCompass(){
  215. addGlobalStyle(`
  216. .compass{
  217. display: none;
  218. }
  219. `);
  220. }
  221.  
  222. // GEOGUESSR LOGO
  223. function doAdjustLogo(){
  224. if(window.location.pathname.includes("game") || window.location.pathname.includes("challenge")){
  225. switch(floatLogo){
  226. case "LEFT":
  227. addGlobalStyle(`
  228. .header__left{
  229. margin-left: 0;
  230. }
  231. `);
  232. break;
  233.  
  234. case "CENTER":
  235. addGlobalStyle(`
  236. .header__left{
  237. margin-left: auto;
  238. }
  239. `);
  240. break;
  241.  
  242. case "RIGHT":
  243. addGlobalStyle(`
  244. .header__left{
  245. margin-left: auto;
  246. margin-right: 0;
  247. }
  248. `);
  249. break;
  250. }
  251.  
  252. addGlobalStyle(`
  253. .header__logo{
  254. margin-top: ${logoTopMargin};
  255. opacity: ${logoOpacity};
  256. }
  257. `);
  258. }
  259. else{
  260. addGlobalStyle(`
  261. .header__left{
  262. margin-left: 0;
  263. }
  264. .header__logo{
  265. margin-top: auto;
  266. opacity: 1;
  267. }
  268. `);
  269. }
  270. }
  271.  
  272. // CHANGE FLAGS
  273. function changeFlags(){
  274. let flags = document.getElementsByClassName("pin__image");
  275.  
  276. if (flags.length === 5) {
  277. Array.prototype.forEach.call(flags, (flag, index) => {
  278. flag.src = IMAGES[index];
  279. });
  280. }
  281. }
  282.  
  283. // GLOBAL STYLES INJECTOR
  284. function addGlobalStyle(css) {
  285. let head;
  286. let style;
  287. head = document.getElementsByTagName('head')[0];
  288. if (!head) { return; }
  289. style = document.createElement('style');
  290. style.type = 'text/css';
  291. style.innerHTML = css.replace(/;/g, ' !important;');
  292. head.appendChild(style);
  293. }
  294.  
  295.  
  296.  
  297. // LISTEN FOR PAGE CHANGES
  298. let currentTab = "";
  299. let oldTab = "";
  300.  
  301. window.addEventListener("click", (event) => {
  302. for (let x = 0; x < 2500; x+=250){
  303. setTimeout(() => {
  304. lookForURLChange(event);
  305. }, x);
  306. }
  307. });
  308.  
  309. function lookForURLChange(event) {
  310. if(event["explicitOriginalTarget"]["baseURI"]){
  311. currentTab = event["explicitOriginalTarget"]["baseURI"];
  312. }
  313. else if(event.hasOwnProperty("path")){
  314. event.path.forEach((element) => {
  315. if(element.hasOwnProperty("URL") && element.hasOwnProperty("location")){
  316. currentTab = element.location.pathname;
  317. }
  318. });
  319. }
  320. if(oldTab != currentTab){
  321. oldTab = currentTab;
  322. setTimeout(executeRealTime, 0);
  323. }
  324. }
  325.  
  326.  
  327.  
  328.  
  329.  
  330.  
  331.  
  332. })();