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() !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或关注我们的公众号极客氢云获取最新地址