Rainbow UI 🌈 | Ad Block 🛑 | Better Map 🗺 | Show Ping 🏓 | And More … | MooMoo.IO

Rainbow UI, ad block, better map, always show ping, start with extra resources, and more for moomoo.io.

  1. // ==UserScript==
  2. // @name Rainbow UI 🌈 | Ad Block 🛑 | Better Map 🗺 | Show Ping 🏓 | And More … | MooMoo.IO
  3. // @namespace -
  4. // @version 1.3.4
  5. // @description Rainbow UI, ad block, better map, always show ping, start with extra resources, and more for moomoo.io.
  6. // @author NotYou
  7. // @match https://moomoo.io/*
  8. // @match https://*.moomoo.io/*
  9. // @match http://moomoo.io/*
  10. // @match http://*.moomoo.io/*
  11. // @run-at document-body
  12. // @license GPL-3.0-or-later
  13. // @grant none
  14. // ==/UserScript==
  15.  
  16. // You can change "false" to "true" (without quotes)
  17. const modConfig = {
  18. rainbowObjects: true,
  19. invertColors: false
  20. }
  21.  
  22. // Do NOT edit code below
  23.  
  24. const extra = function() {
  25. const getResources = window.follmoo
  26.  
  27. if(getResources) {
  28. getResources()
  29. }
  30. }
  31. const style = document.createElement('style')
  32. style.appendChild(document.createTextNode(`
  33. :root {
  34. --w: rgb(255, 255, 255);
  35. --b: rgb(19, 19, 19);
  36. --f: rgb(9, 9, 9);
  37. --b-t: rgba(0, 0, 0, 0.6);
  38. --f-t: rgba(0, 0, 0, 0.8);
  39. }
  40.  
  41. /* AD BLOCK */
  42.  
  43. #adCard, #menuContainer > :last-child, #promoImgHolder, #pre-content-container, #ot-sdk-btn-floating, #moomooio_728x90_home, #moomooio_300x250_1,
  44.  
  45. /* COOKIE BLOCK */
  46.  
  47. #onetrust-consent-sdk
  48.  
  49. {
  50. display: none !important;
  51. }
  52.  
  53. /* RAINBOW UI */
  54.  
  55. #serverBrowser, #vipServerBrowser, .menuCard, #linksContainer2 {
  56. background-color: var(--b);
  57. }
  58.  
  59. #loadingText, #diedText, #gameName, #partyButton, #youtuberOf, #pingDisplay, #ageText, #linksContainer2, #enterGame span, #nameInput, .material-icons {
  60. color: var(--f);
  61. }
  62.  
  63. #ageBody, #actionBar *, #resDisplay *, #upgradeHolder *, #mapDisplay, #topInfoHolder, #killCounter, .uiElement, #ageBar, #storeHolder, .storeTab, #allianceHolder, #allianceManager *, #chatBox, .notifButton {
  64. background-color: var(--f-t) !important;
  65. }
  66.  
  67. .uiElement.gameButton:hover, #actionBar *:hover, #upgradeHolder *:hover, .storeTab:hover, .notifButton:hover {
  68. background-color: var(--b-t);
  69. }
  70.  
  71. #menuCardHolder[style*="block"] {
  72. display: grid !important;
  73. }
  74.  
  75. #rightCardHolder, #guideCard {
  76. height: 147px;
  77. }
  78.  
  79. .menuCard {
  80. box-shadow: var(--f) 0 7px;
  81. }
  82.  
  83. .menuCard * {
  84. color: var(--w);
  85. }
  86.  
  87. #serverBrowser, #vipServerBrowser {
  88. border: 1px solid var(--f);
  89. }
  90.  
  91. #gameName {
  92. text-shadow:
  93. var(--b) 0px 1px 0px,
  94. var(--b) 0px 2px 0px,
  95. var(--b) 0px 3px 0px,
  96. var(--b) 0px 4px 0px,
  97. var(--b) 0px 5px 0px,
  98. var(--b) 0px 6px 0px,
  99. var(--b) 0px 7px 0px,
  100. var(--b) 0px 8px 0px,
  101. var(--b) 0px 9px 0px;
  102. }
  103.  
  104. #ageBarBody {
  105. background-color: red;
  106. }
  107.  
  108. #gameUI .material-icons, .joinAlBtn {
  109. color: red !important;
  110. }
  111.  
  112. #enterGame, #joinPartyButton, #ageBarBody, #gameUI .material-icons, .joinAlBtn, a {
  113. animation: 5s infinite linear both normal rainbow;
  114. }
  115.  
  116. @keyframes rainbow {
  117. 0% { filter: hue-rotate(0deg) }
  118. 100% { filter: hue-rotate(360deg) }
  119. }
  120.  
  121. /* OTHER */
  122.  
  123. #mapDisplay {
  124. background-image: url(data:image/png;base64,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) !important;
  125. background-size: contain !important;
  126. }
  127.  
  128. #topInfoHolder {
  129. border-radius: 3px;
  130. }
  131.  
  132. #pingDisplay {
  133. display: block;
  134. }
  135.  
  136. #vipServerBrowser {
  137. width: 100%;
  138. height: 24px;
  139. }
  140.  
  141. /* MODIFICATIONS */
  142.  
  143. ${modConfig.invertColors ? `
  144. #gameCanvas {
  145. -webkit-filter: invert(1);
  146. filter: invert(1);
  147. }
  148. `: ''}
  149.  
  150. `))
  151. document.head.appendChild(style)
  152.  
  153. window.addEventListener('DOMContentLoaded', () => {
  154. const mainMenu = document.querySelector('#mainMenu')
  155.  
  156. CanvasRenderingContext2D.prototype._rotate = CanvasRenderingContext2D.prototype.rotate
  157.  
  158. const discord = document.querySelector('#linksContainer2 [href*="discord"]')
  159. discord.href = '//gf.qytechs.cn/scripts/449133'
  160. discord.innerHTML = 'Rainbow UI'
  161.  
  162. // Always show ping
  163. mainMenu.insertAdjacentElement('beforebegin', document.querySelector('#pingDisplay'))
  164.  
  165. // Extra Resources
  166. ;(function() {
  167. extra()
  168.  
  169. const obs = new MutationObserver(extra)
  170. obs.observe(document.querySelector('#diedText'), {
  171. childList: true,
  172. subtree: true,
  173. })
  174. })()
  175.  
  176. // VIP Servers
  177. ;(function() {
  178. document.querySelector('#altServer').insertAdjacentHTML('afterend', '<div class="menuHeader" style="margin-top:10px">VIP Servers</div><select id="vipServerBrowser"><option selected="" disabled>Select Server</option></select>')
  179.  
  180. const serverBrowserSelector = '#serverBrowser > select'
  181. let serverBrowser = document.querySelector(serverBrowserSelector)
  182. const vipServerBrowser = document.querySelector('#vipServerBrowser')
  183. const obs = new MutationObserver(() => {
  184. if (!serverBrowser) {
  185. serverBrowser = document.querySelector(serverBrowserSelector)
  186. return
  187. }
  188.  
  189. const servers = Array.from(serverBrowser.children).filter(e => e.textContent.includes('[0/'))
  190.  
  191. if(servers.length > 1) {
  192. servers.forEach(e => {
  193. e = e.cloneNode(true)
  194. e.textContent = e.textContent.split(' [')[0]
  195. vipServerBrowser.insertAdjacentElement('beforeend', e)
  196. })
  197.  
  198. vipServerBrowser.addEventListener('click', e => {
  199. const value = e.target.value
  200.  
  201. if(value.includes(':')) {
  202. location.replace(location.origin + '/?server=' + value)
  203. }
  204. })
  205.  
  206. obs.disconnect()
  207. }
  208. })
  209.  
  210. obs.observe(mainMenu, {
  211. childList: true,
  212. subtree: true,
  213. })
  214. })()
  215.  
  216. // Rainbow Objects
  217.  
  218. if(modConfig.rainbowObjects) {
  219. let deg = 0
  220. let i = 0
  221.  
  222. CanvasRenderingContext2D.prototype.rotate = function(e) {
  223. this._rotate(e)
  224. this.filter = `hue-rotate(${deg}deg)`
  225.  
  226. if (i === 1) {
  227. deg++
  228. }
  229.  
  230. i++
  231.  
  232. deg %= 360
  233. i %= 2
  234. }
  235. }
  236. })
  237.  
  238.  
  239.  
  240.  
  241.  
  242.  
  243.  
  244.  
  245.  
  246.  
  247.  
  248.  
  249.  
  250.  
  251.  
  252.  
  253.  
  254.  
  255.  
  256.  

QingJ © 2025

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