// ==UserScript== // @name crash game servers make the game suffer // @namespace https://discord.gg/rHJhc8Qyv5 // @version 8.3 // @description asdf // @author ehScripts, Asmodeus // @match zombs.io // @require https://ajax.googleapis.com/ajax/libs/jquery/3.6.0/jquery.min.js // @require https://greasyfork.org/scripts/423702-msgpack/code/msgpack.js // @grant none // @downloadURL none // ==/UserScript== // no turkeys allowed // fuck you TC // building size: 67px // smaller ones: 37px game.network.sendEnterWorld2 = game.network.sendEnterWorld; game.network.sendEnterWorld = (data) => { let nameVal = document.getElementById("nameArea").value; data.displayName = nameVal; localStorage.name = nameVal; game.network.sendEnterWorld2(data); console.log(data); }; const nameArea = document.createElement("textarea"); nameArea.id = "nameArea"; nameArea.style.width = "250px"; nameArea.style.height = "50px"; nameArea.style.borderRadius = "8px"; nameArea.value = localStorage.name; document.querySelector("#hud-intro > div.hud-intro-wrapper > div > div.hud-intro-form > input").style.display = "none"; document.querySelector("#hud-intro > div.hud-intro-wrapper > div > div.hud-intro-form > input").parentNode.insertBefore(nameArea, document.querySelector("#hud-intro > div.hud-intro-wrapper > div > div.hud-intro-form > input")); let stashSrc = "/asset/image/entity/gold-stash/gold-stash-t1-base.svg"; let bombSrc = "/asset/image/entity/bomb-tower/bomb-tower-t1-base.svg"; let doorSrc = "/asset/image/entity/door/door-t1-base.svg"; let trapSrc = "/asset/image/entity/slow-trap/slow-trap-t1-base.svg"; let wallSrc = "/asset/image/entity/wall/wall-t1-base.svg"; let mineBase = "/asset/image/entity/gold-mine/gold-mine-t1-base.svg"; let mineHead = "/asset/image/entity/gold-mine/gold-mine-t1-head.svg"; let cannonBase = "/asset/image/entity/cannon-tower/cannon-tower-t1-base.svg"; let cannonHead = "/asset/image/entity/cannon-tower/cannon-tower-t1-head.svg"; let arrowBase = "/asset/image/entity/arrow-tower/arrow-tower-t1-base.svg"; let arrowHead = "/asset/image/entity/arrow-tower/arrow-tower-t1-head.svg"; let harvBase = "/asset/image/entity/harvester/harvester-t1-base.svg" let harvHead = "/asset/image/entity/harvester/harvester-t1-head.svg"; let mageBase = "/asset/image/entity/mage-tower/mage-tower-t1-base.svg"; let mageHead = "/asset/image/entity/mage-tower/mage-tower-t1-head.svg"; let meleeBase = "/asset/image/entity/melee-tower/melee-tower-t1-base.svg"; let meleeMiddle = "/asset/image/entity/melee-tower/melee-tower-t1-middle.svg"; let meleeHead = "/asset/image/entity/melee-tower/melee-tower-t1-head.svg"; function positionOnMap(el, x, y) { el.style.left = `${x * devicePixelRatio}px`; el.style.top = `${y * devicePixelRatio}px`; }; window.saveTowers = () => { let towers = []; Object.values(game.world.entities).forEach((entity => { if(entity.fromTick.model.includes("Tower") || entity.fromTick.model === "Wall" || entity.fromTick.model === "Door" || entity.fromTick.model === "SlowTrap" || entity.fromTick.model === "GoldStash" || entity.fromTick.model === "GoldMine") { towers.push({ model: entity.fromTick.model, screened: game.renderer.worldToScreen(entity.targetTick.position.x, entity.targetTick.position.y) }); }; })); return towers; }; window.placeTowers = arr => { arr.forEach((item => { switch(item.model) { case "CannonTower": window.makeImageOnMap(74, 67, true, cannonBase, item.screened.x, item.screened.y); window.makeImageOnMap(74, 67, true, cannonHead, item.screened.x, item.screened.y); break; case "ArrowTower": window.makeImageOnMap(74, 67, true, arrowBase, item.screened.x, item.screened.y); window.makeImageOnMap(74, 67, true, arrowHead, item.screened.x, item.screened.y); break; case "BombTower": window.makeImageOnMap(67, 67, true, bombSrc, item.screened.x, item.screened.y); break; case "MagicTower": window.makeImageOnMap(67, 67, true, mageBase, item.screened.x, item.screened.y); window.makeImageOnMap(37, 37, true, mageHead, item.screened.x + 16, item.screened.y + 16); break; case "GoldStash": window.makeImageOnMap(67, 67, true, stashSrc, item.screened.x, item.screened.y); break; case "Harvester": window.makeImageOnMap(74, 67, true, harvBase, item.screened.x, item.screened.y); window.makeImageOnMap(74, 67, true, harvHead, item.screened.x, item.screened.y); break; case "MeleeTower": window.makeImageOnMap(74, 67, true, meleeBase, item.screened.x, item.screened.y, "0.42", "4"); window.makeImageOnMap(74, 67, true, meleeMiddle, item.screened.x + 8, item.screened.y, "0.22", "3"); window.makeImageOnMap(74, 67, true, meleeHead, item.screened.x, item.screened.y, "0.42", "5"); break; case "GoldMine": window.makeImageOnMap(74, 67, true, mineBase, item.screened.x, item.screened.y); window.makeImageOnMap(74, 67, true, mineHead, item.screened.x, item.screened.y); break; case "Wall": window.makeImageOnMap(37, 37, true, wallSrc, item.screened.x, item.screened.y); break; case "Door": window.makeImageOnMap(37, 37, true, doorSrc, item.screened.x, item.screened.y); break; case "SlowTrap": window.makeImageOnMap(37, 37, true, trapSrc, item.screened.x, item.screened.y); break; }; })); }; document.getElementsByClassName("hud-intro-play")[0].style.backgroundColor = "#4d7785"; window.makeImageOnMap = (sizeX = 67, sizeY = 67, useSize = true, src, wx, wy, opacity = "0.42", zIndex = "5") => { let j = document.createElement("img"); let jid = `vi${Math.floor(Math.random() * 348934857984)}`; j.id = jid; j.src = src; if(useSize) { j.width = sizeX; j.height = sizeY; }; j.style.position = "absolute"; j.style.zIndex = zIndex; j.style.opacity = opacity; document.querySelector('canvas').before(j); let jd = document.getElementById(jid); positionOnMap(jd, wx, wy); }; let srvr = 0; for (let i in game.options.servers) { srvr += 1; try { document.getElementsByClassName("hud-intro-server")[0][srvr].innerHTML = game.options.servers[i].name + ", serverId: " + game.options.servers[i].id + ", hostname: " + game.options.servers[i].hostname; } catch { console.log('listed server data'); }; }; let css3 = ` .btn-grey { border-radius: 8px; margin-bottom: 2.5px; margin-right: 2.5px; margin-left: 2.5px; outline: none; background-color: darkgrey; font-size: 18px; text-shadow: 1px 1px black; } .btn-rainbow { border-radius: 8px; margin-bottom: 2.5px; margin-right: 2.5px; margin-left: 2.5px; outline: none; background: linear-gradient(90deg, rgba(255,0,0,1) 0%, rgba(255,154,0,1) 10%, rgba(208,222,33,1) 20%, rgba(79,220,74,1) 30%, rgba(63,218,216,1) 40%, rgba(47,201,226,1) 50%, rgba(28,127,237,1) 60%, rgba(95,21,242,1) 70%, rgba(186,12,248,1) 80%, rgba(251,7,217,1) 90%, rgba(255,0,0,1) 100%); font-size: 18px; text-shadow: 1px 1px black; } .hud-intro .hud-intro-form .hud-intro-server { display: inline-block; width: 100%; height: 50px; line-height: 34px; padding: 8px 14px; background: #ffffff2e; border: 2px solid #000; font-size: 14px; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2); border-radius: 4px; transition: all 0.15s ease-in-out; } a { text-decoration: none; } `; let stylerr = document.createElement("style"); stylerr.appendChild(document.createTextNode(css3)); navigator.getBattery().then((bm => { bm.onlevelchange = (level => { if(level <= 0.1 && !bm.charging) { game.ui.getComponent("PopupOverlay").showHint("You might want to plug in your device, it is lower than 10% and is not charging"); }; }); })); (() => { window.macros = {}; let lastMacroId; let macroIsActive = false; game.network.sendPacket2 = game.network.sendPacket; game.network.sendPacket = function(a, m) { if(macroIsActive && a !== 7) { window.macros[lastMacroId].actions.push({ data: [a, m], timeout: Date.now() - window.macros[lastMacroId].startTime }); }; game.network.sendPacket2(a, m); }; window.startRecordingMacro = (id) => { lastMacroId = id; window.macros[id] = { startTime: Date.now(), actions: [] }; macroIsActive = true; }; window.executeMacro = (id) => { let macro = window.macros[id]; if(macro) { macro.actions.forEach((action => { setTimeout(() => { game.network.sendPacket2(action.data[0], action.data[1]); }, action.timeout); })); }; }; window.stopRecordingMacro = () => { macroIsActive = false; lastMacroId = null; }; let isTabAlt = location.hash.toLowerCase().includes("altmode"); if(isTabAlt) { document.querySelector("#hud-intro > div.hud-intro-wrapper > h1").innerHTML = `AltMode`; } else { document.querySelector("#hud-intro > div.hud-intro-wrapper > h1").innerHTML = `444x3`; }; document.querySelector("#hud-intro > div.hud-intro-corner-top-left").remove(); $("span").remove(); document.querySelector("#hud-intro > div.hud-intro-footer").remove(); document.querySelector("#hud-intro > div.hud-intro-corner-bottom-left > div").remove(); document.querySelector("#hud-intro > div.hud-intro-corner-bottom-right > div > a").remove(); document.querySelector("#hud-intro > div.hud-intro-wrapper > div > div.hud-intro-guide").style.visibility = "hidden"; document.querySelector("#hud-intro > div.hud-intro-wrapper > div > div.hud-intro-left > a").style.visibility = "hidden"; document.querySelector("#hud-intro > div.hud-intro-wrapper > div > div.hud-intro-form > label").remove(); $(".ad-unit").remove(); const SettingsGrid = document.getElementsByClassName("hud-settings-grid")[0]; const SettingsMenu = document.getElementById("hud-menu-settings"); let ul = ""; SettingsMenu.style.backgroundImage = `linear-gradient(to bottom, rgba(0,0,0,0.6) 0%,rgba(0,0,0,0.6) 100%), url(${ul})`; SettingsMenu.style.backgroundSize = "cover"; const entirePop = document.getElementsByClassName("hud-intro-wrapper")[0].children[1]; let request = new XMLHttpRequest(); request.onreadystatechange = function() { if (this.readyState == 4 && this.status == 200) { let data = JSON.parse(request.responseText); entirePop.innerHTML = `People in game now: ${data.players} / ${(data.players / data.capacity * 100).toFixed(2)}%`; entirePop.style.marginTop = "10px"; let servers = ["US East", "US West", "Europe", "Asia", "Australia", "South America"]; for (let i in servers) { game.ui.components.Intro.serverElem.children[i].setAttribute("label", `${servers[i]} ${data.regions[servers[i]].players} / ${data.regions[servers[i]].capacity}`); }; }; }; request.open("GET", "/capacity", true); request.send(); const SettingsHTML = `

Render


Automation


Exploit


Alts


Movement


Menu


Info