您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
try to take over the world!
当前为
- // ==UserScript==
- // @name Shape Aimbot UPDATED
- // @namespace http://tampermonkey.net/
- // @version 10
- // @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 = {};
- const
- p = CanvasRenderingContext2D.prototype,
- _fill = p.fill,
- _moveTo = p.moveTo,
- _lineTo = p.lineTo,
- _beginPath = p.beginPath,
- _toString = Function.prototype.toString;
- let fill,
- moveTo,
- lineTo,
- beginPath;
- 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',
- }
- 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;
- }
- });
- let calls = 0;
- let points = [];
- const onClose = (c) => {
- if(['#999999', '#000000', '#00b2e1', '#fcc376'].includes(c)) {
- return;
- }
- if(calls == 4){
- shapes.triangles.push(getCentre(points))
- }
- if(calls == 5){
- shapes.squares.push(getCentre(points))
- }
- if(calls == 6){
- shapes.pentagons.push(getCentre(points))
- }
- }
- beginPath = function(...args) {
- calls = 1;
- points = [];
- _beginPath.call(this, ...args);
- }
- moveTo = function(...args) {
- calls = 2;
- points.push (args);
- _moveTo.call(this, ...args)
- }
- lineTo = function(...args) {
- if (calls >= 2 && calls <= 5) {
- calls ++;
- points.push (args);
- } else {
- calls = 0;
- }
- _lineTo.call(this, ...args)
- }
- fill = function(...args) {
- onClose(this.fillStyle);
- _fill.call(this, ...args)
- }
- 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)
- });
- 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 = "bold 23px serif";
- context.strokeStyle = '#000000';
- context.fillStyle = 'red';
- 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();
- const toString = function() {
- switch(this) {
- case fill: return _toString.call(_fill);
- case moveTo: return _toString.call(_moveTo);
- case beginPath: return _toString.call(_beginPath);
- case lineTo: return _toString.call(_lineTo);
- case toString: return _toString.call(_toString);
- }
- return _toString.call(this);
- };
- p.fill = fill;
- p.beginPath = beginPath;
- p.moveTo = moveTo;
- p.lineTo = lineTo;
- Function.prototype.toString = toString;
- },2500);