i30cps' Utility Mod

ESC = Mod Menu, P = WS Sender, L = Console Command. Features: Increases FPS, Blocks Ads, Biome Map, CPS Viewer (by CyRuler#3691), and more! This is a utility mod, not a hack. Made by i30cps.

目前为 2021-04-18 提交的版本。查看 最新版本

  1. // ==UserScript==
  2. // @name i30cps' Utility Mod
  3. // @author i30cps
  4. // @version 1.4.4 - P = WS Sender, Toggle Aim Cursor!
  5. // @description ESC = Mod Menu, P = WS Sender, L = Console Command. Features: Increases FPS, Blocks Ads, Biome Map, CPS Viewer (by CyRuler#3691), and more! This is a utility mod, not a hack. Made by i30cps.
  6. // @match *://moomoo.io/*
  7. // @match *://sandbox.moomoo.io/*
  8. // @match *://dev.moomoo.io/*
  9. // @match *://abc.moomoo.io/*
  10. // @icon 
  11. // @require https://gf.qytechs.cn/scripts/423602-msgpack/code/msgpack.js?version=912797
  12. // @require http://code.jquery.com/jquery-3.3.1.min.js
  13. // @require https://code.jquery.com/ui/1.12.0/jquery-ui.min.js
  14. // @require https://cdnjs.cloudflare.com/ajax/libs/jquery-confirm/3.3.0/jquery-confirm.min.js
  15. // @namespace -
  16. // ==/UserScript==
  17.  
  18. //Start edit
  19.  
  20. console.log("The mod is working.");
  21. alert("Note: i30cps' Utility Mod does not give any unfair advantages, and is therefore not a hack. Press ESC for the menu.");
  22.  
  23. $("#gameCanvas").css('cursor', 'url(http://cur.cursors-4u.net/user/use-1/use153.cur), default');
  24. $("#enterGame").css('cursor', 'url(http://cur.cursors-4u.net/user/use-1/use153.cur), default');
  25. document.getElementById("storeHolder").style = "height: 800px; width: 400px;"
  26. document.getElementById('loadingText').innerHTML = 'Wait...';
  27. document.getElementById('gameName').innerHTML = 'i30cps';
  28. document.getElementById("leaderboard").append('i30cps\' Utility Mod');;
  29. document.getElementById('errorNotification').remove();
  30. //more fps:
  31. window.location.native_resolution = true;
  32. $("#consentBlock").css({display: "none"});
  33. $("#youtuberOf").css({display: "none"});
  34. $("#mapDisplay").css({background: `url('https://i.imgur.com/fgFsQJp.png')`});
  35. document.getElementById("moomooio_728x90_home").style.display = "none";
  36. $("#moomooio_728x90_home").parent().css({display: "none"});
  37. document.getElementById("linksContainer2").innerHTML = `<a href="https://www.youtube.com/" target="_blank" class="menuLink">YouTube</a> | <a href="https://discord.com/channels/@me" target="_blank" class="menuLink"> Discord </a> | <a href="https://youtube.com/watch?v=dQw4w9WgXcQ" target="_blank" class="menuLink"> Little Bots </a> `
  38. //Edit end
  39. try {
  40. document.getElementById("moomooio_728x90_home").style.display = "none"; //Remove sidney's ads
  41. $("#moomooio_728x90_home").parent().css({display: "none"});
  42. } catch (e) {
  43. console.log("error removing ad");
  44. }
  45.  
  46.  
  47. let mouseX;
  48. let mouseY;
  49.  
  50. let width;
  51. let height;
  52.  
  53. var animateyorn = false;
  54.  
  55. setInterval(() => {
  56.  
  57. if(messageToggle == 1) {
  58. doNewSend(["ch", [animate(true, animateyorn)]])
  59. }
  60. }, 200);
  61.  
  62. setInterval(() => {
  63. SPIKE=document.getElementById("spikechanger").value.toLowerCase();
  64. MILL=document.getElementById("millchanger").value.toLowerCase();
  65. BOOST=document.getElementById("boostchanger").value.toLowerCase();
  66. TURRET=document.getElementById("turretchanger").value.toLowerCase();
  67. }, 500)
  68.  
  69. setInterval(() => {
  70. if(autoaim == true) {
  71. doNewSend(["2", [nearestEnemyAngle]]);
  72. }
  73. }, 0);
  74.  
  75. setInterval(() => {
  76. if(false) {
  77. if(oldHat != normalHat) {
  78. hat(normalHat);
  79. console.log("Tried. - Hat")
  80. }
  81. if(oldAcc != normalAcc) {
  82. acc(normalAcc);
  83. console.log("Tried. - Accessory")
  84. }
  85. oldHat = normalHat;
  86. oldAcc = normalAcc
  87. }
  88. }, 25);
  89.  
  90. function normal() {
  91. hat(normalHat);
  92. acc(normalAcc);
  93. }
  94.  
  95. function aim(x, y){
  96. var cvs = document.getElementById("gameCanvas");
  97. cvs.dispatchEvent(new MouseEvent("mousemove", {
  98. clientX: x,
  99. clientY: y
  100.  
  101. }));
  102. }
  103.  
  104. let coreURL = new URL(window.location.href);
  105. window.sessionStorage.force = coreURL.searchParams.get("fc");
  106.  
  107. var nearestEnemy;
  108. var nearestEnemyAngle;
  109. var isEnemyNear;
  110. var instaSpeed = 230;
  111. var primary;
  112. var instapike = true;
  113. var instaCHAT = true;
  114. var secondary;
  115. var MooJaxAntiAds = true;
  116. var foodType;
  117. var wallType;
  118. var spikeType;
  119. var millType;
  120. var mineType;
  121. var boostType;
  122. var fdng = true;
  123. var turretType;
  124. var spawnpadType = 36;
  125. var autoaim = false;
  126. var tick = 1;
  127. var oldHat;
  128. var oldAcc;
  129. var enemiesNear;
  130. var normalHat;
  131. var normalAcc;
  132. var ws;
  133. var searchp = true;
  134. var msgpack5 = msgpack;
  135. var boostDir;
  136. var boostDir1;
  137. let myPlayer = {
  138. id: null,
  139. x: null,
  140. y: null,
  141. dir: null,
  142. object: null,
  143. weapon: null,
  144. clan: null,
  145. isLeader: null,
  146. hat: null,
  147. accessory: null,
  148. isSkull: null
  149. };
  150.  
  151. let healSpeed = 100;
  152. var messageToggle = 0;
  153. var clanToggle = 0;
  154. let healToggle = 0;
  155. let hatToggle = 1;
  156.  
  157. var PRIMARY;
  158. var SECONDARY;
  159. var HEAL;
  160. var WALL;
  161. var SPIKE = "v";
  162. var BOOST = "f";
  163. var MILL = "z";
  164. var TURRET = "g";
  165. var MINE;
  166. var SPAWNPAD;
  167.  
  168. var nocommand = ["ach1", "spikechanger", "millchanger", "boostchanger", "turretchanger", "chatbox", "allianceinput"]
  169.  
  170. document.msgpack = msgpack;
  171. function n(){
  172. this.buffer = new Uint8Array([0]);
  173. this.buffer.__proto__ = new Uint8Array;
  174. this.type = 0;
  175. }
  176.  
  177. WebSocket.prototype.oldSend = WebSocket.prototype.send;
  178. WebSocket.prototype.send = function(m){
  179. if (!ws){
  180. document.ws = this;
  181.  
  182. ws = this;
  183. socketFound(this);
  184. }
  185. this.oldSend(m);
  186. };
  187.  
  188.  
  189. function socketFound(socket){
  190. socket.addEventListener('message', function(message){
  191. handleMessage(message);
  192. });
  193. }
  194.  
  195. function handleMessage(m){
  196. let temp = msgpack5.decode(new Uint8Array(m.data));
  197. let data;
  198. if(temp.length > 1) {
  199. data = [temp[0], ...temp[1]];
  200. if (data[1] instanceof Array){
  201. data = data;
  202. }
  203. } else {
  204. data = temp;
  205. }
  206. let item = data[0];
  207. if(!data) {return};
  208.  
  209. if(item === "io-init") {
  210. let cvs = document.getElementById("gameCanvas");
  211. width = cvs.clientWidth;
  212. height = cvs.clientHeight;
  213. $(window).resize(function() {
  214. width = cvs.clientWidth;
  215. height = cvs.clientHeight;
  216. });
  217. cvs.addEventListener("mousemove", e => {
  218. mouseX = e.clientX;
  219. mouseY = e.clientY;
  220. });
  221. }
  222.  
  223. if (item == "1" && myPlayer.id == null){
  224. myPlayer.id = data[1];
  225. }
  226.  
  227. if (item == "33") {
  228. enemiesNear = [];
  229. for(let i = 0; i < data[1].length / 13; i++) {
  230. let playerInfo = data[1].slice(13*i, 13*i+13);
  231. if(playerInfo[0] == myPlayer.id) {
  232. myPlayer.x = playerInfo[1];
  233. myPlayer.y = playerInfo[2];
  234. myPlayer.dir = playerInfo[3];
  235. myPlayer.object = playerInfo[4];
  236. myPlayer.weapon = playerInfo[5];
  237. myPlayer.clan = playerInfo[7];
  238. myPlayer.isLeader = playerInfo[8];
  239. myPlayer.hat = playerInfo[9];
  240. myPlayer.accessory = playerInfo[10];
  241. myPlayer.isSkull = playerInfo[11];
  242. } else if(playerInfo[7] != myPlayer.clan || playerInfo[7] === null) {
  243. enemiesNear.push(playerInfo);
  244. }
  245. }
  246. }
  247.  
  248. isEnemyNear = false;
  249. if(enemiesNear) {
  250. nearestEnemy = enemiesNear.sort((a,b) => dist(a, myPlayer) - dist(b, myPlayer))[0];
  251. }
  252. if(nearestEnemy) {
  253. nearestEnemyAngle = Math.atan2(nearestEnemy[2]-myPlayer.y, nearestEnemy[1]-myPlayer.x);
  254. if(Math.sqrt(Math.pow((myPlayer.y-nearestEnemy[2]), 2) + Math.pow((myPlayer.x-nearestEnemy[1]), 2)) < 300) {
  255. isEnemyNear = true;
  256. console.log("Enemy near.");
  257. if(autoaim == false && myPlayer.hat != 7 && myPlayer.hat != 53) {
  258. normalHat = 6;
  259. if(primary != 8) {
  260. normalAcc = 21;
  261. }
  262. };
  263. }
  264. }
  265. if(isEnemyNear == false && autoaim == false) {
  266. normalAcc = 11;
  267. if (myPlayer.y < 2400){
  268. normalHat = 15;
  269. } else if (myPlayer.y > 6850 && myPlayer.y < 7550){
  270. normalHat = 31;
  271. } else {
  272. normalHat = 12;
  273. }
  274. }
  275. if (!nearestEnemy) {
  276. nearestEnemyAngle = myPlayer.dir;
  277. }
  278. if(item == "h" && data[1] == myPlayer.id) {
  279. if(data[2] < 100 && data[2] > 0 && healToggle == 1) {}
  280. }
  281. update();
  282. }
  283.  
  284.  
  285. function doNewSend(sender){
  286. ws.send(new Uint8Array(Array.from(msgpack5.encode(sender))));
  287. }
  288.  
  289. function acc(id) {
  290. doNewSend(["13c", [0, 0, 1]]);
  291. doNewSend(["13c", [0, id, 1]]);
  292. }
  293.  
  294. function hat(id) {
  295. doNewSend(["13c", [0, id, 0]]);
  296. }
  297.  
  298. function placeF(id, angle = Math.atan2(mouseY - height / 2, mouseX - width / 2)) {
  299. doNewSend(["5", [id, null]]);
  300. doNewSend(["c", [1, angle]]);
  301. doNewSend(["c", [0, angle]]);
  302. doNewSend(["5", [id, null]]);
  303. doNewSend(["c", [1, angle]]);
  304. doNewSend(["c", [0, angle]]);
  305. doNewSend(["5", [myPlayer.weapon, true]]);
  306. }
  307.  
  308. function place(id, angle = Math.atan2(mouseY - height / 2, mouseX - width / 2)) {
  309. doNewSend(["5", [id, null]]);
  310. doNewSend(["c", [1, angle]]);
  311. doNewSend(["c", [0, angle]]);
  312. doNewSend(["5", [myPlayer.weapon, true]]);
  313. }
  314.  
  315. function slot(id) {
  316. doNewSend(["5", [id, null]])
  317. }
  318. var repeater = function(key, action, interval) {
  319. let _isKeyDown = false;
  320. let _intervalId = undefined;
  321.  
  322. return {
  323. start(keycode) {
  324. if(keycode == key && document.activeElement.id.toLowerCase() !== 'chatbox') {
  325. _isKeyDown = true;
  326. if(_intervalId === undefined) {
  327. _intervalId = setInterval(() => {
  328. action();
  329. if(!_isKeyDown){
  330. clearInterval(_intervalId);
  331. _intervalId = undefined;
  332. console.log("claered");
  333. }
  334. }, interval);
  335. }
  336. }
  337. },
  338.  
  339. stop(keycode) {
  340. if(keycode == key && document.activeElement.id.toLowerCase() !== 'chatbox') {
  341. _isKeyDown = false;
  342. }
  343. }
  344. };
  345.  
  346.  
  347. }
  348.  
  349. function katana() {
  350. doNewSend([6, [4]])
  351. }
  352.  
  353. document.addEventListener('keydown', (e)=>{
  354. if (e.keyCode == 46 && !nocommand.includes(document.activeElement.id.toLowerCase())) {
  355. const EDITION = 0;
  356.  
  357. var head = document.getElementsByTagName('head')[0];
  358. var icon = document.createElement('link');
  359.  
  360. icon.setAttribute('type', 'image/png');
  361. icon.setAttribute('rel', 'shortcut icon');
  362.  
  363. if (EDITION == 0) icon.setAttribute('href', '');
  364. if (EDITION == 1) icon.setAttribute('href', '');
  365.  
  366. head.appendChild(icon);
  367. }
  368. if(e.keyCode == 38 && !nocommand.includes(document.activeElement.id.toLowerCase())) {
  369. messageToggle = (messageToggle + 1) % 2;
  370. }
  371. if(e.key == "\\" && !nocommand.includes(document.activeElement.id.toLowerCase())) {
  372. doNewSend(["6", [4]]);
  373. }
  374. if(e.keyCode == 189 && !nocommand.includes(document.activeElement.id.toLowerCase())) {
  375. doNewSend(["6", [28]]);
  376. /*setTimeout(() => {
  377. doNewSend(["6", [25]]);
  378. }, 100);*/
  379. }
  380. if(e.key == BOOST && !nocommand.includes(document.activeElement.id.toLowerCase())) {
  381. slot(boostType);
  382. }
  383. if(e.key == MILL && !nocommand.includes(document.activeElement.id.toLowerCase())) {
  384. slot(millType);
  385. }
  386. if(e.key == SPIKE && !nocommand.includes(document.activeElement.id.toLowerCase())) {
  387. slot(spikeType)
  388. }
  389. if(e.key == TURRET && !nocommand.includes(document.activeElement.id.toLowerCase())) {
  390. doNewSend(["5", [turretType, null]])
  391. }
  392. if(e.keyCode == 80 && !nocommand.includes(document.activeElement.toLowerCase())) {
  393. let sendPrompt = prompt("Send:").split(", ");
  394. if (sendPrompt.length == 2) {
  395. eval("doNewSend(["+sendPrompt[0]+", ["+sendPrompt[1]+"]])");
  396. } else if (sendPrompt.length == 3) {
  397. eval("doNewSend(["+sendPrompt[0]+", ["+sendPrompt[1]+", "+sendPrompt[2]+"]])");
  398. } else {
  399. alert("Ws Sender Error. Use a, b, c option format. Do not use brackets ( (), [], {} ).")
  400. }
  401. }
  402. if(e.keyCode == 76 && !nocommand.includes(document.activeElement.id.toLowerCase())) {
  403. let evals = prompt("Console Command: Available Commands: katana(), place(spikeType:millType:boostType:turretType, optionalangle):")
  404. eval(evals);
  405. }
  406. })
  407.  
  408.  
  409. function isElementVisible(e) {
  410. return (e.offsetParent !== null);
  411. }
  412.  
  413.  
  414. function toRad(angle) {
  415. return angle * 0.01745329251;
  416. }
  417.  
  418. function dist(a, b){
  419. return Math.sqrt( Math.pow((b.y-a[2]), 2) + Math.pow((b.x-a[1]), 2) );
  420. }
  421.  
  422.  
  423. document.title = "Utility Mod by i30cps"
  424.  
  425. function update() {
  426. for (let i=0;i<9;i++){
  427. if (isElementVisible(document.getElementById("actionBarItem" + i.toString()))){
  428. primary = i;
  429. }
  430. }
  431.  
  432. for (let i=9;i<16;i++){
  433. if (isElementVisible(document.getElementById("actionBarItem" + i.toString()))){
  434. secondary = i;
  435. }
  436. }
  437.  
  438. for (let i=16;i<19;i++){
  439. if (isElementVisible(document.getElementById("actionBarItem" + i.toString()))){
  440. foodType = i - 16;
  441. }
  442. }
  443.  
  444. for (let i=19;i<22;i++){
  445. if (isElementVisible(document.getElementById("actionBarItem" + i.toString()))){
  446. wallType = i - 16;
  447. }
  448. }
  449.  
  450. for (let i=22;i<26;i++){
  451. if (isElementVisible(document.getElementById("actionBarItem" + i.toString()))){
  452. spikeType = i - 16;
  453. }
  454. }
  455.  
  456. for (let i=26;i<29;i++){
  457. if (isElementVisible(document.getElementById("actionBarItem" + i.toString()))){
  458. millType = i - 16;
  459. }
  460. }
  461.  
  462. for (let i=29;i<31;i++){
  463. if (isElementVisible(document.getElementById("actionBarItem" + i.toString()))){
  464. mineType = i - 16;
  465. }
  466. }
  467.  
  468. for (let i=31;i<33;i++){
  469. if (isElementVisible(document.getElementById("actionBarItem" + i.toString()))){
  470. boostType = i - 16;
  471. }
  472. }
  473.  
  474. for (let i=33;i<39;i++){
  475. if (isElementVisible(document.getElementById("actionBarItem" + i.toString())) && i != 36){
  476. turretType = i - 16;
  477. }
  478. }
  479.  
  480. spawnpadType = 36;
  481. }
  482.  
  483. try {
  484. document.getElementById("moomooio_728x90_home").style.display = "none";
  485. $("moomooio728x90_home").parent().css({display: "none"});
  486. } catch (e) {
  487. console.log("There was an error removing the ads.");
  488. }
  489.  
  490.  
  491. var menuChange = document.createElement("div");
  492. menuChange.className = "menuCard";
  493. menuChange.id = "mainSettings";
  494. menuChange.innerHTML = `
  495. <div id="simpleModal" class="modal">
  496. <div class="modal-content">
  497. <div class="modal-header">
  498. <span class="closeBtn">&times;</span>
  499. <h2 style="font-size: 17px;">Settings</h2>
  500. </div>
  501. <div class="modal-body" style="font-size: 17px;">
  502. <div class="modal-content" style="font-size:14px">
  503. <p>This mod does not give any unfair advantages. ESC = Open Menu, L = Console Command, Up Arrow=Autochat, Dash ('-') = Power Mill</p>
  504. </div>
  505. <div class="flexControl">
  506. <h3 style="font-size: 17px;"> Settings </h3>
  507. <label class="container">Show biomes on the map ?(Snow, Plains, desert)
  508. <input type="checkbox" id="myCheck">
  509. <span class="checkmark"></span>
  510. </label>
  511. <label class="container">Aim Cursor?
  512. <input type="checkbox" id="myCheck3">
  513. <span class="checkmark"></span>
  514. </label>
  515. <label for="spikechanger" class="container">Spike Key:</label>
  516. <input type="text" id="spikechanger" value="v"><label for="millchanger" class="container">Windmill Key:
  517. </label><input type="text" id="millchanger" value="z"><label for="boostchanger" class="container">Boost/Trap Key:</label>
  518. <input type="text" id="boostchanger" value="f"><label for="turretchanger" class="container">Turret/Teleporter/Other Key:</label>
  519. <input type="text" id="turretchanger" value="g">
  520. <h3 style="font-size: 17px;"> Autochat settings </h3>
  521. <label class="container">AutoChat Animation?
  522. <input type="checkbox" id="myCheck2">
  523. <span class="checkmark"></span>
  524. </label>
  525. <br>AutoChat:<input type="text" value="bit.ly/i30cpsmod not unfair" id="ach1" width="100" height="50"/><br>
  526. </div>
  527. </div>
  528. </div>
  529. </div>
  530. `
  531. document.body.appendChild(menuChange)
  532.  
  533.  
  534.  
  535. var styleItem = document.createElement("style");
  536. styleItem.type = "text/css";
  537. styleItem.appendChild(document.createTextNode(`
  538. .keyPressLow {
  539. margin-left: 8px;
  540. font-size: 16px;
  541. margin-right: 8px;
  542. height: 25px;
  543. width: 50px;
  544. background-color: #fcfcfc;
  545. border-radius: 3.5px;
  546. border: none;
  547. text-align: center;
  548. color: #4A4A4A;
  549. border: 0.5px solid #f2f2f2;
  550. }
  551. .menuPrompt {
  552. font-size: 17px;
  553. font-family: 'Hammersmith One';
  554. color: #4A4A4A;
  555. flex: 0.2;
  556. text-align: center;
  557. margin-top: 10px;
  558. display: inline-block;
  559. }
  560.  
  561. .modal {
  562. display: none;
  563. position: fixed;
  564. z-index: 1;
  565. left: 0;
  566. top: 0;
  567. overflow: auto;
  568. height: 100%;
  569. width: 100%;
  570. }
  571.  
  572. .modal-content {
  573. margin: 10% auto;
  574. width: 40%;
  575. box-shadow: 0 5px 8px 0 rgba(0, 0, 0, 0.2), 0 7px 20px 0 rgba(0, 0, 0, 0.17);
  576. font-size: 14px;
  577. line-height: 1.6;
  578. }
  579.  
  580. .modal-header h2,
  581. .modal-footer h3 {
  582. margin: 0;
  583. }
  584.  
  585. .modal-header {
  586. background: #4287f5;
  587. padding: 15px;
  588. color: #fff;
  589. border-top-left-radius: 5px;
  590. border-top-right-radius: 5px;
  591. }
  592.  
  593. .modal-body {
  594. padding: 10px 20px;
  595. background: #fff;
  596. }
  597.  
  598. .modal-footer {
  599. background: #cf2727;
  600. padding: 10px;
  601. color: #fff;
  602. text-align: center;
  603. border-bottom-left-radius: 5px;
  604. border-bottom-right-radius: 5px;
  605. }
  606.  
  607. .closeBtn {
  608. color: #ccc;
  609. float: right;
  610. font-size: 30px;
  611. color: #fff;
  612. }
  613.  
  614. .closeBtn:hover,
  615. .closeBtn:focus {
  616. color: #000;
  617. text-decoration: none;
  618. cursor: pointer;
  619. }
  620.  
  621. /* Customize the label (the container) */
  622. .container {
  623. display: block;
  624. position: relative;
  625. padding-left: 35px;
  626. margin-bottom: 12px;
  627. cursor: pointer;
  628. font-size: 16px;
  629. -webkit-user-select: none;
  630. -moz-user-select: none;
  631. -ms-user-select: none;
  632. user-select: none;
  633. }
  634.  
  635. /* Hide the browser's default checkbox */
  636. .container input {
  637. position: absolute;
  638. opacity: 0;
  639. cursor: pointer;
  640. height: 0;
  641. width: 0;
  642. }
  643.  
  644. /* Create a custom checkbox */
  645. .checkmark {
  646. position: absolute;
  647. top: 0;
  648. left: 0;
  649. height: 25px;
  650. width: 25px;
  651. background-color: #eee;
  652. }
  653.  
  654. /* On mouse-over, add a grey background color */
  655. .container:hover input ~ .checkmark {
  656. background-color: #ccc;
  657. }
  658.  
  659. /* When the checkbox is checked, add a red background */
  660. .container input:checked ~ .checkmark {
  661. background-color: #cf2727;
  662. }
  663.  
  664. /* Create the checkmark/indicator (hidden when not checked) */
  665. .checkmark:after {
  666. content: "";
  667. position: absolute;
  668. display: none;
  669. }
  670.  
  671. /* Show the checkmark when checked */
  672. .container input:checked ~ .checkmark:after {
  673. display: block;
  674. }
  675.  
  676. /* Style the checkmark/indicator */
  677. .container .checkmark:after {
  678. left: 9px;
  679. top: 5px;
  680. width: 5px;
  681. height: 10px;
  682. border: solid white;
  683. border-width: 0 3px 3px 0;
  684. -webkit-transform: rotate(45deg);
  685. -ms-transform: rotate(45deg);
  686. transform: rotate(45deg);
  687. }
  688.  
  689. `))
  690. document.head.appendChild(styleItem);
  691.  
  692.  
  693. $("#adCard").css({display: "none"});
  694.  
  695.  
  696. document.addEventListener('keydown', function(e) {
  697. if (e.keyCode == 27){
  698. if (modal.style.display = "none") {
  699. modal.style.display = "block";
  700. } else {
  701. modal.style.display = "none";
  702. }
  703. }
  704. })
  705.  
  706. // Get modal element
  707. var modal = document.getElementById("simpleModal");
  708. // Get close button
  709. var closeBtn = document.getElementsByClassName('closeBtn')[0];
  710.  
  711. // Events
  712. closeBtn.addEventListener('click', closeModal);
  713. window.addEventListener('click', outsideClick);
  714.  
  715. // Close
  716. function closeModal() {
  717. modal.style.display = 'none';
  718. }
  719.  
  720. // Close If Outside Click
  721. function outsideClick(e) {
  722. if (e.target == modal) {
  723. modal.style.display = 'none';
  724. }
  725. }
  726.  
  727. var checkbox = document.querySelector("#myCheck")
  728.  
  729. checkbox.addEventListener('change', function() {
  730. if (this.checked) {
  731. $("#mapDisplay").css({background: `url('https://i.imgur.com/fgFsQJp.png')`});
  732. console.log('checked')
  733. } else {
  734. $("#mapDisplay").css({background: `rgba(0, 0, 0, 0.25)`})
  735. console.log('unchecked')
  736. }
  737. })
  738. var checkbox2 = document.querySelector("#myCheck2")
  739.  
  740. checkbox2.addEventListener('change', function() {
  741. if (this.checked) {
  742. animateyorn = true;
  743. } else {
  744. animateyorn = false;
  745. }
  746. })
  747. var checkbox3 = document.querySelector("#myCheck3")
  748.  
  749. checkbox3.addEventListener('change', function() {
  750. if (this.checked) {
  751. $("#gameCanvas").css('cursor', 'url(http://cur.cursors-4u.net/user/use-1/use153.cur), default');
  752. } else {
  753. document.getElementById("gameCanvas").style.cursor = 'default';
  754. }
  755. })
  756.  
  757. document.addEventListener('keyup', (e)=>{
  758. if(e.keyCode == 71 && document.activeElement.id.toLowerCase() !== 'chatbox') {
  759. setTimeout( () => {
  760. boostDir = null;
  761. }, 10);
  762. }
  763. })
  764.  
  765. function animate(space, animateyn) {
  766. let result = '';
  767. if (space) {
  768. result = document.getElementById("ach1").value;
  769. } else {
  770. result = "i30cps"
  771. }
  772. if (animateyn) {
  773. let place = Math.floor(Math.random()*result.length);
  774. result = result.substring(0, place) + "_" + result.substring(place+1, result.length);
  775. }
  776. return result;
  777. }
  778.  
  779. unsafeWindow.admob = {
  780. requestInterstitialAd: ()=>{},
  781. showInterstitialAd: ()=>{}
  782. }
  783. function ichat(space, chance) {
  784. var ach1 = document.getElementById("ach2").value;
  785. let result = '';
  786. let characters;
  787. if(space) {
  788. characters = ach1;
  789. }
  790. if(space) {
  791. characters = characters.padStart((30 - characters.length) / 2 + characters.length)
  792. characters = characters.padEnd(30);
  793. }
  794. let count = 0;
  795. for (let i = 0; i < characters.length; i++ ) {
  796. if(Math.floor(Math.random() * chance) == 0 && characters.charAt(i) != "-" && count < 0 && characters.charAt(i) != " ") {
  797. result += "";
  798. count++
  799. } else {
  800. result += characters.charAt(i);
  801. }
  802. }
  803. return result;
  804. }
  805.  
  806.  
  807.  
  808.  
  809. // CPS VIEWER BY CyRuler#3691
  810.  
  811.  
  812.  
  813.  
  814.  
  815. var cps = 0;
  816. var iCliked = 1;
  817. $("#gameCanvas").mousedown(function(e){
  818. if(e.which == 1 && iCliked == 1)
  819. {
  820. cps = (cps + 1)
  821. setTimeout( () => {
  822. cps = (cps - 1)
  823. }, 950);
  824. }
  825. });
  826. $("#gameCanvas").mousedown(function(e){
  827. if(e.which == 3 && iCliked == 1)
  828. {
  829. cps = (cps + 1)
  830. setTimeout( () => {
  831. cps = (cps - 1)
  832. }, 950);
  833. }
  834. });
  835. document.addEventListener("mousedown", buttonPress, false);
  836. function buttonPress(e) {
  837. if(e.button==1 && iCliked == 1)
  838. {
  839. cps = (cps + 1)
  840. setTimeout( () => {
  841. cps = (cps - 1)
  842. }, 950);
  843. }
  844. }
  845.  
  846. document.addEventListener('keydown', function (e) {
  847. if(e.keyCode == 16){
  848. SendKeys.Send("{F3}");
  849. }
  850. });
  851. var CpsMenu = document.createElement("div");
  852. CpsMenu.style.padding = "5px";
  853. CpsMenu.id = "CpsDiv";
  854. CpsMenu.style.font = "30px Arial";
  855. CpsMenu.style.display = "block";
  856. CpsMenu.style.position = "fixed";
  857. CpsMenu.style.top = "3%";
  858. CpsMenu.style.left = "0%";
  859. CpsMenu.textContent = "Loading";
  860. document.body.appendChild(CpsMenu);
  861. setInterval(()=>{
  862. CpsMenu.textContent = "Cps:"+cps;
  863. }, 0);

QingJ © 2025

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