Starve.io

Starve.io Auto Atack Aimbot Auto Crafting extended UI

当前为 2020-09-27 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name Starve.io
  3. // @namespace http://tampermonkey.net/
  4. // @version 0.1.4
  5. // @description Starve.io Auto Atack Aimbot Auto Crafting extended UI
  6. // @author You
  7. // @match https://starve.io/*
  8. // @grant none
  9. // ==/UserScript==
  10.  
  11. (function() {
  12. //polyfills
  13. window.console._log=window.console.log;
  14. 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});
  15. //polyfills
  16. //options
  17. let craftImg,craftItems,craftHelperE;
  18. let enemyMap= new Map();
  19. let imgMap=new Map();
  20. // window.allyMap= new Map();
  21. let myPlayerId;
  22. let myPlayer;
  23. let aimbot=true;
  24. let options={
  25. gameFuncName:"wi",
  26. circleTimerFuncName:"fh",
  27. showLastPlayerUI:true,
  28. timeoutLastPlayerUI:undefined
  29. };
  30. let craftHelper=[{"imgSrc":"https://starve.io/img/inv-bag-out.png","items":[{"imgSrc":"","number":"6"},{"imgSrc":"","number":"5"}]}],craftHelperID;
  31. let ws;
  32. let circleTime;
  33. const lastplayers=["Player1","Player2","Player3","Player4","Player5",];
  34. let commands={lastCraftCommand:{keyCode:"KeyE",wsSend:"[7,49]"},
  35. meatCraft:{keyCode:"KeyZ",wsSend:"[7,49]"},
  36. bandageCraft:{keyCode:"KeyX",wsSend:"[7,54]"},
  37. fillBottle:{keyCode:"KeyC",wsSend:"[7,111]"},
  38. autoClick:{keyCode:"KeyQ",active:false,wsSend:"0"}
  39. }
  40. let oldfunc={};
  41. let newfunc={};
  42. //options
  43. //functions
  44. function run(){
  45. history.pushState('id', 'id', '/?id=1');
  46. }
  47. const dist2d = (p1, p2) => {
  48. return Math.sqrt((p1.x-p2.x)**2 + (p1.y-p2.y)**2);
  49. }
  50.  
  51. const calcAngle = (p1, p2) => {
  52. var dy = p2.y - p1.y;
  53. var dx = p2.x - p1.x;
  54. var theta = Math.atan2(dy, dx);
  55. theta *= 180 / Math.PI;
  56. return theta;
  57. }
  58. const angle360 = (p1,p2) => {
  59. var theta = calcAngle(p1,p2);
  60. if (theta < 0) theta = 360 + theta;
  61. return theta;
  62. }
  63. function findEnemyAngle(angle){
  64. let minDist=99999,enemy;
  65. enemyMap.forEach((value, key, map)=>{
  66. if(value.lastUpdateTime+5000>Date.now()){
  67. let dist=dist2d(myPlayer,value);
  68. if( dist < 290 && dist<minDist){
  69. minDist=dist;
  70. enemy=value;
  71. setTimeout(()=>{aimbot && ws.send(`[3,${findEnemyAngle(angle)}`);},1000/60)
  72. }
  73. }
  74. });
  75. return enemy ? Math.floor(angle360(myPlayer,enemy)*64/90): angle;
  76. }
  77. function viewCraftHelper(craftHelperID){
  78. if(craftHelper.length>0 && craftHelperID<craftHelper.length){
  79. craftImg.innerHTML="";
  80. craftItems.innerHTML="";
  81. craftImg.insertAdjacentHTML('beforeend',`<img class="img_recipe" id="img_1" src=${craftHelper[craftHelperID].imgSrc} style="display: inline-block;">`);
  82. craftHelper[craftHelperID].items.forEach((item)=>{
  83. craftItems.insertAdjacentHTML('beforeend',`<div><img class="inv" id="inv1" src="${item.imgSrc}" style="display: inline-block; vertical-align: middle;"><span>${item.number}</span></div>`);
  84.  
  85. });
  86. }
  87. }
  88. function prev(){
  89. craftHelperID--;
  90. if(craftHelperID<0){
  91. craftHelperID=craftHelper.length-1;
  92. }
  93. craftHelper.length>1 && viewCraftHelper(craftHelperID);
  94. }
  95. function next(){
  96. craftHelperID++;
  97. if(craftHelperID>=craftHelper.length){
  98. craftHelperID=0;
  99. }
  100. craftHelper.length>1 && viewCraftHelper(craftHelperID);
  101. }
  102. function remove(){
  103. if(craftHelper.length>1){
  104. craftHelper.splice(craftHelperID,1);
  105. prev();
  106. }else if(craftHelper.length==1){viewCraftHelper(0);}
  107. }
  108. //functions
  109. //hooks
  110. /* //If there is an update, bring the new function name.
  111. oldfunc['String.indexOf']=String.prototype.indexOf;
  112. String.prototype.indexOf=newfunc['String.indexOf']=new Proxy(String.prototype.indexOf,{
  113. apply:function(target, thisArg, argArray){
  114. if(argArray[0]=="http://starve.io/beta"){ console.log(arguments.callee.caller.name)
  115. String.prototype.indexOf=oldfunc['String.indexOf'];
  116. }
  117. return target.apply(thisArg, argArray);
  118. }});
  119. */
  120. oldfunc.webSocket=window.WebSocket;
  121. window.WebSocket=newfunc.webSocket=new Proxy(window.WebSocket,{
  122. construct:function(target,args){
  123. ws = new target(...args);
  124. setTimeout(()=>{var event = document.createEvent('Event');
  125. event.data=[22,0];
  126. event.initEvent('message', true, true);
  127. ws.dispatchEvent(event);},2000);
  128. const messageHandler = (e) => {
  129. if ("string" === typeof e.data){
  130. e = JSON.parse(e.data);
  131. switch (e[0]) {
  132. case 2:
  133. lastplayers.unshift(e[2]+" | "+e[1]) && lastplayers.length>5 && lastplayers.pop();
  134. options.showLastPlayerUI=true;
  135. options.timeoutLastPlayerUI && clearTimeout(options.timeoutLastPlayerUI);
  136. options.timeoutLastPlayerUI=setTimeout(()=>{options.showLastPlayerUI=false;},5000);
  137. break;
  138. case 3:
  139. myPlayerId=e[9];
  140. break;
  141. }
  142. }else{
  143. var d = new Uint8Array(e.data);
  144. switch (d[0]) {
  145. case 16:
  146. circleTime=Date.now();
  147. break;
  148. case 22:
  149. if(d[1]==1 &&!(e.data instanceof Array)){
  150. setTimeout(()=>{var event = document.createEvent('Event');
  151. event.data=[22,0];
  152. event.initEvent('message', true, true);
  153. ws.dispatchEvent(event);},2000);
  154. }
  155. break;
  156. }
  157. }
  158. };
  159.  
  160. const closeHandler = (event) => {
  161. console.log('Close', event);
  162. aimbot=false;
  163. enemyMap.clear();
  164. ws.removeEventListener('message', messageHandler);
  165. ws.removeEventListener('close', closeHandler);
  166. ws.send= oldfunc['ws.send'];
  167. };
  168. ws.addEventListener('message', messageHandler);
  169. ws.addEventListener('close', closeHandler);
  170.  
  171. oldfunc['ws.send']=ws.send;
  172. newfunc['ws.send']= ws.send= new Proxy(ws.send, {
  173. apply: function(target, _this, _arguments) {
  174. if(typeof _arguments[0]==='string' ){
  175. let arr
  176. try{
  177. arr =JSON.parse(_arguments[0]);
  178. }catch(err){}
  179. if(arr){
  180. if(arr[0]===3 || arr[0]===4){
  181. if(aimbot){
  182. arr[1]=findEnemyAngle(arr[1]);
  183. _arguments[0]=JSON.stringify(arr);
  184. }
  185. }
  186. if(arr[0]===7){
  187. target.apply(_this, ['[5,28]']);
  188. commands.lastCraftCommand.wsSend=_arguments[0];
  189. }else if(arr[0]===3){
  190. commands.autoClick.wsSend=arr[1];
  191. }else if(arr[0]===14){
  192. commands.autoClick.active=false;
  193. }
  194. }
  195. }
  196. ws.readyState === ws.OPEN && Function.prototype.apply.apply(target, [_this, _arguments]);
  197. }
  198. });
  199. return ws;
  200. }
  201. });
  202. oldfunc['canvas.fillRect'] = CanvasRenderingContext2D.prototype.fillRect;
  203. newfunc['canvas.fillRect'] = CanvasRenderingContext2D.prototype.fillRect= new Proxy(CanvasRenderingContext2D.prototype.fillRect, {
  204. apply: function(target, _this, _arguments) {
  205. if(arguments.callee.caller && arguments.callee.caller.name===options.circleTimerFuncName && _this.fillStyle==="#669bb1"){
  206. _this.fillStyle = aimbot? "green" : "red";
  207. _this.font = "25px Arial";
  208. _this.fillText(`${circleTime? (5-(Date.now()-circleTime)/1000).toFixed(1):'5'}`,_arguments[0]+180,_arguments[1]+20);
  209. if(options.showLastPlayerUI){
  210. lastplayers.forEach((p,i)=>{
  211. _this.fillText(p,_arguments[0]+180,_arguments[1]+20+i*30-180);
  212. });
  213. }
  214. _this.fillStyle="#669bb1"
  215. }
  216. return Function.prototype.apply.apply(target, [_this, _arguments]);
  217. }
  218. });
  219. oldfunc['canvas.drawImage'] = CanvasRenderingContext2D.prototype.drawImage;
  220. newfunc['canvas.drawImage'] = CanvasRenderingContext2D.prototype.drawImage= new Proxy(CanvasRenderingContext2D.prototype.drawImage, {
  221. apply: function(target, _this, _arguments) {
  222. if(_arguments[0] instanceof Image ){
  223. if(_arguments[0].src && _arguments[0].src.includes('night')){
  224. true;
  225. // _arguments[0]=imgMap.get(_arguments[0].src.split('/img/')[1]);
  226. }else if(_arguments[0].src && _arguments[0].src.includes('day')){
  227. // imgMap.set(_arguments[0].src.split('/img/')[1].replace('night'),_arguments[0]);
  228. }
  229. }
  230. return Function.prototype.apply.apply(target, [_this, _arguments]);
  231. }
  232. });
  233. oldfunc['array.push'] = Array.prototype.push;
  234. newfunc['array.push'] = Array.prototype.push= new Proxy(Array.prototype.push, {
  235. apply: function(target, _this, _arguments) {
  236. const data=_arguments[0];
  237. if (data && data.type != null && data.id != null && data.x && data.y && data.update) {
  238.  
  239. const old_update = data.update;
  240. data.update = function(){
  241. this.lastUpdateTime=Date.now();
  242. return old_update.apply(this,arguments);
  243. }
  244. let id=data[Object.keys(data)[1]];
  245. if(id===myPlayerId){
  246. myPlayer=data;
  247. }
  248. else{
  249. enemyMap.set(id,data);
  250. }
  251. }
  252. return Function.prototype.apply.apply(target, [_this, _arguments]);
  253. }
  254. });
  255.  
  256. //hooks
  257. //handler
  258. /* window.addEventListener('beforescriptexecute',e => {
  259. if (e.script.src.includes('c9')) {
  260. e.preventDefault();
  261. fetch('https://starve.io/js/c9.js').then(response=>response.text()).then((dataStr) => {
  262. let sc=document.createElement('script');
  263. sc.textContent=dataStr.replace(new RegExp('function '+options.gameFuncName+'\\(\\)\\{',"gi"),"function "+options.gameFuncName+"(){'object' === typeof this && window!==this && ((obj)=>{window.GAME=obj})(this);");
  264. e.target.append(sc);
  265. })
  266. }
  267. });*/
  268. document.addEventListener('keydown', (event)=>{
  269. if( document.getElementById('chat_block').style.display!=='inline-block'){
  270. if(event.code==="KeyQ"){
  271. commands.autoClick.active=!commands.autoClick.active;
  272. commands.autoClick.active ? ws.send(`[4,${commands.autoClick.wsSend}]`) : ws.send("[14]")
  273. }else if(event.code==='Space'){
  274. aimbot=!aimbot;
  275. }else{
  276. for (const [key, value] of Object.entries(commands)) {
  277. if(value.keyCode===event.code){
  278. ws.send(value.wsSend);
  279. }
  280. }
  281. }
  282. }
  283. });
  284. document.addEventListener("DOMContentLoaded", function(event) {
  285. //style
  286. document.getElementById("game_canvas") && document.getElementById("game_canvas").style && (function(){document.getElementById("game_canvas").style.filter = "brightness(1.2)"})();
  287. //style
  288. //create craft Helper Panel
  289. craftHelperE=document.createElement('div');
  290. 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">&lt;&lt;</span><span id="remove">Remove</span><span id="next">&gt;&gt;</span></div>');
  291. craftImg=document.getElementById('craftImg');
  292. craftItems=document.getElementById('craftItems');
  293. document.getElementById('prev').addEventListener('click',prev);
  294. document.getElementById('next').addEventListener('click',next);
  295. document.getElementById('remove').addEventListener('click',remove);
  296. document.getElementsByClassName('content')[0].addEventListener('click',(e)=>{
  297. if(e.target instanceof HTMLImageElement){
  298. let items=[];
  299. craftItems.innerHTML="";
  300. craftImg.innerHTML="";
  301. craftImg.appendChild(e.target.cloneNode());
  302. document.querySelectorAll('.recipe >img').forEach((e,i)=>{
  303. if(e.style.display=="inline-block"){
  304. let div=document.createElement('div'); e.style['vertical-align']='middle';
  305. items.push({imgSrc:e.src, number:document.getElementById('numb'+(i+1)).textContent});
  306. div.appendChild(e.cloneNode());
  307. div.insertAdjacentHTML('beforeend',`<span>${document.getElementById('numb'+(i+1)).textContent}</span>`);
  308. craftItems.appendChild(div);
  309. }
  310. });
  311. craftHelper[craftHelper.length]={imgSrc:e.target.src,items:items};
  312. craftHelperID=craftHelper.length-1;
  313. }
  314. });
  315. viewCraftHelper(0);
  316.  
  317. });
  318.  
  319. document.addEventListener('contextmenu', function(e) {
  320. ws.send(`[5,7]`);
  321. });
  322.  
  323.  
  324. //handler
  325. //app
  326. run();
  327. //app
  328.  
  329. })();

QingJ © 2025

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