您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Starve.io Auto Atack Aimbot Auto Crafting extended UI
当前为
// ==UserScript== // @name Starve.io // @namespace http://tampermonkey.net/ // @version 0.1.4 // @description Starve.io Auto Atack Aimbot Auto Crafting extended UI // @author You // @match https://starve.io/* // @grant none // ==/UserScript== (function() { //polyfills window.console._log=window.console.log; function Event(e,t){this.script=e,this.target=t,this._cancel=!1,this._replace=null,this._stop=!1}Event.prototype.preventDefault=function(){this._cancel=!0},Event.prototype.stopPropagation=function(){this._stop=!0},Event.prototype.replacePayload=function(e){this._replace=e};var callbacks=[],addBeforeScriptExecuteListener=function(e){if(!e instanceof Function)throw new Error("Event handler must be a function.");callbacks.push(e)},removeBeforeScriptExecuteListener=function(e){for(var t=callbacks.length;t--;)callbacks[t]===e&&callbacks.splice(t,1)},addev=window.addEventListener.bind(window),rmev=window.removeEventListener.bind(window);window.addEventListener=function(){"beforescriptexecute"===arguments[0].toLowerCase()?addBeforeScriptExecuteListener(arguments[1]):addev.apply(null,arguments)},window.removeEventListener=function(){"beforescriptexecute"===arguments[0].toLowerCase()?removeBeforeScriptExecuteListener(arguments[1]):rmev.apply(null,arguments)};var dispatch=function(e,t){var r=new Event(e,t);if(window.onbeforescriptexecute instanceof Function)try{window.onbeforescriptexecute(r)}catch(e){console.error(e)}for(var n=0;n<callbacks.length&&!r._stop;n++)try{callbacks[n](r)}catch(e){console.error(e)}return r},observer=new MutationObserver(e=>{for(var t=0;t<e.length;t++)for(var r=0;r<e[t].addedNodes.length;r++){var n=e[t].addedNodes[r];if("SCRIPT"===n.tagName){var o=dispatch(n,e[t].target);o._cancel?n.remove():"string"==typeof o._replace&&(n.textContent=o._replace)}}});observer.observe(document,{childList:!0,subtree:!0}); //polyfills //options let craftImg,craftItems,craftHelperE; let enemyMap= new Map(); let imgMap=new Map(); // window.allyMap= new Map(); let myPlayerId; let myPlayer; let aimbot=true; let options={ gameFuncName:"wi", circleTimerFuncName:"fh", showLastPlayerUI:true, timeoutLastPlayerUI:undefined }; let craftHelper=[{"imgSrc":"https://starve.io/img/inv-bag-out.png","items":[{"imgSrc":"","number":"6"},{"imgSrc":"","number":"5"}]}],craftHelperID; let ws; let circleTime; const lastplayers=["Player1","Player2","Player3","Player4","Player5",]; let commands={lastCraftCommand:{keyCode:"KeyE",wsSend:"[7,49]"}, meatCraft:{keyCode:"KeyZ",wsSend:"[7,49]"}, bandageCraft:{keyCode:"KeyX",wsSend:"[7,54]"}, fillBottle:{keyCode:"KeyC",wsSend:"[7,111]"}, autoClick:{keyCode:"KeyQ",active:false,wsSend:"0"} } let oldfunc={}; let newfunc={}; //options //functions function run(){ history.pushState('id', 'id', '/?id=1'); } const dist2d = (p1, p2) => { return Math.sqrt((p1.x-p2.x)**2 + (p1.y-p2.y)**2); } const calcAngle = (p1, p2) => { var dy = p2.y - p1.y; var dx = p2.x - p1.x; var theta = Math.atan2(dy, dx); theta *= 180 / Math.PI; return theta; } const angle360 = (p1,p2) => { var theta = calcAngle(p1,p2); if (theta < 0) theta = 360 + theta; return theta; } function findEnemyAngle(angle){ let minDist=99999,enemy; enemyMap.forEach((value, key, map)=>{ if(value.lastUpdateTime+5000>Date.now()){ let dist=dist2d(myPlayer,value); if( dist < 290 && dist<minDist){ minDist=dist; enemy=value; setTimeout(()=>{aimbot && ws.send(`[3,${findEnemyAngle(angle)}`);},1000/60) } } }); return enemy ? Math.floor(angle360(myPlayer,enemy)*64/90): angle; } function viewCraftHelper(craftHelperID){ if(craftHelper.length>0 && craftHelperID<craftHelper.length){ craftImg.innerHTML=""; craftItems.innerHTML=""; craftImg.insertAdjacentHTML('beforeend',`<img class="img_recipe" id="img_1" src=${craftHelper[craftHelperID].imgSrc} style="display: inline-block;">`); craftHelper[craftHelperID].items.forEach((item)=>{ craftItems.insertAdjacentHTML('beforeend',`<div><img class="inv" id="inv1" src="${item.imgSrc}" style="display: inline-block; vertical-align: middle;"><span>${item.number}</span></div>`); }); } } function prev(){ craftHelperID--; if(craftHelperID<0){ craftHelperID=craftHelper.length-1; } craftHelper.length>1 && viewCraftHelper(craftHelperID); } function next(){ craftHelperID++; if(craftHelperID>=craftHelper.length){ craftHelperID=0; } craftHelper.length>1 && viewCraftHelper(craftHelperID); } function remove(){ if(craftHelper.length>1){ craftHelper.splice(craftHelperID,1); prev(); }else if(craftHelper.length==1){viewCraftHelper(0);} } //functions //hooks /* //If there is an update, bring the new function name. oldfunc['String.indexOf']=String.prototype.indexOf; String.prototype.indexOf=newfunc['String.indexOf']=new Proxy(String.prototype.indexOf,{ apply:function(target, thisArg, argArray){ if(argArray[0]=="http://starve.io/beta"){ console.log(arguments.callee.caller.name) String.prototype.indexOf=oldfunc['String.indexOf']; } return target.apply(thisArg, argArray); }}); */ oldfunc.webSocket=window.WebSocket; window.WebSocket=newfunc.webSocket=new Proxy(window.WebSocket,{ construct:function(target,args){ ws = new target(...args); setTimeout(()=>{var event = document.createEvent('Event'); event.data=[22,0]; event.initEvent('message', true, true); ws.dispatchEvent(event);},2000); const messageHandler = (e) => { if ("string" === typeof e.data){ e = JSON.parse(e.data); switch (e[0]) { case 2: lastplayers.unshift(e[2]+" | "+e[1]) && lastplayers.length>5 && lastplayers.pop(); options.showLastPlayerUI=true; options.timeoutLastPlayerUI && clearTimeout(options.timeoutLastPlayerUI); options.timeoutLastPlayerUI=setTimeout(()=>{options.showLastPlayerUI=false;},5000); break; case 3: myPlayerId=e[9]; break; } }else{ var d = new Uint8Array(e.data); switch (d[0]) { case 16: circleTime=Date.now(); break; case 22: if(d[1]==1 &&!(e.data instanceof Array)){ setTimeout(()=>{var event = document.createEvent('Event'); event.data=[22,0]; event.initEvent('message', true, true); ws.dispatchEvent(event);},2000); } break; } } }; const closeHandler = (event) => { console.log('Close', event); aimbot=false; enemyMap.clear(); ws.removeEventListener('message', messageHandler); ws.removeEventListener('close', closeHandler); ws.send= oldfunc['ws.send']; }; ws.addEventListener('message', messageHandler); ws.addEventListener('close', closeHandler); oldfunc['ws.send']=ws.send; newfunc['ws.send']= ws.send= new Proxy(ws.send, { apply: function(target, _this, _arguments) { if(typeof _arguments[0]==='string' ){ let arr try{ arr =JSON.parse(_arguments[0]); }catch(err){} if(arr){ if(arr[0]===3 || arr[0]===4){ if(aimbot){ arr[1]=findEnemyAngle(arr[1]); _arguments[0]=JSON.stringify(arr); } } if(arr[0]===7){ target.apply(_this, ['[5,28]']); commands.lastCraftCommand.wsSend=_arguments[0]; }else if(arr[0]===3){ commands.autoClick.wsSend=arr[1]; }else if(arr[0]===14){ commands.autoClick.active=false; } } } ws.readyState === ws.OPEN && Function.prototype.apply.apply(target, [_this, _arguments]); } }); return ws; } }); oldfunc['canvas.fillRect'] = CanvasRenderingContext2D.prototype.fillRect; newfunc['canvas.fillRect'] = CanvasRenderingContext2D.prototype.fillRect= new Proxy(CanvasRenderingContext2D.prototype.fillRect, { apply: function(target, _this, _arguments) { if(arguments.callee.caller && arguments.callee.caller.name===options.circleTimerFuncName && _this.fillStyle==="#669bb1"){ _this.fillStyle = aimbot? "green" : "red"; _this.font = "25px Arial"; _this.fillText(`${circleTime? (5-(Date.now()-circleTime)/1000).toFixed(1):'5'}`,_arguments[0]+180,_arguments[1]+20); if(options.showLastPlayerUI){ lastplayers.forEach((p,i)=>{ _this.fillText(p,_arguments[0]+180,_arguments[1]+20+i*30-180); }); } _this.fillStyle="#669bb1" } return Function.prototype.apply.apply(target, [_this, _arguments]); } }); oldfunc['canvas.drawImage'] = CanvasRenderingContext2D.prototype.drawImage; newfunc['canvas.drawImage'] = CanvasRenderingContext2D.prototype.drawImage= new Proxy(CanvasRenderingContext2D.prototype.drawImage, { apply: function(target, _this, _arguments) { if(_arguments[0] instanceof Image ){ if(_arguments[0].src && _arguments[0].src.includes('night')){ true; // _arguments[0]=imgMap.get(_arguments[0].src.split('/img/')[1]); }else if(_arguments[0].src && _arguments[0].src.includes('day')){ // imgMap.set(_arguments[0].src.split('/img/')[1].replace('night'),_arguments[0]); } } return Function.prototype.apply.apply(target, [_this, _arguments]); } }); oldfunc['array.push'] = Array.prototype.push; newfunc['array.push'] = Array.prototype.push= new Proxy(Array.prototype.push, { apply: function(target, _this, _arguments) { const data=_arguments[0]; if (data && data.type != null && data.id != null && data.x && data.y && data.update) { const old_update = data.update; data.update = function(){ this.lastUpdateTime=Date.now(); return old_update.apply(this,arguments); } let id=data[Object.keys(data)[1]]; if(id===myPlayerId){ myPlayer=data; } else{ enemyMap.set(id,data); } } return Function.prototype.apply.apply(target, [_this, _arguments]); } }); //hooks //handler /* window.addEventListener('beforescriptexecute',e => { if (e.script.src.includes('c9')) { e.preventDefault(); fetch('https://starve.io/js/c9.js').then(response=>response.text()).then((dataStr) => { let sc=document.createElement('script'); sc.textContent=dataStr.replace(new RegExp('function '+options.gameFuncName+'\\(\\)\\{',"gi"),"function "+options.gameFuncName+"(){'object' === typeof this && window!==this && ((obj)=>{window.GAME=obj})(this);"); e.target.append(sc); }) } });*/ document.addEventListener('keydown', (event)=>{ if( document.getElementById('chat_block').style.display!=='inline-block'){ if(event.code==="KeyQ"){ commands.autoClick.active=!commands.autoClick.active; commands.autoClick.active ? ws.send(`[4,${commands.autoClick.wsSend}]`) : ws.send("[14]") }else if(event.code==='Space'){ aimbot=!aimbot; }else{ for (const [key, value] of Object.entries(commands)) { if(value.keyCode===event.code){ ws.send(value.wsSend); } } } } }); document.addEventListener("DOMContentLoaded", function(event) { //style document.getElementById("game_canvas") && document.getElementById("game_canvas").style && (function(){document.getElementById("game_canvas").style.filter = "brightness(1.2)"})(); //style //create craft Helper Panel craftHelperE=document.createElement('div'); document.body.insertAdjacentHTML('beforeend','<div style=" position: absolute; left: 0; color: white; bottom: 0; margin: 10px; "><div id="craftItems" style=" opacity: 0.5; "></div> <div id="craftImg"></div><div><span id="prev"><<</span><span id="remove">Remove</span><span id="next">>></span></div>'); craftImg=document.getElementById('craftImg'); craftItems=document.getElementById('craftItems'); document.getElementById('prev').addEventListener('click',prev); document.getElementById('next').addEventListener('click',next); document.getElementById('remove').addEventListener('click',remove); document.getElementsByClassName('content')[0].addEventListener('click',(e)=>{ if(e.target instanceof HTMLImageElement){ let items=[]; craftItems.innerHTML=""; craftImg.innerHTML=""; craftImg.appendChild(e.target.cloneNode()); document.querySelectorAll('.recipe >img').forEach((e,i)=>{ if(e.style.display=="inline-block"){ let div=document.createElement('div'); e.style['vertical-align']='middle'; items.push({imgSrc:e.src, number:document.getElementById('numb'+(i+1)).textContent}); div.appendChild(e.cloneNode()); div.insertAdjacentHTML('beforeend',`<span>${document.getElementById('numb'+(i+1)).textContent}</span>`); craftItems.appendChild(div); } }); craftHelper[craftHelper.length]={imgSrc:e.target.src,items:items}; craftHelperID=craftHelper.length-1; } }); viewCraftHelper(0); }); document.addEventListener('contextmenu', function(e) { ws.send(`[5,7]`); }); //handler //app run(); //app })();
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址