您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Press f to set the afk location and j to afk boom
当前为
- // ==UserScript==
- // @name Afk Script
- // @namespace http://tampermonkey.net/
- // @version 1
- // @description Press f to set the afk location and j to afk boom
- // @author Mi300
- // @match https://diep.io/*
- // @icon 
- // @license dont copy my script thx
- // @grant none
- // ==/UserScript==
- setTimeout (function() {
- function hookContext(method, callback, target = CanvasRenderingContext2D) {
- target.prototype[method] = new Proxy(target.prototype[method], {
- apply(method, context, args) {
- callback(context, args);
- method.apply(context, args);
- }
- });
- };
- 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);
- hookContext('beginPath', function(context, args) {
- drawInstructions = 1;
- vertices = new Array(0);
- });
- hookContext('moveTo', function(context, args) {
- drawInstructions = 2;
- vertices.push(args);
- });
- hookContext('lineTo', function(context, args) {
- if (drawInstructions >= 2 && drawInstructions <= 5) {
- drawInstructions++;
- vertices.push(args);
- return;
- }
- drawInstructions = 0;
- });
- hookContext('fill', function(context, args) {
- if (context.globalAlpha != 1 || context.fillStyle != '#000000') {
- return;
- }
- if (drawInstructions === 4) {
- const pos = getAverage (vertices);
- arrowPos = pos;
- }
- });
- }
- function hookMinimap() {
- hookContext('strokeRect', function(context, args) {
- const t = context.getTransform();
- minimapPos = [t.e, t.f];
- minimapDim = [t.a, t.d];
- });
- hookContext('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);