您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
try to take over the world!
- // ==UserScript==
- // @name Shape Aimbot UPDATED
- // @namespace http://tampermonkey.net/
- // @version 2023
- // @description try to take over the world!
- // @author Mi300
- // @match https://diep.io/*
- // @icon 
- // @license dont copy thx
- // @grant none
- // ==/UserScript==
- setTimeout(function(){
- const canvas = document.getElementById ('canvas');
- const context = canvas.getContext ('2d');
- let mouse = [0, 0]
- let shapes = {};
- function clearShapes() {
- shapes = {
- squares: [],
- triangles: [],
- pentagons: [],
- }
- }
- clearShapes();
- let shapeData = {
- triangles: {
- sides: 3,
- colour: '',
- },
- squares: {
- sides: 4,
- colour: '',
- },
- pentagons: {
- sides: 5,
- colour: '',
- },
- }
- let debugOptions = {
- lines: true,
- shapeInfo: true,
- aim: false,
- }
- const names = {
- squares: 'Square',
- triangles: 'Triangle',
- pentagons: 'Pentagon',
- }
- 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()
- }
- document.addEventListener('keydown', function(e) {
- if (e.key === 't') {
- debugOptions.aim = !debugOptions.aim;
- }
- if (e.key === 'r') {
- debugOptions.lines = !debugOptions.lines;
- }
- if (e.key === 'q') {
- debugOptions.shapeInfo = !debugOptions.shapeInfo;
- }
- });
- function hookShapes(callback) {
- let calls = 0;
- let points = [];
- const onClose = (colour) => {
- callback(getCentre(points), colour, calls)
- }
- hook('beginPath', function(thisArg, args){
- calls = 1;
- points = [];
- });
- hook('moveTo', function(thisArg, args){
- if (calls == 1) {
- calls+=1;
- points.push(args)
- } else {
- calls = 0;
- }
- });
- hook('lineTo', function(thisArg, args){
- if (calls >= 2 && calls <= 6) {
- calls+=1;
- points.push(args)
- } else {
- calls = 0;
- }
- });
- hook('fill', function(thisArg, args){
- if(calls >= 4 && calls <= 6) {
- onClose(thisArg.fillStyle);
- } else {
- calls = 0;
- }
- });
- }
- function getCentre (vertices) {
- let centre = [0, 0];
- vertices.forEach (vertex => {
- centre [0] += vertex[0]
- centre [1] += vertex[1]
- });
- centre[0] /= vertices.length;
- centre[1] /= vertices.length;
- return centre;
- }
- document.addEventListener('mousemove', function() {
- if (!debugOptions.aim) {
- return;
- }
- input.mouse(...mouse)
- });
- hookShapes(function(a, c, ca){
- if (!['#ffe869', '#fc7677', '#768dfc'].includes(c)) {
- return;
- }
- if(ca == 4){
- shapes.triangles.push(a)
- }
- if(ca == 5){
- shapes.squares.push(a)
- }
- if(ca == 6){
- shapes.pentagons.push(a)
- }
- });
- function getDist(t1, t2){
- const distX = t1[0] - t2[0];
- const distY = t1[1] - t2[1];
- return [Math.hypot(distX, distY), distX, distY];
- };
- function getClosest (entities) {
- let acc = [0, 0]
- for (let i = 0; i < entities.length; i ++) {
- const accumulator = getDist (acc, [canvas.width / 2, canvas.height / 2])[0];
- const current = getDist (entities[i], [canvas.width / 2, canvas.height / 2])[0];
- if (current < accumulator) acc = entities[i];
- }
- return acc;
- }
- function aim() {
- const target = getClosest
- (
- shapes.pentagons.length>0
- ?shapes.pentagons
- :shapes.triangles.length>0
- ?shapes.triangles
- :shapes.squares
- )
- if (!debugOptions.aim) {
- return;
- }
- mouse = target;
- input.mouse(...target)
- }
- function drawDebug() {
- if (debugOptions.lines) {
- const everyshape = [].concat(
- shapes.squares,
- shapes.triangles,
- shapes.pentagons,
- )
- everyshape.forEach(function(shape){
- context.beginPath();
- context.lineWidth = 0.5;
- context.strokeStyle == 'black';
- context.moveTo(canvas.width / 2, canvas.height / 2);
- context.lineTo(...shape)
- context.stroke()
- context.closePath()
- });
- }
- if (debugOptions.shapeInfo) {
- for (let key in shapes) {
- const type = shapeData[key];
- context.strokeStyle = 'red';
- context.lineWidth = 2;
- shapes[key].forEach(function(shape){
- const size = 75;
- context.beginPath();
- context.strokeRect(shape[0] - size / 2, shape[1] - size / 2, size, size);
- context.closePath();
- });
- }
- for (let key in shapes) {
- const type = shapeData[key];
- shapes[key].forEach(function(shape){
- const size = 75;
- context.beginPath();
- context.lineWidth = 2;
- context.font = "30px serif";
- context.strokeStyle = '#000000';
- context.fillStyle = '#FFFFFF';
- context.strokeText(names[key], shape[0] - 25, shape[1] + size / 2.5)
- context.fillText(names[key], shape[0] - 25, shape[1] + size / 2.5)
- context.closePath();
- });
- }
- }
- }
- function mainloop() {
- window.requestAnimationFrame(mainloop);
- drawDebug();
- aim();
- clearShapes();
- }
- mainloop();
- },2500);