您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Press F to set the afk location and J to afk
// ==UserScript== // @name Afk Script UPDATED // @namespace http://tampermonkey.net/ // @version 3 // @description Press F to set the afk location and J to afk // @author Mi300 // @match https://diep.io/* // @icon  // @license dont copy my script thx // @grant none // ==/UserScript== setTimeout (function() { function hook(target, callback){ const check = () => { window.requestAnimationFrame(check) const func = CanvasRenderingContext2D.prototype[target] if(func.toString().includes(target)){ CanvasRenderingContext2D.prototype[target] = new Proxy (func, { apply (method, thisArg, args) { callback(thisArg, args) return Reflect.apply (method, thisArg, args) } }); } } check() } const canvas = document.getElementById('canvas'); const ctx = canvas.getContext('2d'); let distance = [0, 0]; let isActive = false; let storedPos = [0, 0]; let arrowPos = [0, 0]; let minimapPos = [0, 0]; let minimapDim = [0, 0]; let worldPosition = [0, 0]; let teamSnapshot = false; let team = '#f14e54'; function hookMinimapArrow() { let drawInstructions = 0; let vertices = new Array(0); hook('beginPath', function(context, args) { drawInstructions = 1; vertices = new Array(0); }); hook('moveTo', function(context, args) { drawInstructions = 2; vertices.push(args); }); hook('lineTo', function(context, args) { if (drawInstructions >= 2 && drawInstructions <= 5) { drawInstructions++; vertices.push(args); return; } drawInstructions = 0; }); hook('fill', function(context, args) { if (context.globalAlpha != 1 || context.fillStyle != '#000000') { return; } if (drawInstructions === 4) { const pos = getAverage (vertices); arrowPos = pos; } }); } function hookMinimap() { hook('strokeRect', function(context, args) { const t = context.getTransform(); minimapPos = [t.e, t.f]; minimapDim = [t.a, t.d]; }); hook('rect', function(context, args) {// purple: #bf7ff5, red: #f14e54, blue: #00b2e1, green: #00e16e const c = context.fillStyle; if (teamSnapshot) { if (c == '#f14e54') { team = c; } if (c == '#00b2e1') { team = c; } if (c == '#bf7ff5') { team = c; } if (c == '#00e16e') { team = c; } } }); } hookMinimap(); hookMinimapArrow(); function getAverage(points) { let ret = [0, 0]; points.forEach (point => { ret[0] += point[0]; ret[1] += point[1]; }); ret[0] /= points.length; ret[1] /= points.length; return ret; } function getWorldPos () { const ret = [ parseFloat((((arrowPos[0] - minimapPos[0] - minimapDim[0] / 2) / minimapDim[0] * 100) * 460).toFixed (3)), parseFloat((((arrowPos[1] - minimapPos[1] - minimapDim[1] / 2) / minimapDim[1] * 100) * 460).toFixed (3)), ] return ret; } let lineWidth = 0; let cameraZoom = 0; CanvasRenderingContext2D.prototype.stroke = new Proxy(CanvasRenderingContext2D.prototype.stroke, { apply(method, self, args) { lineWidth = self.lineWidth; return Reflect.apply(method, self, args); } }); CanvasRenderingContext2D.prototype.createPattern = new Proxy(CanvasRenderingContext2D.prototype.createPattern, { apply(method, self, args) { cameraZoom = 1 / lineWidth; return Reflect.apply(method, self, args); } }); input.try_spawn = new Proxy(input.try_spawn, { apply(method, self, args) { teamSnapshot = true; setTimeout(function() { teamSnapshot = false; console.log (team) },1000); return Reflect.apply(method, self, args); } }); function tick() { window.requestAnimationFrame(tick); worldPosition = getWorldPos(); distance = getDist( worldPosition, storedPos, ) if (isActive) { move(); } drawAfkPos(); } tick(); function toGrid(dist) { return [ dist[0] / ((1 - cameraZoom) * 8), dist[1] / ((1 - cameraZoom) * 8), dist[2] / ((1 - cameraZoom) * 8), ] } function drawAfkPos() { //distance const width = canvas.width; const height = canvas.height; const grid = toGrid(distance); const size = 50; let toDraw = [ width / 2 - grid[1], height / 2 - grid[2], ] ctx.beginPath(); ctx.globalAlpha = 0.5; ctx.fillStyle = team ctx.arc(...toDraw, size, 0, Math.PI * 2, false); ctx.fill(); ctx.stroke(); ctx.globalAlpha = 1; ctx.beginPath(); ctx.lineWidth = 4; ctx.font = "23px bold arial" ctx.fillStyle = 'white'; ctx.strokeStyle = 'black'; if (isActive) { ctx.strokeText('[J] Locked', toDraw[0] - 50, toDraw[1] + 25); ctx.fillText('[J] Locked', toDraw[0] - 50, toDraw[1] + 25); } else { ctx.strokeText('[J] Unlocked', toDraw[0] - 50, toDraw[1] + 25); ctx.fillText('[J] Unlocked', toDraw[0] - 50, toDraw[1] + 25); } } document.addEventListener('keydown', e => { if(e.key === 'j') { isActive = !isActive; input.key_up (83); input.key_up (87); input.key_up (68); input.key_up (65); } if(e.key === 'f') { storedPos = worldPosition; } }); function getDist(t1, t2) { const distX = t1[0] - t2[0]; const distY = t1[1] - t2[1]; return [Math.hypot(distX, distY), distX, distY]; }; function move() { if (distance[1] < 0.1) { input.key_up (65); input.key_down (68); } else if (distance[1] > -0.1) { input.key_up (68); input.key_down (65); } else { input.key_up (68); input.key_up (65); } if (distance[2] < 0.1) { input.key_up (87); input.key_down (83); } else if (distance[2] > 0.1) { input.key_up (83); input.key_down (87); } else { input.key_up (83); input.key_up (87); } } },2500);
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址