// ==UserScript==
// @name ScaledBot
// @namespace http://tampermonkey.net/
// @version 1.0
// @license MIT
// @description OWOP ScaledBot.
// @author scar17off
// @match *://augustberchelmann.com/owop/*
// @match *://ourworldofpixels.com/*
// @match *://yourworldofpixels.glitch.me/*
// @icon https://www.google.com/s2/favicons?domain=ourworldofpixels.com
// @grant none
// @namespace none
// ==/UserScript==
(function() {
'use strict';
function install() {
window.history.pushState("object or string", "Title", "/?#main");
var OJS = null;
if (!localStorage.scaled_height) {
localStorage.scaled_height = "315px";
};
if (!localStorage.scaled_width) {
localStorage.scaled_width = "680px";
};
let height = localStorage.scaled_height,
width = localStorage.scaled_width;
if(!OWOP.tool) OWOP.tool = OWOP.tools;
if(!OWOP.tools) OWOP.tools = OWOP.tool;
let f1 = 0;
let radius121 = 0;
let stop = false;
let OldPaste = false;
let wolfmove = false;
let useplayer = false;
let Pixelization = false;
if(!OWOP.cursors.stamp) OWOP.cursors.paste = OWOP.cursors.stamp;
if(!OWOP.cursors.shield) OWOP.cursors.shield = OWOP.cursors.protection;
if (!localStorage.scaled_botnick) {
localStorage.scaled_botnick = "SCALED_BOT";
};
let AutoLogin = false;
let paintfollow = false;
let AutoNickname = false;
let AutoPassword = false;
let folint;
let FollowInterval;
if (!localStorage.scaled_followinterval) {
localStorage.scaled_followinterval = 79;
FollowInterval = localStorage.scaled_followinterval;
} else {
FollowInterval = localStorage.scaled_followinterval;
};
let autoreconnecten = false;
let animation = 0;
let animations = {
circle: 0,
disk: 1,
atom: 2,
random: 3,
wave: 4,
line: 5,
hyperbola: 6,
ez: 7,
botline: 8,
x: 9,
spiral: 10,
cool: 11,
disktwo: 12,
topbottom: 13,
laggy: 14,
smallcircle: 15,
eight: 16,
cool2: 17,
tworings: 18,
threed: 19,
flower: 20,
square: 21,
infinity: 22,
infinity2: 23,
default2: 24,
trialge: 25,
disk3: 26,
saturn: 27,
storm: 28,
disk4: 29
};
let pattern = 0;
let patterns = {
lr: 0,
tb: 1,
rand: 2
};
let imgpattern = 0;
let imgpatterns = {
default: 0,
random: 1,
leftup: 2,
grid: 3,
square: 4
};
let eraserpattern = 0;
let eraserpatterns = {
tb: 0,
lr: 1,
perfect: 2
};
const SITEKEY = "6LcgvScUAAAAAARUXtwrM8MP0A0N70z4DHNJh-KI";
let following = false;
let cont;
let BOTS = [];
let over, newX, newY, pixel, color
let rendercaptchaen = false;
function componentToHex(c) {
var hex = c.toString(16);
return hex.length == 1 ? "0" + hex : hex;
};
function rgbtohex(r, g, b) {
return "#" + componentToHex(r) + componentToHex(g) + componentToHex(b);
};
append("https://raw.githack.com/Olical/EventEmitter/master/EventEmitter.min.js", () => {
function Bucket(rate, time) {
this.lastCheck = Date.now();
this.allowance = rate;
this.rate = rate;
this.time = time;
this.infinite = false;
}
Bucket.prototype.canSpend = function(count) {
if (this.infinite) {
return true;
}
this.allowance += (Date.now() - this.lastCheck) / 1000 * (this.rate / this.time);
this.lastCheck = Date.now();
if (this.allowance > this.rate) {
this.allowance = this.rate;
}
if (this.allowance < count) {
return false;
}
this.allowance -= count;
return true;
};
OJS = class extends EventEmitter {
// Options: "no_log", "ws", "origin", "agent", "index"
constructor(options) {
super();
let init = {};
let that = this;
if (!options.origin) options.origin = location.href.replaceAll("?", "");
if (!options.ws) options.ws = OWOP.options.serverAddress[0].url;
if (!options.proxy) {options.device = "🖥️"} else {options.device = "📡"};
if (options.origin) init.origin = options.origin;
if (options.agent) init.agent = options.agent;
let OJS = this;
this.ws = new WebSocket(options.ws, null, init);
this.ws.binaryType = 'arraybuffer';
this.RANKS = {
ADMIN: 3,
MOD: 2,
USER: 1,
NONE: 0
};
this.options = {
device: "🖥️",
isJoined: false,
id: options.ind,
ind: options.ind,
index: options.ind,
busy: false,
canSay: true,
tickAmount: 30,
special: 0,
class: null,
chunkSize: 16,
netUpdateSpeed: 20,
clusterChunkAmount: 64,
maxWorldNameLength: 24,
worldBorder: 0xFFFFF,
chatBucket: [4, 6],
captchaState: {
CA_WAITING: 0,
CA_VERIFYING: 1,
CA_VERIFIED: 2,
CA_OK: 3,
CA_INVALID: 4
},
captchaNames: {
0: "WAITING",
1: "VERIFYING",
2: "VERIFIED",
3: "OK",
4: "INVALID"
},
tools: {
id: {
'cursor': 0,
'move': 1,
'pipette': 2,
'eraser': 3,
'zoom': 4,
'fill': 5,
'paste': 6,
'export': 7,
'line': 8,
'protect': 9,
'copy': 10
},
0: 'cursor',
1: 'move',
2: 'pipette',
3: 'eraser',
4: 'zoom',
5: 'fill',
6: 'paste',
7: 'export',
8: 'line',
9: 'protect',
10: 'copy'
},
misc: {
worldVerification: OWOP.options.serverAddress[0].proto.misc.worldVerification,
chatVerification: OWOP.options.serverAddress[0].proto.misc.chatVerification,
tokenVerification: OWOP.options.serverAddress[0].proto.misc.tokenVerification
},
opCode: {
setId: 0,
worldUpdate: 1,
chunkLoad: 2,
teleport: 3,
setRank: 4,
captcha: 5,
setPQuota: 6,
chunkProtected: 7
}
};
this.chat = {
recvModifier: msg => msg,
sendModifier: msg => msg,
send: msg => OJS.ws.send(OJS.chat.sendModifier(msg) + OJS.options.misc.chatVerification),
sendWS: msg => {
OJS.ws.send(msg)
},
firstdata: () => OJS.chat.history[0],
lastdata: () => OJS.chat.history[OJS.chat.history.length - 1],
history: []
};
this.world = {
join: (world = "main") => {
if (OJS.ws.readyState !== 1) OJS.ws = new WebSocket(options.ws, null, init);
let ints = [];
world = world.toLowerCase();
for (let i = 0; i < world.length && i < 24; i++) {
let charCode = world.charCodeAt(i);
if ((charCode < 123 && charCode > 96) || (charCode < 58 && charCode > 47) || charCode === 95 || charCode === 46) {
ints.push(charCode);
}
}
let array = new ArrayBuffer(ints.length + 2);
let dv = new DataView(array);
for (let i = ints.length; i--;) {
dv.setUint8(i, ints[i]);
}
dv.setUint16(ints.length, OJS.options.misc.worldVerification, true);
OJS.ws.send(array);
OJS.utils.log("Joining world: " + world);
OJS.emit(OJS.events.CONNECT);
OJS.world.name = world;
let color = rgbtohex(OJS.player.color[0], OJS.player.color[1], OJS.player.color[2]);
var bottable = document.createElement("tr");
bottable.innerHTML = `<td id="scaled-bots-menu-list-bot-${options.ind}">`+options.ind+`</td><td id="scaled-bots-menu-list-bot-${options.ind}-x">`+OJS.player.x+`</td><td id="scaled-bots-menu-list-bot-${options.ind}-y">`+OJS.player.y+`</td><td id="scaled-bots-menu-list-bot-${options.ind}-pq">`+OJS.utils.bucket.allowance+`</td><td id="scaled-bots-menu-list-bot-${options.ind}-color">`+color+`</td><td id="scaled-bots-menu-list-bot-${options.ind}-device">`+options.device+'</td>'+`<button id="scaled-bots-menu-list-bot-${options.ind}-leave">Disconnect</button>`+'  ';
bottable.id = `scaled-bots-menu-list-bot-${options.ind}`;
document.getElementById("scaled-bots-menu-list").appendChild(bottable);
document.getElementById(`scaled-bots-menu-list-bot-${options.ind}-leave`).addEventListener("click", () => {
that.world.leave();
document.getElementById(`scaled-bots-menu-list-bot-${options.ind}`).style.display = "none";;
});
if (options.proxy) document.getElementById(`scaled-proxy-proxyconns-${options.proxy}`).innerText = parseInt(document.getElementById(`scaled-proxy-proxyconns-${options.proxy}`).innerText) + 1;
OJS.options.isJoined = true;
return true;
},
leave: () => {
OJS.ws.close()
},
move: (x, y) => {
if (this.ws.readyState !== 1) return;
let array = new ArrayBuffer(12);
let dv = new DataView(array);
dv.setInt32(0, 16 * x, true);
dv.setInt32(4, 16 * y, true);
dv.setUint8(8, OWOP.player.selectedColor[0]);
dv.setUint8(9, OWOP.player.selectedColor[1]);
dv.setUint8(10, OWOP.player.selectedColor[2]);
dv.setUint8(11, OJS.options.tools.id[OWOP.player.tool.id]);
OJS.ws.send(array);
OJS.player.color[0] = OWOP.player.selectedColor[0];
OJS.player.color[1] = OWOP.player.selectedColor[1];
OJS.player.color[2] = OWOP.player.selectedColor[2];
OJS.player.x = Math.round(16 * x);
OJS.player.y = Math.round(16 * y);
if (document.getElementById(`scaled-bots-menu-list-bot-${options.ind}`)) {
document.getElementById(`scaled-bots-menu-list-bot-${options.ind}-x`).innerText = Math.round(x);
document.getElementById(`scaled-bots-menu-list-bot-${options.ind}-y`).innerText = Math.round(y);
document.getElementById(`scaled-bots-menu-list-bot-${options.ind}-color`).innerText = rgbtohex(OJS.player.color[0], OJS.player.color[1], OJS.player.color[2]);
};
},
setPixel: async function(x = OJS.player.x, y = OJS.player.y, color = OJS.player.color) {
let oldPlayerX = OJS.player.x;
let oldPlayerY = OJS.player.y;
let c = OWOP.world.getPixel(x, y);
//if(isProtected(x, y)) return;
if (c)
if (c[0] === color[0] && c[1] === color[1] && c[2] === color[2]) return;
OJS.world.move(x, y);
if (!OJS.utils.bucket.canSpend(1)) return false;
let array = new ArrayBuffer(11);
let dv = new DataView(array);
dv.setInt32(0, x, true);
dv.setInt32(4, y, true);
dv.setUint8(8, color[0]);
dv.setUint8(9, color[1]);
dv.setUint8(10, color[2]);
OJS.player.color = [color[0], color[1], color[2]];
document.getElementById(`scaled-bots-menu-list-bot-${options.ind}-color`).innerText = rgbtohex(OJS.player.color[0], OJS.player.color[1], OJS.player.color[2]);
if(useplayer) OWOP.world.setPixel(x, y, color);
OJS.ws.send(array);
if(wolfmove) OJS.world.move(oldPlayerX, oldPlayerY);
return true;
},
clearChunk: (x = OJS.player.x, y = OJS.player.y) => {
if (OJS.player.rank >= OJS.RANKS.MOD) {
let array = new ArrayBuffer(9);
let dv = new DataView(array);
dv.setInt32(0, x, true);
dv.setInt32(4, y, true);
OJS.ws.send(array);
return true;
} else {
console.error("[ERROR]: You are not admin!");
return false
}
},
setColor: function(rgb) {
if (typeof rgb !== "object") return OJS.utils.log(`Please use array.`);
let array = new ArrayBuffer(12);
let dv = new DataView(array);
dv.setInt32(0, OJS.player.x, true);
dv.setInt32(4, OJS.player.y, true);
dv.setUint8(8, rgb[0]);
dv.setUint8(9, rgb[1]);
dv.setUint8(10, rgb[2]);
dv.setUint8(11, OJS.player.tool);
OJS.ws.send(array);
OJS.player.color = [rgb[0], rgb[1], rgb[2]];
document.getElementById(`scaled-bots-menu-list-bot-${options.ind}-color`).innerText = rgbtohex(OJS.player.color[0], OJS.player.color[1], OJS.player.color[2]);
},
setTool: function(toolId) {
let array = new ArrayBuffer(12);
let dv = new DataView(array);
dv.setInt32(0, OJS.player.x, true);
dv.setInt32(4, OJS.player.y, true);
dv.setUint8(8, OJS.player.color[0]);
dv.setUint8(9, OJS.player.color[1]);
dv.setUint8(10, OJS.player.color[2]);
dv.setUint8(11, toolId);
OJS.ws.send(array);
OJS.player.tool = toolId;
},
protectChunk: function(x, y, newState) {
if (OJS.player.rank >= OJS.RANKS.MOD) {
let array = new ArrayBuffer(10);
let dv = new DataView(array);
dv.setInt32(0, x, true);
dv.setInt32(4, y, true);
dv.setUint8(8, newState);
OJS.ws.send(array);
} else {
console.error("[ERROR]: No permission.")
}
},
getPixel: OWOP.world.getPixel,
name: null
};
this.player = {
id: 0,
rank: 1,
x: 0,
y: 0,
color: [0, 0, 0],
tool: 1
};
this.players = {};
this.utils = {
bucket: new Bucket(32, 4),
log: msg => {
if (!options.no_log && msg[0] !== "[" && isNaN(parseInt(msg[0]))) console.log(`${options.index ? `(${options.index}) ` : ""}` + `[OWOP.js]: ${msg}`)
},
setNickname: name => {
this.chat.send("/nick " + name);
},
dataHandler: async data => {
if (typeof data !== "object") return;
let op = OJS.options.opCode;
data = new DataView(data);
switch (data.getUint8(0)) {
case op.setId:
OJS.player.id = data.getUint32(1);
OJS.utils.log(`Joined world ${OJS.world.name}, your ID is: ${data.getUint32(1)}.`);
OJS.emit(OJS.events.ID, OJS.player.id);
break;
case op.worldUpdate:
let updated = false;
let updates = {};
for (let i = data.getUint8(1); i--;) {
updated = true;
let pid = data.getUint32(2 + i * 16);
let pmx = data.getUint32(2 + i * 16 + 4);
let pmy = data.getUint32(2 + i * 16 + 8);
let pr = data.getUint8(2 + i * 16 + 12);
let pg = data.getUint8(2 + i * 16 + 13);
let pb = data.getUint8(2 + i * 16 + 14);
let ptool = data.getUint8(2 + i * 16 + 15);
updates[pid] = {
x: pmx,
y: pmy,
rgb: [pr, pg, pb],
tool: OJS.options.tools[ptool]
};
OJS.players[pid] = {
x: updates[pid].x >> 4,
y: updates[pid].y >> 4,
rgb: updates[pid].rgb,
tool: updates[pid].tool
};
}
if (updated) OJS.emit(OJS.events.UPDATE, updates);
break;
case op.setRank:
OJS.utils.log(`Got rank ${data.getUint8(1)}`);
OJS.player.rank = data.getUint8(1);
OJS.emit(OJS.events.RANK, OJS.player.rank);
break;
case op.captcha:
console.log(OJS.options.captchaNames[data.getUint8(1)]);
switch (data.getUint8(1)) {
case OJS.options.captchaState.CA_WAITING:
this.options.captcha = true;
if (!localStorage.owopcaptcha) OJS.ws.send(OWOP.options.serverAddress[0].proto.misc.tokenVerification + await renderCaptcha())
else OJS.ws.send(`CaptchALETMEINPLZ${localStorage.owopcaptcha}`);
break;
case OJS.options.captchaState.CA_OK:
OJS.world.join(OWOP.world.name);
};
OJS.emit(OJS.events.CAPTCHA);
break;
case op.teleport:
let x = data.getInt32(1, !0),
y = data.getInt32(5, !0);
OJS.emit(OJS.events.TELEPORT, x, y);
break;
case op.setPQuota:
let rate = data.getUint16(1, !0),
time = data.getUint16(3, !0);
OJS.utils.bucket = new Bucket(rate, time);
OJS.emit(OJS.events.PQUOTA, rate, time);
OJS.utils.log(`Got new PQuota: ${rate}x${time}.`);
break;
}
}
};
this.events = {
CONNECT: 0,
data: 1,
ID: 2,
RANK: 3,
DISCONNECT: 4,
UPDATE: 5,
TELEPORT: 6,
CAPTCHA: 7,
PQUOTA: 8,
CHUNK: 9
};
let pqi = setInterval(() => {
if (!document.getElementById(`scaled-bots-menu-list-bot-${options.ind}-pq`)) return;
for (let i = 0; i < BOTS.length - 1; i++) BOTS[i].utils.bucket.canSpend(0);
document.getElementById(`scaled-bots-menu-list-bot-${options.ind}-pq`).innerText = Math.round(OJS.utils.bucket.allowance);
}, 20);
this.ws.onopen = () => {
this.emit("open")
};
this.ws.onmessage = msg => {
OJS.utils.dataHandler(msg.data);
if (typeof msg.data !== "string") return;
if (msg.data.startsWith('<')) return;
OJS.utils.log(OJS.chat.recvModifier(msg.data));
this.emit("data", OJS.chat.recvModifier(msg.data));
};
this.ws.onclose = () => {
document.getElementById(`scaled-bots-menu-list-bot-${options.ind}`).parentElement.style.display = "none";
if (!autoreconnecten) //OWOP.chat.local(`[${options.ind}]: Closed connection.`)
BOTS = BOTS.filter(i => i.options.ind !== options.ind);
console.log(`[OWOP.js]: Disconnected.`);
if (autoreconnecten) BOTS.push(new struct(options));
this.emit("close")
};
};
}});
let ProxyPasswords = localStorage.scaled_proxies;
if (!ProxyPasswords) ProxyPasswords = [];
if (localStorage.scaled_proxies) ProxyPasswords = ProxyPasswords.split(",");
const updateServers = () => {
const servers = document.getElementById("scaled-proxies-menu-list");
for (let i in ProxyPasswords) {
const Proxy = ProxyPasswords[i];
let proxytable = document.createElement("tr");
proxytable.id = `scaled-proxy-${Proxy}`;
proxytable.innerHTML = `<td id="scaled-proxy-${Proxy}">${Proxy}</td><td id="scaled-proxy-proxystatus-${Proxy}" style="color: yellow;">=</td><td id="scaled-proxy-proxyconns-${Proxy}">?</td><td><button id="scaled-proxy-proxyjoin-${Proxy}">Connect</button></td><td><button id="scaled-proxy-proxydisconnect-${Proxy}">Disconnect</button></td><td><button id="scaled-proxy-proxydelete-${Proxy}">Delete</button></td>`+'  ';
servers.appendChild(proxytable);
document.getElementById(`scaled-proxy-proxydelete-${Proxy}`).onclick = () => {
delete localStorage.scaled_proxies[Proxy];
delete ProxyPasswords[Proxy];
localStorage.scaled_proxies = localStorage.scaled_proxies(e => e !== Proxy);
ProxyPasswords = localStorage.scaled_proxies(e => e !== Proxy);
};
const WSCheck = new WebSocket(`wss://ws-proxy${Proxy}.glitch.me/?ws=WS-STATUS`);
WSCheck.onopen = () => {
onlineproxy += 1;
if(checkingproxy !== 0) checkingproxy -= 1;
document.getElementById(`scaled-proxy-proxystatus-${Proxy}`).innerText = "+";
document.getElementById(`scaled-proxy-proxystatus-${Proxy}`).style.color = "lightgreen";
document.getElementById(`scaled-proxy-proxyjoin-${Proxy}`).onclick = () => {
proxyJoin(Proxy);
};
document.getElementById(`scaled-proxy-proxydisconnect-${Proxy}`).onclick = () => {
for(let i in BOTS){
if(BOTS[i].options.proxy == document.getElementById(`scaled-proxy-${Proxy}`).innerText){
BOTS[i].ws.close();
BOTS[i].slice();
};
};
};
WSCheck.send("WS-STATUS");
};
WSCheck.onmessage = msg => {
document.getElementById(`scaled-proxy-proxyconns-${Proxy}`).innerText = parseInt(msg.data.split(",")[1]) - 1;
WSCheck.close();
};
WSCheck.onerror = () => {
if(onlineproxy !== 0) onlineproxy -= 1;
checkingproxy -= 1;
offlineproxy += 1;
document.getElementById(`scaled-proxy-proxystatus-${Proxy}`).innerText = "-";
document.getElementById(`scaled-proxy-proxystatus-${Proxy}`).style.color = "red";
};
};
};
let allproxy = ProxyPasswords.length;
let checkingproxy = allproxy;
let offlineproxy = 0;
let onlineproxy = 0;
const renderCaptcha = () => new Promise(resolve => {
if (rendercaptchaen = true) {
OWOP.windowSys.addWindow(new OWOP.windowSys.class.window(`Captcha`, {
closeable: true
}, function(win) {
grecaptcha.render(win.addObj(OWOP.util.mkHTML("div", {})), {
theme: "dark",
sitekey: SITEKEY,
callback: function callback(token) {
win.close();
resolve(token);
}
});
}));
};
});
const getFree = () => {
let b = BOTS.filter(i => i.ws.readyState === 1);
if (b.length === 0) return -1;
if (last >= b.length) last = 0;
return last++;
};
let botslen = 7;
async function writeChar(matrix, x, y) {
for (var xx = 0; xx < matrix.length; xx++)
for (var yy = 0; yy < 8; yy += slen)
for (var bb = 0; bb < slen; bb++)
if ((matrix[xx] >> (7 - yy - bb)) & 1 && yy + bb < 8) {
const abc = getFree();
BOTS[abc].world.setPixel(x + xx, y + yy + bb, OWOP.player.selectedColor, false);
};
};
async function writeText(str, x, y) {
if (isNaN(x) || isNaN(y)) return OWOP.chat.local('Invalid Coordinates')
str = str.toUpperCase();
var len = str.length,
ccode, matrix;
for (var i = 0; i < len; i++) {
ccode = str.charCodeAt(i);
if (ccode >= 0x41 && ccode <= 0x5a)
matrix = chars[ccode - 65];
else if (ccode == 0x20) {
x += 2;
continue;
} else if (ccode >= 0x30 && ccode <= 0x39)
matrix = NUMS[ccode - 0x30];
else if (symbols[ccode])
matrix = symbols[ccode];
else {
continue;
}
writeChar(matrix, x, y);
x += matrix.length + 1;
}
};
const proxyJoin = server => {
let ws = "wss://ws-proxy" + server + ".glitch.me";
let BotCount = parseFloat(document.getElementById("scaled-main-menu-botcount").value);
for (let i = 0; i < BotCount; i++) {
const ofo = BOTS.length;
BOTS[ofo] = new OJS({
ws: ws + `?ws=${OWOP.options.serverAddress[0].url}`,
origin: location.href,
ind: ofo,
proxy: server
});
BOTS[ofo].ws.onmessage = msg => {
if (msg.data.toString().startsWith('You are banned.')) {
document.getElementById(`scaled-proxy-proxystatus-${server}-proxystatus-${server}`).innerText = "|";
document.getElementById(`scaled-proxy-proxystatus-${server}-proxystatus-${server}`).style.color = "yellow";
//document.getElementById(`proxy-${server}`).style.cssText = "display:none";
};
};
//BOTS[ofo].ws.onopen = () => {
// if(AutoLogin = true){
// if(localStorage.adminlogin) {
// BOTS[ofo].chat.send(`/adminlogin ${localStorage.adminlogin}`);
// };
// };
// if(AutoPassword = true) {
// if(AutoPassword && JSON.parse(localStorage.worldPasswords)[OWOP.world.name]) BOTS[ofo].chat.send(`/pass ${JSON.parse(localStorage.worldPasswords)[OWOP.world.name]}`);
// };
// if(AutoNickname = true) {
// BOTS[ofo].chat.send(`/nickname ${localStorage.scaled_botnick}`);
// };
//};
};
};
function drawRectbrush(x, y, w, h, color) {
if (isNaN(x) || isNaN(y) || isNaN(w) || isNaN(h)) {
return;
}
color = color || OWOP.player.selectedColor;
let Y, X, i;
for (Y = 0; Y < h; Y++) {
for (X = 0; X < w; X += BOTS.length) {
for (i = 0; i < BOTS.length; i++) {
if (X + i < w) {
over = 0;
newX = X + i;
newY = Y;
pixel = OWOP.world.getPixel(x + newX, y + newY);
if (pixel[0] !== color[0] || pixel[1] !== color[1] || pixel[2] !== color[2]) {
let abc = getFree();
BOTS[abc].world.setPixel(x + newX, y + newY, color);
} else continue;
}
}
}
}
};
const upload = (accept = "*") => new Promise(resolve => {
let file = document.createElement('input');
file.type = "file";
file.accept = accept;
file.onchange = () => {
let reader = new FileReader();
reader.onloadend = () => {
resolve(reader.result);
};
reader.readAsDataURL(file.files[0]);
};
file.click();
});
const refreshAssets = () => {
let assets = localStorage.scaled_assets;
if (!assets) assets = [];
else assets = JSON.parse(assets);
const assetsDiv = document.getElementById("scaled-assets-menu-assetlist");
assetsDiv.innerHTML = "";
for (let i in assets) {
const image = new Image();
image.onload = () => {
image.style.width = "48px";
image.style.height = "48px";
image.style.border = "solid 1px";
image.onclick = e => {
for (let j in document.getElementById("scaled-assets-menu-assetlist").children) {
if (typeof(document.getElementById("scaled-assets-menu-assetlist").children[j]) !== "object") break;
document.getElementById("scaled-assets-menu-assetlist").children[j].style.border = "solid 1px";
}
selectedAsset = assets[i];
image.style.border = "solid 1px red";
};
image.oncontextmenu = e => {
e.preventDefault();
assets.splice(i, 1);
localStorage.scaled_assets = JSON.stringify(assets);
refreshAssets();
}
assetsDiv.append(image);
};
image.src = assets[i];
}
};
const sleep = ms => new Promise(resolve => setTimeout(resolve, ms));
let selectedAsset = null;
let last = 0;
OWOP.windowSys.addWindow(new OWOP.windowSys.class.window(" ", {
closeable: true
}, function(win) {
let menu = document.createElement("div");
let styles = document.createElement("style");
styles.type = "text/css";
styles.innerHTML = `
th[id^="scaled-"], td[id^="scaled-"] {
font-family: Verdana,sans-serif;
font-size: 12px;
padding: 2px 6px;
width: 500px;
text-align: center;
}
tr[id^="scaled-"]:first-child {
font-family: Verdana,sans-serif;
font-size: 12px;
text-align: center;
background-color: rgba(0, 0, 0, 0.5);
}
tr[id^="scaled-"]:nth-child(odd) {
font-family: Verdana,sans-serif;
font-size: 12px;
background-color: rgba(0, 0, 0, 0.1);
}
table[id^="scaled-"] {
border-collapse: collapse;
border: 0px solid #000;
color: #fff;
text-shadow: -1px 0 #000, 0 1px #000, 1px 0 #000, 0 -1px #000;
padding: 2px;
}
.circle:before{
text-align: center;
height: 90px;
width: 90px;
content: '';
position: absolute;
top:30px;
left:0px;
right:0px;
bottom: 0px;
border: 20px solid #fff;
border-radius:50%;
animation: animate 5s linear infinite;
}
@keyframes animate{
0%{
box-shadow: 0 0 50px #0f0,0 0 50px #0f0 inset;
filter: hue-rotate(0deg);
}
20%{
box-shadow: 0 0 60px #0f0,0 0 60px #0f0 inset;
}
40%{
box-shadow: 0 0 40px #0f0,0 0 40px #0f0 inset;
}
60%{
box-shadow: 0 0 80px #0f0,0 0 80px #0f0 inset;
}
80%{
box-shadow: 0 0 100px #0f0,0 0 100px #0f0 inset;
}
100%{
box-shadow: 0 0 50px #0f0,0 0 50px #0f0 inset;
filter: hue-rotate(360deg);
}
}
svg{
width:0;
height:0;
}
#scaled-menu-container {
user-select: none;
font-size: 14px;
overflow: hidden;
color: #fff;
font-family: Verdana,sans-serif;
box-sizing: border-box;
position: fixed;
top: 50%;
left: 50%;
height: 366px;
width: 500px;
margin-top: -183px;
margin-left: -250px;
z-index: 2147000000;
}
#scaled-main-menu {
font-size: 12px;
user-select: none;
background-color: rgba(100, 100, 100, 0.4);
color: #fff;
font-family: Verdana,sans-serif;
box-sizing: border-box;
position: relative;
height: 100%;
padding: .5em 1em;
border-top: none;
margin-left: 130px;
}
#scaled-proxies-menu {
font-size: 12px;
user-select: none;
color: #fff;
font-family: Verdana,sans-serif;
background-color: rgba(100, 100, 100, 0.4);
box-sizing: border-box;
position: relative;
height: 100%;
padding: .5em 1em;
border-top: none;
margin-left: 130px;
}
#scaled-assets-menu {
font-size: 12px;
user-select: none;
color: #fff;
font-family: Verdana,sans-serif;
background-color: rgba(100, 100, 100, 0.4);
box-sizing: border-box;
position: relative;
height: 100%;
padding: .5em 1em;
border-top: none;
margin-left: 130px;
}
#scaled-config-menu {
font-size: 12px;
user-select: none;
color: #fff;
font-family: Verdana,sans-serif;
background-color: rgba(100, 100, 100, 0.4);
box-sizing: border-box;
position: relative;
height: 100%;
padding: .5em 1em;
border-top: none;
margin-left: 130px;
}
#scaled-bots-menu {
font-size: 12px;
user-select: none;
color: #fff;
font-family: Verdana,sans-serif;
background-color: rgba(100, 100, 100, 0.4);
box-sizing: border-box;
position: relative;
height: 100%;
padding: .5em 1em;
border-top: none;
margin-left: 130px;
}
#scaled-addons-menu {
font-size: 12px;
user-select: none;
color: #fff;
font-family: Verdana,sans-serif;
background-color: rgba(100, 100, 100, 0.4);
box-sizing: border-box;
position: relative;
height: 100%;
padding: .5em 1em;
border-top: none;
margin-left: 130px;
}
.i-tab-content {
font-size: 12px;
user-select: none;
color: #fff;
font-family: Verdana,sans-serif;
box-sizing: border-box;
width: 100%;
height: 100%;
background-color: rgba(100, 100, 100, 0.4)
}
.i-tab-menu, .sidebar {
font-size: 12px;
user-select: none;
color: #fff;
font-family: Verdana,sans-serif;
box-sizing: border-box;
position: relative;
background-color: rgba(120, 120, 120, 0.4);
display: block;
overflow: auto;
float: left;
width: 130px;
height: 100%;
box-shadow: 0 2px 5px 0 rgba(0,0,0,.16),0 2px 10px 0 rgba(0,0,0,.12);
}
.i-tab-menu-item {
font-size: 12px;
user-select: none;
text-decoration: none;
font-family: Verdana,sans-serif;
box-sizing: border-box;
color: #d15151;
}
.i-tab-menu-item:hover {
background-color: rgb(77, 73, 73, 0.5)
!important;
}
#scaled-main-menu-item {
user-select: none;
color: #fff;
font-family: Verdana,sans-serif;
box-sizing: border-box;
float: left;
background-color: inherit;
padding: 8px 8px;
margin: 0;
border: none;
font-size: 14px;
text-align: center;
outline: 0;
transition: .3s;
width: 100%;
}
#scaled-proxies-menu-item {
user-select: none;
color: #fff;
font-family: Verdana,sans-serif;
box-sizing: border-box;
float: left;
background-color: inherit;
padding: 8px 8px;
margin: 0;
border: none;
font-size: 14px;
text-align: center;
outline: 0;
transition: .3s;
width: 100%;
}
#scaled-assets-menu-item {
user-select: none;
color: #fff;
font-family: Verdana,sans-serif;
box-sizing: border-box;
float: left;
background-color: inherit;
padding: 8px 8px;
margin: 0;
border: none;
font-size: 14px;
text-align: center;
outline: 0;
transition: .3s;
width: 100%;
}
#scaled-addons-menu-item {
user-select: none;
color: #fff;
font-family: Verdana,sans-serif;
box-sizing: border-box;
float: left;
background-color: inherit;
padding: 8px 8px;
margin: 0;
border: none;
font-size: 14px;
text-align: center;
outline: 0;
transition: .3s;
width: 100%;
}
#scaled-config-menu-item {
user-select: none;
color: #fff;
font-family: Verdana,sans-serif;
box-sizing: border-box;
float: left;
background-color: inherit;
padding: 8px 8px;
margin: 0;
border: none;
font-size: 14px;
text-align: center;
outline: 0;
transition: .3s;
width: 100%;
}
#scaled-bots-menu-item {
user-select: none;
color: #fff;
font-family: Verdana,sans-serif;
box-sizing: border-box;
float: left;
background-color: inherit;
padding: 8px 8px;
margin: 0;
border: none;
font-size: 14px;
text-align: center;
outline: 0;
transition: .3s;
width: 100%;
}
.i-tab-menu-item {
user-select: none;
color: #fff;
font-family: Verdana,sans-serif;
box-sizing: border-box;
float: left;
background-color: inherit;
padding: 8px 8px;
margin: 0;
border: none;
font-size: 14px;
text-align: center;
outline: 0;
transition: .3s;
width: 100%;
}
.is-active {
background-color: rgb(140, 0, 255, 0.5) !important;
}
label {
cursor: default;
}
.wincontainer {
background-color: rgba(53, 53, 53, 1);
}
#windows > div, .winframe {
position: absolute;
pointer-events: auto;
background-color: rgb(22, 21, 21);
border: 11px solid rgb(22, 21, 21);
border-width: 11px;
-o-border-image: url(https://raw.githubusercontent.com/scar17off/OSM-2-packages/main/packages/assets/window_out.png) 11 repeat;
border-image: url(https://raw.githubusercontent.com/scar17off/OSM-2-packages/main/packages/assets/window_out.png) 11 repeat;
border-image-outset: 1px;
}
button[id^="tool-"]:not(.selected) > div {
background-image: url("https://github.com/scar17off/OSM-2-packages/blob/main/packages/assets/scaledbottoolset.png?raw=true") !important;
background-color: rgba(69, 69, 69, 1);
}
*[id^="scaled-"] {
font-family: 'Hammersmith One';
font-size: 13px;
-webkit-touch-callout: none;
-webkit-user-select: none;
-khtml-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
fieldset {
display: block;
margin-inline-start: 2px;
margin-inline-end: 2px;
padding-block-start: 0.35em;
padding-inline-start: 0.75em;
padding-inline-end: 0.75em;
padding-block-end: 0.625em;
min-inline-size: min-content;
border-width: 2px;
border-style: groove;
border-image: initial;
border-color: rgba(115, 115, 115, 1);
}
button[id^="scaled"] {
border-width: 1px;
border-style: groove;
border-image: initial;
border-color: rgba(115, 115, 115, 1);
border: solid 1px;
background-color: #292929;
color: #919191;
}`;
menu.innerHTML = `
<div id="scaled-content">
<div class="circle">
<svg>
<filter id = "wavy">
<feTurbulence x="0" y="0" baseFrequency="0.5" numOctaves="5" seed="7"/>
<feDisplacementMap in="SourceGraphic" scale="30"/>
</filter>
</svg>
</div>
<div class="i-tab-menu sidebar">
<a><h2 class="i-tab-menu-item">Scaled Bot</h2></a>
<button id="scaled-main-menu-item" class="i-tab-menu-item">Main</button>
<button id="scaled-proxies-menu-item" class="i-tab-menu-item">Proxies</button>
<button id="scaled-assets-menu-item" class="i-tab-menu-item">Assets</button>
<button id="scaled-bots-menu-item" class="i-tab-menu-item">Bots</button>
<button id="scaled-addons-menu-item" class="i-tab-menu-item">Addons</button>
<button id="scaled-config-menu-item" class="i-tab-menu-item">Config</button>
<a><h1 id="scaled-made-by-item" class="i-tab-menu-item" title="made with love">Made by <a href="https://discord.gg/PRhsxYvWHq">scar17off</a>.</h2></a>
<a><h1 class="i-tab-menu-item"><span id="scaled-info-menu">0 bots, 0.00 chunks </span></h2></a>
</div>
<div id="scaled-main-menu">
<form>
<fieldset>
<legend>Connection Options</legend>
<div><input type="number" id="scaled-main-menu-botcount" style="width: 240; border: solid 1px;background-color: #292929; color: #919191; user-select: none;" placeholder="Count" value="5" id="scaled-main-menu-botcount" title="Number of bots to connect."></input></div>
<div><input type="checkbox" id="scaled-main-menu-captcharender" name="usecaptcharenderer"></input><label>Captcha Renderer</label></div>
<div><input type="checkbox" id="scaled-main-menu-autoreconnect" name="useautoreconnect"></input><label>Auto Reconnect</label></div>
<div><input type="checkbox" id="scaled-main-menu-autopassword" name="autopasswordenabler"></input><label>Auto Password</label></div>
<div><input type="checkbox" id="scaled-main-menu-autologin" name="autologinenabler"></input><label title="Automatically log ins as Admin or Moderator.">Auto Login</label></div>
<div><input type="checkbox" id="scaled-main-menu-autonickname" name="autonicknameenabler"></input><label title="Automatically sets bot nickname.">Auto Nickname</label></div>
</fieldset>
</form>
<hr>
<form>
<fieldset>
<legend>Bot Connection</legend>
<div><button id="scaled-main-menu-connect">Connect</button>
<button id="scaled-main-menu-disconnect">Disconnect</button></div>
</fieldset>
</form>
<hr>
<form>
<fieldset>
<legend>Follow Options</legend>
<div>
<select style="width: 240; font-size: 13px; border: solid 1px; background-color: #292929; color: #919191;" title="Follow select" id="scaled-main-menu-followselect">
<option>Circle</option>
<option>Disk</option>
<option>Atom</option>
<option>Random</option>
<option>Wave</option>
<option>Right-Left</option>
<option>Hyperbola</option>
<option>BotLine</option>
<option>X</option>
<option>Spiral</option>
<option>Cool</option>
<option>Disk 2</option>
<option>Top-Bottom</option>
<option>Laggy</option>
<option>Small Circle</option>
<option>8</option>
<option>Cool 2</option>
<option>3D</option>
<option>Flower</option>
<option>Infinity</option>
<option>Infinity 2</option>
<option>Square</option>
<option>Default 2</option>
<option>Disk 3</option>
<option>Saturn</option>
<option>Triagle</option>
<option>Storm</option>
<option>Disk 4</option>
</select>
<div><input type="checkbox" id="scaled-main-menu-follow" name="followenable">Follow</input></div>
<div><input type="checkbox" id="scaled-main-menu-paintfollow" name="paintfollowenable">Paint Follow</input></div>
</div>
</fieldset>
</form>
<hr>
<form>
<fieldset>
<legend>Chat</legend>
<div><input id="scaled-main-menu-send" placeholder="Message to send" title="Send" style="width: 240; border: solid 1px;background-color: #292929; color: #919191; user-select: none;"></input>
<button id="scaled-main-menu-botsend">Send</button></div>
</fieldset>
</form>
<hr>
<form>
<fieldset>
<legend>Paste Options</legend>
<div><label>Asset Paster Pattern</label>
<select style="width: 240px; font-size: 13px; border: solid 1px; background-color: #292929; color: #919191;" id="scaled-main-menu-assetpasterpattern">
<option>Default</option>
<option>Random</option>
<option>Left - Up</option>
<option>Grid</option>
<option>Square</option>
</select>
</div>
<div><label>Bot Area Pattern</label>
<select style="width: 240px; font-size: 13px; border: solid 1px; background-color: #292929; color: #919191;" id="scaled-main-menu-areapattern">
<option>Default</option>
<option>Top - Bottom</option>
<option>Random</option>
</select>
</div>
<div><label>Chunker Pattern</label>
<select style="width: 240px; font-size: 13px; border: solid 1px; background-color: #292929; color: #919191;" id="scaled-main-menu-eraserpattern">
<option>Top - Bottom</option>
<option>Left - Right</option>
<option>Perfect</option>
</select>
</div>
<div><input type="checkbox" id="scaled-main-menu-oldpaste" name="oldpasteenabler"></input><label title="Old Paste">Old Paste</label></div>
<div><input type="checkbox" id="scaled-main-menu-wolfmove" name="wolfmoveenabler"></input><label title="WolfMove">Wolf Move</label></div>
<div><input type="checkbox" id="scaled-main-menu-useplayer" name="useplayerenabler"></input><label title="UsePlayer">Use player</label></div>
</fieldset>
</form>
</div>
<div id="scaled-proxies-menu">
<form>
<fieldset>
<div><input id="scaled-proxies-menu-addproxy" placeholder="xxxx-yyyy" title="Enter your proxy here." style="width: 150px; height: 14px; border: solid 1px;background-color: #292929; color: #919191; user-select: none;"></input>
<button id="scaled-proxies-menu-add">Add</button>
<button id="scaled-proxies-menu-refresh">Refresh</button>
<button id="scaled-proxies-menu-delall">Delete all</button>
<button id="scaled-proxies-menu-conall">Connect all</button>
<br>
<label>Count: ${allproxy}</label>
<label id="scaled-proxies-menu-onlineproxy">Online proxies: ${onlineproxy}</label>
<label id="scaled-proxies-menu-offlineproxy">Offline proxies: ${offlineproxy}</label>
<label id="scaled-proxies-menu-checkingproxy">Checking proxy: ${checkingproxy}</label>
</div>
</fieldset>
</form>
<hr>
<table id="scaled-proxies-menu-list">
<tr id="scaled-proxies-menu-tr"><th id="scaled-proxies-menu-proxy">Proxy</th><th id="scaled-proxies-menu-status">Status</th><th id="scaled-proxies-menu-connections">Connections</th><th id="scaled-proxies-menu-actions">Actions</th>
</tr>
</table>
</div>
<div id="scaled-assets-menu">
<form>
<fieldset>
<div><button id="scaled-assets-menu-addasset" class="scaled-assets-menu">Add asset</button>
<button id="scaled-assets-menu-clear" class="scaled-assets-menu">Clear</button></div>
</fieldset>
</form>
<form>
<fieldset>
<div id="scaled-assets-menu-assetlist"></div>
</fieldset>
</form>
</div>
<div id="scaled-config-menu">
<div><input id="scaled-config-menu-config-proxies" style="border: 1px solid; background-color: #292929; color: #919191; margin: 0px; width: 510px; height: 16px;" placeholder="Proxy Passwords" value=${localStorage.scaled_proxies}></input></div>
<div><input type="number" id="scaled-config-menu-config-followint" style="border: 1px solid; background-color: #292929; color: #919191; margin: 0px; width: 510px; height: 16px;" placeholder="Follow Interval (ms)" value=${localStorage.scaled_followinterval}></input></div>
<div><input id="scaled-config-menu-config-botnick" style="border: 1px solid; background-color: #292929; color: #919191; margin: 0px; width: 510px; height: 16px;" placeholder="Bot nickname." value=${localStorage.scaled_botnick}></input></div>
</div>
<div id="scaled-bots-menu">
<form>
<fieldset>
<table id="scaled-bots-menu-list">
<tr id="scaled-bots-menu-tr">
<th id="scaled-bots-menu-id">Id</th><th id="scaled-bots-menu-x">X</th><th id="scaled-bots-menu-y">Y</th><th id="scaled-bots-menu-pq">PQuota</th><th id="scaled-bots-menu-color">Color</th><th id="scaled-bots-menu-ws">WS</th><th id="scaled-bots-menu-actions">Actions</th>
</tr>
</table>
</fieldset>
</form>
</div>
<div id="scaled-addons-menu">
<form>
<fieldset>
<div>
<select style="width: 240px; font-size: 13px; border: solid 1px; background-color: #292929; color: #919191;" id="scaled-addons-menu-list">
<option>Chunker with queue</option>
<option>Chess chunker</option>
</select>
<button id="scaled-addons-menu-load">Load</button>
</div>
<div>
<input id="scaled-addons-menu-url" style="border: 1px solid; background-color: #292929; color: #919191; margin: 0px; width: 430px; height: 16px;" placeholder="Link to raw addon."></input>
<button id="scaled-addons-menu-exec">Execute</button>
</div>
</fieldset>
</form>
</div>
</div>
`;
win.addObj(menu);
win.addObj(styles);
cont = win.container;
cont.style.height = height;
cont.style.maxHeight = height;
cont.style.width = width;
}).move(75, 75));
setInterval(() => {
document.getElementById("scaled-proxies-menu-onlineproxy").innerText = `Online proxies: ${onlineproxy}`;
document.getElementById("scaled-proxies-menu-offlineproxy").innerText = `Offline proxies: ${offlineproxy}`;
document.getElementById("scaled-proxies-menu-checkingproxy").innerText = `Checking proxies: ${checkingproxy}`;
}, 25);
document.getElementById("scaled-addons-menu-load").onclick = async () => {
let val = document.getElementById("scaled-addons-menu-list").value;
if (val === "Chunker with queue") loadAddon("chunkerwithqueue");
if (val === "Chess chunker") loadAddon("chesschunker");
};
function loadAddon(url) {
let xhttpt = new XMLHttpRequest();
xhttpt.open("GET", `https://raw.githubusercontent.com/scar17off/OSM-2-packages/main/packages/scaled-addons/${url}.js`);
xhttpt.responseType = "text";
xhttpt.addEventListener("load", function() {
eval(xhttpt.response);
});
xhttpt.send();
};
document.getElementById("scaled-main-menu-disconnect").onclick = async () => {
for (let i in BOTS) BOTS[i].ws.close();
BOTS = [];
};
document.getElementById("scaled-main-menu-eraserpattern").onchange = () => {
let val = document.getElementById("scaled-main-menu-eraserpattern").value;
if (val === "Left - Right") eraserpattern = eraserpatterns.lr;
if (val === "Top - Bottom") eraserpattern = eraserpatterns.tb;
if (val === "Perfect") eraserpattern = eraserpatterns.perfect;
};
document.getElementById("scaled-proxies-menu-conall").onclick = () => {
for (let i in ProxyPasswords) {
let Proxy = ProxyPasswords[i];
document.getElementById(`scaled-proxy-proxyjoin-${Proxy}`).click();
};
};
document.getElementById("scaled-main-menu-areapattern").onchange = () => {
let val = document.getElementById("scaled-main-menu-areapattern").value;
if (val === "Default") pattern = patterns.lr;
if (val === "Top - Bottom") pattern = patterns.tb;
if (val === "Random") pattern = patterns.rand;
};
document.getElementById("scaled-main-menu-assetpasterpattern").onchange = () => {
let val = document.getElementById("scaled-main-menu-assetpasterpattern").value;
if (val == "Default") imgpattern = imgpatterns.default;
if (val == "Left - Up") imgpattern = imgpatterns.leftup;
if (val == "Grid") imgpattern = imgpatterns.grid;
if (val == "Square") imgpattern = imgpatterns.square;
if (val == "Random") imgpattern = imgpatterns.random;
};
document.getElementById("scaled-main-menu-oldpaste").onchange = async () => {
if (!OldPaste) {
OldPaste = true;
} else {
OldPaste = false;
};
};
document.getElementById("scaled-main-menu-wolfmove").onchange = async () => {
if (!wolfmove) {
wolfmove = true;
} else {
wolfmove = false;
};
};
document.getElementById("scaled-main-menu-useplayer").onchange = async () => {
if (!useplayer) {
useplayer = true;
} else {
useplayer = false;
};
};
document.getElementById("scaled-main-menu-captcharender").onchange = async () => {
if (!rendercaptchaen) {
rendercaptchaen = true;
} else {
rendercaptchaen = false;
};
};
document.getElementById("scaled-assets-menu-clear").onclick = async () => {
localStorage.scaled_assets = [];
refreshAssets();
};
document.getElementById("scaled-main-menu-paintfollow").onchange = async () => {
if (!paintfollow) {
paintfollow = true;
} else {
paintfollow = false;
};
};
let botcount = 0;
setInterval(() => {
let o = 0;
for (let i in BOTS) {
o += BOTS[i].utils.bucket.allowance;
botcount = BOTS.filter(BOT => BOT.ws.readyState === 1).length;
};
let botchunks = (o / 256).toFixed(2);
document.getElementById("scaled-info-menu").innerText = botcount + ` bots, ` + botchunks + ` chunks`;
}, 25);
document.getElementById("scaled-main-menu-autopassword").onclick = async () => {
if (!AutoPassword) {
AutoPassword = true;
} else {
AutoPassword = false;
};
};
document.getElementById("scaled-main-menu-autonickname").onclick = async () => {
if (!AutoNickname) {
AutoNickname = true;
} else {
AutoNickname = false;
};
};
document.getElementById("scaled-proxies-menu-add").onclick = async () => {
let prox = document.getElementById("scaled-proxies-menu-addproxy").value;
if (prox == "") return;
ProxyPasswords.push(prox);
localStorage.scaled_proxies += ","+prox;
updateServers();
};
document.getElementById("scaled-main-menu-autologin").onchange = async () => {
if (!AutoLogin) {
AutoLogin = true;
} else {
AutoLogin = false;
};
};
document.getElementById("scaled-main-menu-botsend").onclick = async () => {
for (let i = 0; i < BOTS.length; i++) BOTS[i].chat.send(document.getElementById("scaled-main-menu-send").value);
};
document.getElementById("scaled-proxies-menu-delall").onclick = async () => {
localStorage.scaled_proxies = "";
ProxyPasswords = [];
updateServers();
};
document.getElementById("scaled-proxies-menu-refresh").onclick = async () => {
updateServers();
allproxy = ProxyPasswords.length;
offlineproxy = 0;
onlineproxy = 0;
checkingproxy = allproxy
};
document.getElementById("scaled-main-menu-connect").onclick = async () => {
let BotCount = parseFloat(document.getElementById("scaled-main-menu-botcount").value);
for (let i = 0; i < BotCount; i++) {
const ofo = BOTS.length + 0;
BOTS[ofo] = new OJS({
ind: ofo,
controller: true
});
//BOTS[ofo].ws.onopen = () => {
// if(AutoLogin = true){
// if(localStorage.adminlogin) {
// BOTS[ofo].chat.send(`/adminlogin ${localStorage.adminlogin}`);
// };
// };
// if(AutoPassword = true) {
// if(AutoPassword && JSON.parse(localStorage.worldPasswords)[OWOP.world.name]) BOTS[ofo].chat.send(`/pass ${JSON.parse(localStorage.worldPasswords)[OWOP.world.name]}`); };
// if(AutoNickname = true) {
// BOTS[ofo].chat.send(`/nickname ${localStorage.scaled_botnick}`);
// };
//};
}
};
let PI2 = 3 * Math.PI,
FOLLOWADD = PI2 / 45,
f = 0,
x, y,
offset = 0,
state = 1, a = 0
let spiral = {
step: 0,
PI2: 2 * Math.PI,
speed: ()=>((2 * Math.PI) / 30 / BOTS.length),
radius: (i) => i * 3
};
document.getElementById("scaled-main-menu-follow").onchange = () => {
if (!following) {
following = true;
folint = setInterval(() => {
let pos = {
x: OWOP.mouse.tileX,
y: OWOP.mouse.tileY
},
i = BOTS.length;
while (i--) {
if (animation === animations.hyperbola) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
x = pos.x + Math.tan(2 * Math.PI * 2 / BOTS.length * i + f * BOTS.length);
y = pos.y + 1 / Math.tan(2 * Math.PI * 2 / BOTS.length * i + f * BOTS.length);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.line) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
x = pos.x + (Math.cos(2 * Math.PI * 2 ** BOTS.length * i + f) * BOTS.length);
y = pos.y + (Math.sin(2 * Math.PI * 2 / BOTS.length * i + f) * BOTS.length);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.wave) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
x = pos.x + (Math.cos(2 * Math.PI / BOTS.length * i + f) * BOTS.length);
y = pos.y + (Math.sin(2 * Math.PI * 2 / BOTS.length * i + f) * BOTS.length);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.random) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
x = pos.x + (Math.cos(2 * Math.PI * 2 / BOTS.length - i + f) * BOTS.length);
y = pos.y + (Math.sin(2 * Math.PI * 2 / BOTS.length * i + f) * BOTS.length);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.atom) {
if (i >= BOTS.length / 2) {
x = pos.x + (Math.cos(2 * Math.PI * 2 / BOTS.length * i + f) * BOTS.length / 2),
y = pos.y + (Math.sin(2 * Math.PI * 2 / BOTS.length * i + f + 2) * BOTS.length / 2);
if (!BOTS[i].options.isJoined) continue;
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
x = pos.x + (Math.cos(2 * Math.PI * 2 / BOTS.length * i + f + 2) * BOTS.length / 2);
y = pos.y + (Math.sin(2 * Math.PI * 2 / BOTS.length * i + f) * BOTS.length / 2);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
}
} else if (animation === animations.circle) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
x = pos.x + (Math.cos(2 * Math.PI * 2 / BOTS.length * i + f) * BOTS.length);
y = pos.y + (Math.sin(2 * Math.PI * 2 / BOTS.length * i + f) * BOTS.length);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.disk) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
x = pos.x + (Math.cos(2 * Math.PI * 2 / BOTS.length * i + f * 2) * BOTS.length);
y = pos.y + (Math.sin(2 * Math.PI * 2 / BOTS.length * i + f) * BOTS.length);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.botline) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
x = pos.x + i * 2;
y = pos.y;
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.x) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
let r = 2 * Math.PI * 2 / BOTS.length * i + f;
if (i % 2 == 0) {
let s = Math.sin(r);
y = pos.y + (Math.cos(r) * 3 + 15 * s);
x = pos.x + (s * 15 + 3 * s);
} else {
let c = Math.cos(r)
x = pos.x + (c * 8 + 9 * c);
y = pos.y + (Math.sin(r) * 3 + -15 * c);
}
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.spiral) {
let speed = spiral.speed();
let radius = spiral.radius(i);
x = Math.cos(Math.PI / BOTS.length * i + spiral.step) * radius;
y = Math.sin(Math.PI / BOTS.length * i + spiral.step) * radius;
x += pos.x
y += pos.y
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
spiral.step += speed;
spiral.step %= spiral.PI2;
} else if (animation === animations.cool) {
x = pos.x + Math.cos(((Math.PI * 2 / BOTS.length) * i) + offset) * (radius * 16);
y = pos.y + Math.sin(((Math.PI * 2 / BOTS.length) * i) + offset) * (radius * 16);
offset += ((Math.PI * 2) / 100) / BOTS.length;
if (state === 1) {
radius -= 0.01;
if (radius <= 0.1) state = 2;
} else {
radius += 0.01;
if (radius >= BOTS.length * 0.1) state = 1
}
if (offset > Math.PI * 2) offset = 0;
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.disktwo) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
x = pos.x + (Math.cos(2 * Math.PI * 2 / 4.09 * i + f * 2) * 4.09);
y = pos.y + (Math.sin(2 * Math.PI * 2 / 4.09 * i + f) * 4.09);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.topbottom) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
x = pos.x + (Math.sin(2 * Math.PI * 2 / BOTS.length * i + f) * BOTS.length);
y = pos.y + (Math.cos(2 * Math.PI * 2 ** BOTS.length * i + f) * BOTS.length);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.laggy) {
if (i >= BOTS.length / 2) {
x = pos.x + (Math.cos(2 * Math.PI * 2 / 3.5 * i + f) * 3.5 / 2),
y = pos.y + (Math.sin(2 * Math.PI * 2 / 3.5 * i + f + 2) * 3.5 / 2);
if (!BOTS[i].options.isJoined) continue;
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
x = pos.x + (Math.cos(2 * Math.PI * 2 / 4.05 * i + f + 2) * 4.0909 / 2);
y = pos.y + (Math.sin(2 * Math.PI * 2 / 4.05 * i + f) * 4.09 / 2);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
}
} else if (animation === animations.smallcircle) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
x = pos.x + (Math.cos(2 * Math.PI * 2 / 4.35 * i + f) * 4.35);
y = pos.y + (Math.sin(2 * Math.PI * 2 / 4.35 * i + f) * 4.35);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.eight) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
x = pos.x + (Math.sin(10 * Math.PI / BOTS.length * i * f) * BOTS.length / 1.768);
y = pos.y + (Math.cos(5 * Math.PI / BOTS.length * i * f) * BOTS.length / 1.768);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.cool2) {
if (i >= BOTS.length / 2) {
x = pos.x + (Math.cos(8 * Math.PI * 2 / BOTS.length + 5 * i + f) * BOTS.length / 4),
y = pos.y + (Math.sin(8 * Math.PI * 2 / BOTS.length + 5 * i + f + 10) * BOTS.length / 4);
if (!BOTS[i].options.isJoined) continue;
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
x = pos.x + (Math.cos(1.1 * Math.PI * 2 / BOTS.length + 5 * i + f + 10) * BOTS.length / 4);
y = pos.y + (Math.sin(1.1 * Math.PI * 2 / BOTS.length + 5 * i + f) * BOTS.length / 4);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
}
} else if (animation === animations.threed) {
if (i >= BOTS.length / 2) {
y = pos.y + Math.cos(2 * Math.PI / BOTS * i + f) * 40;
x = pos.x + Math.sin(2 * Math.PI * 2 / BOTS * i + f) * 40;
if (!BOTS[i].options.isJoined) continue;
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
x = pos.x + (Math.cos(2 * Math.PI * 4 / 4.09 * i + f * 2.5) * 9); // 4.09, 4.09
y = pos.y + (Math.sin(2 * Math.PI * 2 / 4.09 * i + f) * 9); // 4.09, 4.09
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
}
} else if (animation === animations.flower) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
if (state === 1) {
radius121 -= 0.1;
localStorage.buxxed_followint - 1;
if (radius121 <= 1) {
state = 2
}
} else {
radius121 += 0.2;
localStorage.buxxed_followint + 2;
if (radius121 >= 10) {
state = 1
}
}
if (state == 2) {
x = pos.x + (Math.cos(2 * Math.PI * 2 / BOTS.length * i + f) * radius121);
y = pos.y + (Math.sin(2 * Math.PI * 2 / BOTS.length * i + f) * radius121);
} else {
x = pos.x + (Math.cos(2 * Math.PI * 2 / BOTS.length * i - f) * radius121);
y = pos.y + (Math.sin(2 * Math.PI * 2 / BOTS.length * i - f) * radius121);
}
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.square) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
a = spiral.PI2 / BOTS[i].length * i + f;
x = pos.x + squareX(f / 40 * i + f) * BOTS.length / 1.285;
y = pos.y + squareY(f / 40 * i + f) * BOTS.length / 1.285;
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.infinity) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
a = spiral.PI2 / BOTS[i].length * i + f;
x = pos.x + infinityX(f / 20 * i + f) * 40;
y = pos.y + infinityY(f / 20 * i + f) * 40;
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.infinity2) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
a = spiral.PI2 / BOTS[i].length * i + f;
x = pos.x + infinityX(f / 20 * i + f) * 40;
y = pos.y + infinityY(f / 20 * i + f) * 40;
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.default2) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
let x1;
let y1;
let x;
let y;
if (i >= BOTS.length / 2) {
x1 = pos.x + (Math.cos(2 * Math.PI * 2 / (BOTS.length / 2) * i) * (BOTS.length / 2));
y1 = pos.y + (Math.sin(2 * Math.PI * 2 / (BOTS.length / 2) * i) * (BOTS.length / 2));
x = x1 + (Math.cos(2 * Math.PI * 2 / 4 * i + f) * 4);
y = y1 + (Math.sin(2 * Math.PI * 2 / 4 * i + f) * 4);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else {
x = pos.x + (Math.cos(2 * Math.PI * 2 / (BOTS.length / 2) * i) * (BOTS.length / 2));
y = pos.y + (Math.sin(2 * Math.PI * 2 / (BOTS.length / 2) * i) * (BOTS.length / 2));
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
}
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.saturn) {
let t = 2 * Math.PI * 2 / BOTS.length * i + f1;
if (i <= BOTS.length / 2) {
let x = pos.x + (Math.cos(t + 2) * BOTS.length / (BOTS.length / 10))
let y = pos.y + (Math.sin(t) * BOTS.length / (BOTS.length / 10));
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else {
let x = pos.x + (Math.cos(t) * BOTS.length / (BOTS.length / 10))
let y = pos.y + (Math.sin(t) * BOTS.length / (BOTS.length / 10));
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
}
} else if (animation === animations.disk3) {
let t = Math.PI * 2 / BOTS.length * i + f;
let t1 = Math.PI / BOTS.length * i + f;
x = pos.x + (2 * Math.sin(t) + Math.sin(2 * t1)) * BOTS.length / 2;
y = pos.y + (2 * Math.cos(t) - Math.cos(2 * t1)) * BOTS.length / 2;
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.triagle) {
if (!BOTS[i]) return;
if (!BOTS[i].options.isJoined) continue;
let t = Math.PI * 2 / BOTS.length * i + f;
x = pos.x + (2 * Math.sin(t) + Math.sin(2 * (t))) * BOTS.length / 2;
y = pos.y + (2 * Math.cos(t) - Math.cos(2 * (t))) * BOTS.length / 2;
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.storm) {
let t = Math.PI * 2 / BOTS.length * i - f;
let t1 = Math.PI * 3 / BOTS.length * i + f;
x1 = pos.x + (Math.cos(2 * t) * BOTS.length);
y1 = pos.y + (Math.sin(2 * t) * BOTS.length);
x = x1 + (Math.cos(3 * t) * BOTS.length);
y = y1 + (Math.sin(3 * t) * BOTS.length);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].world.setPixel(x, y, OWOP.player.selectedColor)
} else if (animation === animations.disk4) {
y = pos.y + 40 * Math.cos(angle + f);
x = pos.x + 40 * Math.sin(angle);
BOTS[i].world.move(x, y);
if (paintfollow) BOTS[i].wold.setP(x, y, OWOP.player.selectedColor);
}
};
if(animation === animations.infinity) {
FOLLOWADD = PI2 / 100;
f = (f + FOLLOWADD);
} else if(animation === animations.infinity2) {
FOLLOWADD = PI2 / 95;
f = (f + FOLLOWADD);
} else if(animation === animations.eight) {
FOLLOWADD = PI2 / 500;
f = (f + FOLLOWADD) % PI2;
} else {
FOLLOWADD = PI2 / 45;
f = (f + FOLLOWADD) % PI2;
}
}, parseInt(localStorage.scaled_followinterval));
} else {
following = false;
clearInterval(folint);
};
};
document.getElementById("scaled-main-menu-followselect").onchange = () => {
let val = document.getElementById("scaled-main-menu-followselect").value;
if (val === "Circle") animation = animations.circle;
if (val === "Disk") animation = animations.disk;
if (val === "Atom") animation = animations.atom;
if (val === "Random") animation = animations.random;
if (val === "Wave") animation = animations.wave;
if (val === "Right-Left") animation = animations.line;
if (val === "Hyperbola") animation = animations.hyperbola;
if (val === "BotLine") animation = animations.botline;
if (val === "X") animation = animations.x;
if (val === "Spiral") animation = animations.spiral;
if (val === "Cool") animation = animations.cool;
if (val === "Disk 2") animation = animations.disktwo;
if (val === "Top-Bottom") animation = animations.topbottom;
if (val === "Laggy") animation = animations.laggy;
if (val === "Small Circle") animation = animations.smallcircle;
if (val === "8") animation = animations.eight;
if (val === "Cool 2") animation = animations.cool2;
if (val === "3D") animation = animations.threed;
if (val === "Flower") animation = animations.flower;
if (val === "Infinity") animation = animations.infinity;
if (val === "Infinity 2") animation = animations.infinity2;
if (val === "Square") animation = animations.square;
if (val === "Default 2") animation = animations.default2;
if (val === "Disk 3") animation = animations.disk3;
if (val === "Triagle") animation = animations.triagle;
if (val === "Saturn") animation = animations.saturn;
if (val === "Storm") animation = animations.storm;
if (val === "Disk 4") animation = animations.disk4;
};
document.getElementById("scaled-config-menu-config-proxies").onchange = () => {
let val = document.getElementById("scaled-config-menu-config-proxies").value;
localStorage.scaled_proxies = val;
};
document.getElementById("scaled-main-menu-autoreconnect").onchange = () => {
autoreconnecten = document.getElementById("scaled-config-menu-config-proxies").value;
};
document.getElementById("scaled-config-menu-config-botnick").onchange = () => {
let val = document.getElementById("scaled-config-menu-config-botnick").value;
localStorage.scaled_botnick = val;
};
document.getElementById("scaled-config-menu-config-followint").onchange = () => {
let val = document.getElementById("scaled-config-menu-config-followint").value;
localStorage.scaled_followinterval = val;
};
document.getElementById("scaled-assets-menu-addasset").onclick = async () => {
let assets = localStorage.scaled_assets;
if (!assets) assets = [];
else assets = JSON.parse(assets);
assets.push(await upload("image/*"));
localStorage.scaled_assets = JSON.stringify(assets);
refreshAssets();
};
updateServers();
// hidden
document.getElementById("scaled-main-menu").hidden = false;
document.getElementById("scaled-main-menu-item").classList.add("is-active");
document.getElementById("scaled-proxies-menu").hidden = true;
document.getElementById("scaled-proxies-menu-item").classList.remove("is-active");
document.getElementById("scaled-assets-menu").hidden = true;
document.getElementById("scaled-assets-menu-item").classList.remove("is-active");
document.getElementById("scaled-config-menu").hidden = true;
document.getElementById("scaled-config-menu-item").classList.remove("is-active");
document.getElementById("scaled-bots-menu").hidden = true;
document.getElementById("scaled-bots-menu-item").classList.remove("is-active");
document.getElementById("scaled-addons-menu").hidden = true;
document.getElementById("scaled-addons-menu-item").classList.remove("is-active");
// onclick
document.getElementById("scaled-main-menu-item").addEventListener("click", () => {
document.getElementById("scaled-main-menu").hidden = false;
document.getElementById("scaled-main-menu-item").classList.add("is-active");
document.getElementById("scaled-proxies-menu").hidden = true;
document.getElementById("scaled-proxies-menu-item").classList.remove("is-active");
document.getElementById("scaled-assets-menu").hidden = true;
document.getElementById("scaled-assets-menu-item").classList.remove("is-active");
document.getElementById("scaled-config-menu").hidden = true;
document.getElementById("scaled-config-menu-item").classList.remove("is-active");
document.getElementById("scaled-bots-menu").hidden = true;
document.getElementById("scaled-bots-menu-item").classList.remove("is-active");
document.getElementById("scaled-addons-menu").hidden = true;
document.getElementById("scaled-addons-menu-item").classList.remove("is-active");
});
document.getElementById("scaled-proxies-menu-item").addEventListener("click", () => {
document.getElementById("scaled-main-menu").hidden = true;
document.getElementById("scaled-main-menu-item").classList.remove("is-active");
document.getElementById("scaled-proxies-menu").hidden = false;
document.getElementById("scaled-proxies-menu-item").classList.add("is-active");
document.getElementById("scaled-assets-menu").hidden = true;
document.getElementById("scaled-assets-menu-item").classList.remove("is-active");
document.getElementById("scaled-config-menu").hidden = true;
document.getElementById("scaled-config-menu-item").classList.remove("is-active");
document.getElementById("scaled-bots-menu").hidden = true;
document.getElementById("scaled-bots-menu-item").classList.remove("is-active");
document.getElementById("scaled-addons-menu").hidden = true;
document.getElementById("scaled-addons-menu-item").classList.remove("is-active");
});
document.getElementById("scaled-assets-menu-item").addEventListener("click", () => {
refreshAssets();
document.getElementById("scaled-main-menu").hidden = true;
document.getElementById("scaled-main-menu-item").classList.remove("is-active");
document.getElementById("scaled-proxies-menu").hidden = true;
document.getElementById("scaled-proxies-menu-item").classList.remove("is-active");
document.getElementById("scaled-assets-menu").hidden = false;
document.getElementById("scaled-assets-menu-item").classList.add("is-active");
document.getElementById("scaled-config-menu").hidden = true;
document.getElementById("scaled-config-menu-item").classList.remove("is-active");
document.getElementById("scaled-bots-menu").hidden = true;
document.getElementById("scaled-bots-menu-item").classList.remove("is-active");
document.getElementById("scaled-addons-menu").hidden = true;
document.getElementById("scaled-addons-menu-item").classList.remove("is-active");
});
document.getElementById("scaled-config-menu-item").addEventListener("click", () => {
document.getElementById("scaled-main-menu").hidden = true;
document.getElementById("scaled-main-menu-item").classList.remove("is-active");
document.getElementById("scaled-proxies-menu").hidden = true;
document.getElementById("scaled-proxies-menu-item").classList.remove("is-active");
document.getElementById("scaled-assets-menu").hidden = true;
document.getElementById("scaled-assets-menu-item").classList.remove("is-active");
document.getElementById("scaled-config-menu").hidden = false;
document.getElementById("scaled-config-menu-item").classList.add("is-active");
document.getElementById("scaled-bots-menu").hidden = true;
document.getElementById("scaled-bots-menu-item").classList.remove("is-active");
document.getElementById("scaled-addons-menu").hidden = true;
document.getElementById("scaled-addons-menu-item").classList.remove("is-active");
});
document.getElementById("scaled-bots-menu-item").addEventListener("click", () => {
document.getElementById("scaled-main-menu").hidden = true;
document.getElementById("scaled-main-menu-item").classList.remove("is-active");
document.getElementById("scaled-proxies-menu").hidden = true;
document.getElementById("scaled-proxies-menu-item").classList.remove("is-active");
document.getElementById("scaled-assets-menu").hidden = true;
document.getElementById("scaled-assets-menu-item").classList.remove("is-active");
document.getElementById("scaled-config-menu").hidden = true;
document.getElementById("scaled-config-menu-item").classList.remove("is-active");
document.getElementById("scaled-bots-menu").hidden = false;
document.getElementById("scaled-bots-menu-item").classList.add("is-active");
document.getElementById("scaled-addons-menu").hidden = true;
document.getElementById("scaled-addons-menu-item").classList.remove("is-active");
});
document.getElementById("scaled-addons-menu-item").addEventListener("click", () => {
document.getElementById("scaled-main-menu").hidden = true;
document.getElementById("scaled-main-menu-item").classList.remove("is-active");
document.getElementById("scaled-proxies-menu").hidden = true;
document.getElementById("scaled-proxies-menu-item").classList.remove("is-active");
document.getElementById("scaled-assets-menu").hidden = true;
document.getElementById("scaled-assets-menu-item").classList.remove("is-active");
document.getElementById("scaled-config-menu").hidden = true;
document.getElementById("scaled-config-menu-item").classList.remove("is-active");
document.getElementById("scaled-bots-menu").hidden = true;
document.getElementById("scaled-bots-menu-item").classList.remove("is-active");
document.getElementById("scaled-addons-menu").hidden = false;
document.getElementById("scaled-addons-menu-item").classList.add("is-active");
});
OWOP.tools.addToolObject(new OWOP.tools.class("Bot Brush", OWOP.cursors.brush, OWOP.fx.player.RECT_SELECT_ALIGNED(1), OWOP.RANK.USER, tool => {
tool.setEvent("mousemove mousedown", async e => {
if (e.buttons !== 0)
for (let i = -1; i < 2; i++)
for (let j = -1; j < 2; j++)
if (!OWOP.world.setPixel(OWOP.mouse.tileX + i, OWOP.mouse.tileY + j, e.buttons === 1 ? OWOP.player.selectedColor : [255, 255, 255])) {
let abc = getFree();
if (Math.floor(BOTS[abc].utils.bucket.allowance) === 1) await sleep(42);
BOTS[abc].world.setPixel(OWOP.mouse.tileX + i, OWOP.mouse.tileY + j, e.buttons === 1 ? OWOP.player.selectedColor : [255, 255, 255]);
};
});
}));
let LastChunk = Date.now();
OWOP.tools.addToolObject(new OWOP.tools.class('Bot Chunker', OWOP.cursors.erase, OWOP.fx.player.RECT_SELECT_ALIGNED(16), false, function(tool) {
let queue = [];
let pix = 16;
const set = (x, y, color) => {
OWOP.mouse.lastX = x * 16;
OWOP.mouse.lastY = y * 16;
OWOP.world.setPixel(x, y, color);
};
const eq = (a, b) => a[0] === b[0] && a[1] === b[1] && a[2] === b[2];
const eq2 = function eq(a, b) {
return a && b && a[0] === b[0] && a[1] === b[1] && a[2] === b[2];
};
function clearChunk(chunkX, chunkY) {
for (let y = 0; y < 16; ++y) {
for (let x = 0; x < 16; ++x) {
let pos = [chunkX * 16 + x, chunkY * 16 + y];
if ((!eq(OWOP.world.getPixel(...pos), [255, 255, 255])) && (queue.filter(i => eq(i, pos)).length < 1)) {
queue.unshift(pos);
}
}
}
}
tool.setEvent('mousedown mousemove', function(mouse, event) {
if (mouse.buttons === 1) {
if (eraserpattern === eraserpatterns.tb) {
let brushercolor = OWOP.player.selectedColor;
let antx = Math.floor(OWOP.mouse.tileX / 16)
let anty = Math.floor(OWOP.mouse.tileY / 16)
let verx = antx * 16
let very = anty * 16
drawRectbrush(verx, very, 16, 16, brushercolor)
} else if (eraserpattern === eraserpatterns.lr) {
if (Date.now() - LastChunk < 100) return;
LastChunk = Date.now();
for (let i = 0; i < BOTS.length; i++) BOTS[i].options.busy = true;
let color = mouse.buttons === 1 ? OWOP.player.selectedColor : [255, 255, 255];
let chunkx = Math.floor(OWOP.mouse.tileX / pix) * pix;
let chunky = Math.floor(OWOP.mouse.tileY / pix) * pix;
let armor = pix * pix;
//console.log(armor)
for (let x = 0; x < pix; x++) {
for (let y = 0; y < pix; y++) {
const abc = getFree();
//if(BOTS[abc].utils.bucket.allowance === 0) await sleep(42);
BOTS[abc].world.setPixel(chunkx + x, chunky + y, color);
};
}
for (let i = 0; i < BOTS.length; i++) BOTS[i].options.busy = false;
} else if(eraserpattern === eraserpatterns.perfect) {
if (Date.now() - LastChunk < 100) return;
LastChunk = Date.now();
for (let i = 0; i < BOTS.length; i++) BOTS[i].options.busy = true;
let color = mouse.buttons === 1 ? OWOP.player.selectedColor : [255, 255, 255];
let chunkx = Math.floor(OWOP.mouse.tileX / pix) * pix;
let chunky = Math.floor(OWOP.mouse.tileY / pix) * pix;
let armor = pix * pix;
for (let y = 0; y < pix; ++y) {
for (let x = 0; x < pix; ++x) {
let abc = getFree();
BOTS[abc].utils.bucket.canSpend(0)
if(BOTS[abc].utils.bucket.allowance >= 1){
if((!eq2(OWOP.world.getPixel(chunkx + x, chunky + y), color))) {
BOTS[abc].world.setPixel(chunkx + x, chunky + y, color);
};
} else {
x--
};
};
};
for (let i = 0; i < BOTS.length; i++) BOTS[i].options.busy = false;
}
};
});
}));
OWOP.tools.addToolObject(new OWOP.tools.class('Bot Text', OWOP.cursors.write, OWOP.fx.player.RECT_SELECT_ALIGNED(1), false, function(tool) {
tool.setEvent('mousedown', function(mouse, event) {
if (mouse.buttons == 1 || mouse.buttons == 2) {
var text = prompt('Text to draw:');
writeText(text, mouse.tileX, mouse.tileY);
};
});
}));
OWOP.tools.addToolObject(new OWOP.tools.class("Bot Fill", OWOP.cursors.fill, OWOP.fx.player.NONE, OWOP.RANK.USER, e => {
e.extra.tickAmount = 30;
let t = [],
n = null,
o = OWOP.fx.player.RECT_SELECT_ALIGNED(1);
async function r() {
var o = function(e, t) {
return e && t && e[0] === t[0] && e[1] === t[1] && e[2] === t[2]
},
r = function(e, r) {
return !!o(OWOP.world.getPixel(e, r), n) && (t.unshift([e, r]),
!0)
};
if (t.length && n) {
var i = OWOP.player.selectedColor,
a = 0,
s = e.extra.tickAmount;
s *= 3;
for (a = 0; a < s && t.length; a++) {
var l = t.pop(),
u = l[0],
d = l[1],
f = OWOP.world.getPixel(u, d);
if (o(f, n) && !o(f, i)) {
if (!OWOP.world.setPixel(u, d, i)) {
let abc = getFree();
if (BOTS[abc].utils.bucket.allowance === 0) sleep(42).then(i => {
if (!BOTS[abc].world.setPixel(u, d, i)) t.push(l);
});
if (BOTS[abc].utils.bucket.allowance !== 0)
if (!BOTS[abc].world.setPixel(u, d, i)) t.push(l);
break
}
var p = r(u, d - 1),
m = r(u, d + 1),
v = r(u - 1, d),
g = r(u + 1, d);
p && v && r(u - 1, d - 1),
p && g && r(u + 1, d - 1),
m && v && r(u - 1, d + 1),
m && g && r(u + 1, d + 1)
}
}
}
}
e.setFxRenderer(function(e, r, i) {
r.globalAlpha = .8,
r.strokeStyle = e.extra.player.htmlRgb;
var a = OWOP.camera.zoom;
if (n && e.extra.isLocalPlayer) {
r.beginPath();
for (var s = 0; s < t.length; s++)
r.rect((t[s][0] - OWOP.camera.x) * a, (t[s][1] - OWOP.camera.y) * a, a, a);
r.stroke()
} else
o(e, r, i)
}),
e.setEvent("mousedown", function(o) {
4 & o.buttons || (n = OWOP.world.getPixel(o.tileX, o.tileY)) && (t.push([o.tileX, o.tileY]),
e.setEvent("tick", r))
}),
e.setEvent("mouseup deselect", function(o) {
o && 1 & o.buttons || (n = null,
t = [],
e.setEvent("tick", null))
});
}));
let aboab;
OWOP.tools.addToolObject(new OWOP.tools.class('Bot Area', OWOP.cursors.select, OWOP.fx.player.NONE, false, function(tool) {
tool.setFxRenderer(function(fx, ctx, time) {
if (!fx.extra.isLocalPlayer) return 1;
let x = fx.extra.player.x;
let y = fx.extra.player.y;
let fxx = (Math.floor(x / 16) - OWOP.camera.x) * OWOP.camera.zoom;
let fxy = (Math.floor(y / 16) - OWOP.camera.y) * OWOP.camera.zoom;
let oldlinew = ctx.lineWidth;
ctx.lineWidth = 1;
if (tool.extra.end) {
let s = tool.extra.start;
let e = tool.extra.end;
let x = (s[0] - OWOP.camera.x) * OWOP.camera.zoom + 0.5;
let y = (s[1] - OWOP.camera.y) * OWOP.camera.zoom + 0.5;
let w = e[0] - s[0];
let h = e[1] - s[1];
ctx.beginPath();
ctx.rect(x, y, w * OWOP.camera.zoom, h * OWOP.camera.zoom);
ctx.globalAlpha = 0.25;
ctx.strokeStyle = "#FFFFFF";
ctx.stroke();
ctx.setLineDash([3, 4]);
ctx.strokeStyle = "#000000";
ctx.stroke();
//ctx.globalAlpha = 0.25 + Math.sin(time / 500) / 4;
ctx.fillStyle = OWOP.renderer.patterns.unloaded;
ctx.fill();
ctx.setLineDash([]);
let oldfont = ctx.font;
ctx.font = "16px sans-serif";
let perc = 2;
if (perc > 100) perc = 100;
let txt = tool.extra.clicking ? 'Right click to start pixeling.' : '';
let txtx = window.innerWidth >> 1;
let txty = window.innerHeight >> 1;
txtx = Math.max(x, Math.min(txtx, x + w * OWOP.camera.zoom));
txty = Math.max(y, Math.min(txty, y + h * OWOP.camera.zoom));
OWOP.drawText = (ctx, str, x, y, centered) => {
ctx.strokeStyle = "#000000", ctx.fillStyle = "#FFFFFF", ctx.lineWidth = 2.5, ctx.globalAlpha = 1;
if (centered) {
x -= ctx.measureText(str).width >> 1;
}
ctx.strokeText(str, x, y);
ctx.globalAlpha = 1;
ctx.fillText(str, x, y);
};
OWOP.drawText(ctx, txt, txtx, txty, true);
ctx.font = oldfont;
ctx.lineWidth = oldlinew;
return 0;
} else {
ctx.beginPath();
ctx.moveTo(0, fxy + 0.5);
ctx.lineTo(window.innerWidth, fxy + 0.5);
ctx.moveTo(fxx + 0.5, 0);
ctx.lineTo(fxx + 0.5, window.innerHeight);
//ctx.lineWidth = 1;
ctx.globalAlpha = 0.8;
ctx.strokeStyle = "#FFFFFF";
ctx.stroke();
ctx.setLineDash([3]);
ctx.strokeStyle = "#000000";
ctx.stroke();
ctx.setLineDash([]);
ctx.lineWidth = oldlinew;
return 1;
}
});
tool.extra.start = null;
tool.extra.end = null;
tool.extra.clicking = false;
tool.setEvent('mousedown', async (mouse, event) => {
let s = tool.extra.start;
let e = tool.extra.end;
let isInside = function isInside() {
return mouse.tileX >= s[0] && mouse.tileX < e[0] && mouse.tileY >= s[1] && mouse.tileY < e[1];
};
if (mouse.buttons === 1 && !tool.extra.end) {
tool.extra.start = [Math.floor(mouse.tileX / 16) * 16, Math.floor(mouse.tileY / 16) * 16];
tool.extra.clicking = true;
tool.setEvent('mousemove', function(mouse, event) {
if (tool.extra.start && mouse.buttons === 1) {
tool.extra.end = [Math.floor(mouse.tileX / 16) * 16, Math.floor(mouse.tileY / 16) * 16];
return 1;
}
});
let finish = function finish() {
tool.setEvent('mousemove mouseup deselect', null);
tool.extra.clicking = false;
let s = tool.extra.start;
let e = tool.extra.end;
if (e) {
if (s[0] === e[0] || s[1] === e[1]) {
tool.extra.start = null;
tool.extra.end = null;
}
if (s[0] > e[0]) {
let tmp = e[0];
e[0] = s[0];
s[0] = tmp;
}
if (s[1] > e[1]) {
let tmp = e[1];
e[1] = s[1];
s[1] = tmp;
}
}
OWOP.renderer.render(OWOP.renderer.rendertype.FX);
};
tool.setEvent('deselect', finish);
tool.setEvent('mouseup', function(mouse, event) {
if (!(mouse.buttons & 1)) {
finish();
}
});
} else if (mouse.buttons === 1 && tool.extra.end) {
if (isInside()) {
let offx = mouse.tileX;
let offy = mouse.tileY;
tool.setEvent('mousemove', function(mouse, event) {
let dx = mouse.tileX - offx;
let dy = mouse.tileY - offy;
tool.extra.start = [s[0] + dx, s[1] + dy];
tool.extra.end = [e[0] + dx, e[1] + dy];
});
let end = function end() {
tool.setEvent('mouseup deselect mousemove', null);
};
tool.setEvent('deselect', end);
tool.setEvent('mouseup', function(mouse, event) {
if (!(mouse.buttons & 1)) {
end();
};
});
}
} else if (mouse.buttons === 2 && tool.extra.end && isInside()) {
if (BOTS.length === 0) {
let w = tool.extra.end[0] - tool.extra.start[0];
let h = tool.extra.end[1] - tool.extra.start[1];
for (let x = 0; x < w; x++) {
let chunkx = tool.extra.start[0];
let chunky = tool.extra.start[1];
let color = OWOP.player.selectedColor;
for (let y = 0; y < h; y++) {
OWOP.world.setPixel(chunkx + x, chunky + y, color);
}
}
}
for (let i = 0; i < BOTS.length; i++) BOTS[i].options.busy = true;
let w = tool.extra.end[0] - tool.extra.start[0];
let h = tool.extra.end[1] - tool.extra.start[1];
let color = OWOP.player.selectedColor;
let chunkx = tool.extra.start[0];
let chunky = tool.extra.start[1];
async function drawPattern(pattern) {
if (pattern == patterns.lr) {
for (let x = 0; x < w; x++) {
for (let y = 0; y < h; y++) {
let abc = getFree();
if (!OldPaste) {
BOTS[abc].utils.bucket.canSpend(0);
if (BOTS[abc].utils.bucket.allowance <= 1) await sleep(0);
}
BOTS[abc].world.setPixel(chunkx + x, chunky + y, color);
}
}
} else if (pattern == patterns.tb) {
for (let y = 0; y < h; y++) {
for (let x = 0; x < w; x++) {
let abc = getFree();
if (!OldPaste) {
BOTS[abc].utils.bucket.canSpend(0);
if (BOTS[abc].utils.bucket.allowance <= 1) await sleep(0);
}
BOTS[abc].world.setPixel(chunkx + x, chunky + y, color);
}
}
} else if (pattern == patterns.rand) {
for (let x = 0; x < w * 3; x++) {
for (let y = 0; y < h * 3; y++) {
let abc = getFree();
if (!OldPaste) {
BOTS[abc].utils.bucket.canSpend(0);
if (BOTS[abc].utils.bucket.allowance <= 1) await sleep(0);
}
BOTS[abc].world.setPixel(chunkx + Math.floor(Math.random() * w), chunky + Math.floor(Math.random() * h), color);
}
}
};
};
drawPattern(pattern);
for (let i = 0; i < BOTS.length; i++) BOTS[i].options.busy = false;
} else {
tool.extra.start = null;
tool.extra.end = null;
}
});
}));
OWOP.tools.addToolObject(new OWOP.tools.class('Bot Paster', OWOP.cursors.paste, OWOP.fx.player.RECT_SELECT_ALIGNED(1), false, function(tool) {
tool.setEvent('mousedown', function(mouse, event) {
let sX = !Pixelization ? OWOP.mouse.tileX : Math.floor(OWOP.mouse.tileX / 16) * 16,
sY = !Pixelization ? OWOP.mouse.tileY : Math.floor(OWOP.mouse.tileY / 16) * 16;
if (mouse.buttons != 0) {
let input = document.createElement('input');
input.type = "file";
input.accept = 'image/*';
input.click();
input.onchange = () => {
if (BOTS.length === 0) return OWOP.chat.local("No bots connected!");
sleep(15);
let imgURL = URL.createObjectURL(input.files[0]);
let img = new Image();
img.onload = async () => {
let cnv = document.createElement('canvas');
let ctx = cnv.getContext('2d');
let imgWidth = img.naturalWidth;
let imgHeight = img.naturalHeight;
cnv.width = 3000;
cnv.height = 3000;
if (imgWidth > 3000) return OJS.chat.local('The width of image is too big!');
if (imgHeight > 3000) return OJS.chat.local('The height of image is too big!');
ctx.drawImage(img, 0, 0);
let imgData = ctx.getImageData(0, 0, imgWidth, imgHeight);
let orgPixels = Array.from(imgData.data);
let i = 0;
let I = 0;
let pixels = [];
while (i <= orgPixels.length) {
pixels.push([orgPixels[i], orgPixels[i + 1], orgPixels[i + 2], orgPixels[i + 3]]);
i += 4;
};
for (let i = 0; i < BOTS.length; i++) BOTS[i].options.busy = true;
for (i = 0; i < imgHeight; i++)
for (let j = 0; j < imgWidth; j++) {
let abc = getFree();
BOTS[abc].world.setPixel(sX + j, sY + i, pixels[I]);
I++;
}
for (let i = 0; i < BOTS.length; i++) BOTS[i].options.busy = false;
};
img.src = imgURL;
};
};
});
}));
OWOP.world.protection = {
intervals: {},
pixels: {}
};
OWOP.tools.addToolObject(new OWOP.tools.class("Bot Protection 16", OWOP.cursors.shield, OWOP.fx.player.RECT_SELECT_ALIGNED(16), OWOP.RANK.USER, tool => {
tool.setFxRenderer((fx, ctx) => {
const X = fx.extra.player.x,
Y = fx.extra.player.y,
cX = (16 * Math.floor(X / 256) - OWOP.camera.x) * OWOP.camera.zoom,
cY = (16 * Math.floor(Y / 256) - OWOP.camera.y) * OWOP.camera.zoom,
tX = fx.extra.player.tileX,
tY = fx.extra.player.tileY,
chunk = OWOP.world.protection.pixels[`${tX},${tY}`];
ctx.globalAlpha = .5;
ctx.fillStyle = chunk ? "#00FF00" : "#FF0000";
ctx.fillRect(cX, cY, 16 * OWOP.camera.zoom, 16 * OWOP.camera.zoom);
return true;
});
tool.setEvent("mousedown mousemove", fx => {
const X = Math.floor(OWOP.mouse.tileX / OWOP.options.serverAddress[0].proto.chunkSize) * 16,
Y = Math.floor(OWOP.mouse.tileY / OWOP.options.serverAddress[0].proto.chunkSize) * 16,
chunk = OWOP.world.protection.pixels[`${X},${Y}`];
switch (fx.buttons) {
case 1:
if (chunk) return false;
for (let y = 0; y < 16; y++)
for (let x = 0; x < 16; x++) {
OWOP.world.protection.pixels[`${X + x},${Y + y}`] = OWOP.world.getPixel(X + x, Y + y);
OWOP.world.protection.intervals[`${X + x},${Y + y}`] = setInterval(() => {
if (!OWOP.world.setPixel(X + x, Y + y, OWOP.world.protection.pixels[`${X + x},${Y + y}`])) {
let abc = getFree();
if (BOTS[abc].utils.bucket.allowance >= 1) BOTS[abc].world.setPixel(X + x, Y + y, OWOP.world.protection.pixels[`${X + x},${Y + y}`]);
}
}, 1);
}
return true;
break;
case 2:
if (!chunk) return false;
for (let y = 0; y < 16; y++)
for (let x = 0; x < 16; x++) {
clearInterval(OWOP.world.protection.intervals[`${X + x},${Y + y}`]);
delete OWOP.world.protection.intervals[`${X + x},${Y + y}`];
delete OWOP.world.protection.pixels[`${X + x},${Y + y}`];
}
break;
}
});
}));
OWOP.tools.addToolObject(new OWOP.tools.class("Bot Area Protect", OWOP.cursors.selectprotect, OWOP.fx.player.NONE, OWOP.RANK.USER, tool => {
const X = Math.floor(OWOP.mouse.tileX / OWOP.options.serverAddress[0].proto.chunkSize) * 16,
Y = Math.floor(OWOP.mouse.tileY / OWOP.options.serverAddress[0].proto.chunkSize) * 16,
chunk = OWOP.world.protection.pixels[`${X},${Y}`];
function drawText(ctx, str, x, y, centered) {
ctx.strokeStyle = "#000000", ctx.fillStyle = "#FFFFFF", ctx.lineWidth = 2.5, ctx.globalAlpha = 0.5;
if (centered) {
x -= ctx.measureText(str).width >> 1;
}
ctx.strokeText(str, x, y);
ctx.globalAlpha = 1;
ctx.fillText(str, x, y);
}
tool.setFxRenderer(function (fx, ctx, time) {
if (!fx.extra.isLocalPlayer) return 1;
var x = fx.extra.player.x;
var y = fx.extra.player.y;
var fxx = (Math.round(x / 256) * 16 - OWOP.camera.x) * OWOP.camera.zoom;
var fxy = (Math.round(y / 256) * 16 - OWOP.camera.y) * OWOP.camera.zoom;
var oldlinew = ctx.lineWidth;
ctx.lineWidth = 1;
if (tool.extra.end) {
var s = tool.extra.start;
var e = tool.extra.end;
var x = (s[0] * 16 - OWOP.camera.x) * OWOP.camera.zoom + 0.5;
var y = (s[1] * 16 - OWOP.camera.y) * OWOP.camera.zoom + 0.5;
var rw = e[0] - s[0];
var rh = e[1] - s[1];
var w = rw * OWOP.camera.zoom * 16;
var h = rh * OWOP.camera.zoom * 16;
ctx.beginPath();
ctx.rect(x, y, w, h);
ctx.globalAlpha = 1;
ctx.strokeStyle = "#FFFFFF";
ctx.stroke();
ctx.setLineDash([3, 4]);
ctx.strokeStyle = "#000000";
ctx.stroke();
if (tool.extra.isSure) {
ctx.globalAlpha = 0.6;
ctx.fillStyle = "#00EE00";
ctx.fill();
}
ctx.globalAlpha = 0.25 + Math.sin(time / 500) / 4;
ctx.fillStyle = OWOP.renderer.patterns.unloaded;
ctx.fill();
ctx.setLineDash([]);
var oldfont = ctx.font;
ctx.font = "16px sans-serif";
var txt = (tool.extra.isSure ? "Click again to confirm. " : !tool.extra.clicking ? "Click to erase. " : "") + '(' + Math.abs(rw) + 'x' + Math.abs(rh) + ')';
var txtx = window.innerWidth >> 1;
var txty = window.innerHeight >> 1;
txtx = Math.max(x, Math.min(txtx, x + w));
txty = Math.max(y, Math.min(txty, y + h));
drawText(ctx, txt, txtx, txty, true);
ctx.font = oldfont;
ctx.lineWidth = oldlinew;
return 0;
} else {
ctx.beginPath();
ctx.moveTo(0, fxy + 0.5);
ctx.lineTo(window.innerWidth, fxy + 0.5);
ctx.moveTo(fxx + 0.5, 0);
ctx.lineTo(fxx + 0.5, window.innerHeight);
//ctx.lineWidth = 1;
ctx.globalAlpha = 1;
ctx.strokeStyle = "#FFFFFF";
ctx.stroke();
ctx.setLineDash([3]);
ctx.strokeStyle = "#000000";
ctx.stroke();
ctx.setLineDash([]);
ctx.lineWidth = oldlinew;
return 1;
}
});
tool.extra.start = null;
tool.extra.end = null;
tool.extra.clicking = false;
tool.extra.isSure = false;
var timeout = null;
var sure = function sure() {
if (tool.extra.isSure) {
clearTimeout(timeout);
timeout = null;
tool.extra.isSure = false;
return true;
}
tool.extra.isSure = true;
setTimeout(function () {
tool.extra.isSure = false;
timeout = null;
}, 1000);
return false;
};
tool.setEvent('mousedown', function (mouse, event) {
var get = {
rx: function rx() {
return mouse.tileX / 16;
},
ry: function ry() {
return mouse.tileY / 16;
},
x: function x() {
return Math.round(mouse.tileX / 16);
},
y: function y() {
return Math.round(mouse.tileY / 16);
}
};
var s = tool.extra.start;
var e = tool.extra.end;
var isInside = function isInside() {
return get.rx() >= s[0] && get.rx() < e[0] && get.ry() >= s[1] && get.ry() < e[1];
};
if (mouse.buttons === 1 && !tool.extra.end) {
tool.extra.start = [get.x(), get.y()];
tool.extra.clicking = true;
tool.setEvent('mousemove', function (mouse, event) {
if (tool.extra.start && mouse.buttons === 1) {
tool.extra.end = [get.x(), get.y()];
return 1;
}
});
var finish = function finish() {
tool.setEvent('mousemove mouseup deselect', null);
tool.extra.clicking = false;
var s = tool.extra.start;
var e = tool.extra.end;
if (e) {
if (s[0] === e[0] || s[1] === e[1]) {
tool.extra.start = null;
tool.extra.end = null;
}
if (s[0] > e[0]) {
var tmp = e[0];
e[0] = s[0];
s[0] = tmp;
}
if (s[1] > e[1]) {
var tmp = e[1];
e[1] = s[1];
s[1] = tmp;
}
}
OWOP.renderer.render(OWOP.renderer.rendertype.FX);
};
tool.setEvent('deselect', finish);
tool.setEvent('mouseup', function (mouse, event) {
if (!(mouse.buttons & 1)) {
finish();
}
});
} else if (mouse.buttons === 1 && tool.extra.end) {
if (isInside() && sure()) {
tool.extra.start = null;
tool.extra.end = null;
var _ref = [s[0], s[1], e[0] - s[0], e[1] - s[1]],
x = _ref[0],
y = _ref[1],
w = _ref[2],
h = _ref[3];
for (var i = x; i < x + w; i++) {
for (var j = y; j < y + h; j++) {
clearInterval(OWOP.world.protection.intervals[`${X + i},${Y + j}`]);
delete OWOP.world.protection.intervals[`${X + i},${Y + j}`];
delete OWOP.world.protection.pixels[`${X + i},${Y + j}`];
}
}
} else if (!isInside()) {
tool.extra.start = null;
tool.extra.end = null;
}
} else if (mouse.buttons === 0 && tool.extra.end) {
if (isInside() && sure()) {
tool.extra.start = null;
tool.extra.end = null;
var _ref = [s[0], s[1], e[0] - s[0], e[1] - s[1]],
x = _ref[0],
y = _ref[1],
w = _ref[2],
h = _ref[3];
for (var i = x; i < x + w; i++) {
for (var j = y; j < y + h; j++) {
OWOP.world.protection.pixels[`${X + i},${Y + j}`] = OWOP.world.getPixel(X + i, Y + j);
OWOP.world.protection.intervals[`${X + i},${Y + j}`] = setInterval(() => {
if (!OWOP.world.setPixel(X + i, Y + j, OWOP.world.protection.pixels[`${X + i},${Y + j}`])) {
let abc = getFree();
if (BOTS[abc].utils.bucket.allowance >= 1) BOTS[abc].world.setPixel(X + i, Y + j, OWOP.world.protection.pixels[`${X + x},${Y + y}`]);
}
}, 3000);
}
}
} else if (!isInside()) {
tool.extra.start = null;
tool.extra.end = null;
}
}
});
}));
OWOP.tools.addToolObject(new OWOP.tools.class("Bot Protection 32", OWOP.cursors.shield, OWOP.fx.player.RECT_SELECT_ALIGNED(32), OWOP.RANK.USER, tool => {
tool.setFxRenderer((fx, ctx) => {
const X = fx.extra.player.x,
Y = fx.extra.player.y,
cX = (32 * Math.floor(X / 512) - OWOP.camera.x) * OWOP.camera.zoom,
cY = (32 * Math.floor(Y / 512) - OWOP.camera.y) * OWOP.camera.zoom,
tX = fx.extra.player.tileX,
tY = fx.extra.player.tileY,
chunk = OWOP.world.protection.pixels[`${tX},${tY}`];
ctx.globalAlpha = .5;
ctx.fillStyle = chunk ? "#00FF00" : "#FF0000";
ctx.fillRect(cX, cY, 32 * OWOP.camera.zoom, 32 * OWOP.camera.zoom);
return true;
});
tool.setEvent("mousedown mousemove", fx => {
const X = Math.floor(OWOP.mouse.tileX / OWOP.options.serverAddress[0].proto.chunkSize) * 32,
Y = Math.floor(OWOP.mouse.tileY / OWOP.options.serverAddress[0].proto.chunkSize) * 32,
chunk = OWOP.world.protection.pixels[`${X},${Y}`];
switch (fx.buttons) {
case 1:
if (chunk) return false;
for (let y = 0; y < 32; y++)
for (let x = 0; x < 32; x++) {
OWOP.world.protection.pixels[`${X + x},${Y + y}`] = OWOP.world.getPixel(X + x, Y + y);
OWOP.world.protection.intervals[`${X + x},${Y + y}`] = setInterval(() => {
if (!OWOP.world.setPixel(X + x, Y + y, OWOP.world.protection.pixels[`${X + x},${Y + y}`])) {
let abc = getFree();
if (BOTS[abc].utils.bucket.allowance >= 1) BOTS[abc].world.setPixel(X + x, Y + y, OWOP.world.protection.pixels[`${X + x},${Y + y}`]);
}
}, 1);
}
return true;
break;
case 2:
if (!chunk) return false;
for (let y = 0; y < 32; y++)
for (let x = 0; x < 32; x++) {
clearInterval(OWOP.world.protection.intervals[`${X + x},${Y + y}`]);
delete OWOP.world.protection.intervals[`${X + x},${Y + y}`];
delete OWOP.world.protection.pixels[`${X + x},${Y + y}`];
}
break;
}
});
}));
OWOP.tools.addToolObject(new OWOP.tools.class("Bot Protection 64", OWOP.cursors.shield, OWOP.fx.player.RECT_SELECT_ALIGNED(64), OWOP.RANK.USER, tool => {
tool.setFxRenderer((fx, ctx) => {
const X = fx.extra.player.x,
Y = fx.extra.player.y,
cX = (64 * Math.floor(X / 1024) - OWOP.camera.x) * OWOP.camera.zoom,
cY = (64 * Math.floor(Y / 1024) - OWOP.camera.y) * OWOP.camera.zoom,
tX = fx.extra.player.tileX,
tY = fx.extra.player.tileY,
chunk = OWOP.world.protection.pixels[`${tX},${tY}`];
ctx.globalAlpha = .5;
ctx.fillStyle = chunk ? "#00FF00" : "#FF0000";
ctx.fillRect(cX, cY, 64 * OWOP.camera.zoom, 64 * OWOP.camera.zoom);
return true;
});
tool.setEvent("mousedown mousemove", fx => {
const X = Math.floor(OWOP.mouse.tileX / OWOP.options.serverAddress[0].proto.chunkSize) * 64,
Y = Math.floor(OWOP.mouse.tileY / OWOP.options.serverAddress[0].proto.chunkSize) * 64,
chunk = OWOP.world.protection.pixels[`${X},${Y}`];
switch (fx.buttons) {
case 1:
if (chunk) return false;
for (let y = 0; y < 64; y++)
for (let x = 0; x < 64; x++) {
OWOP.world.protection.pixels[`${X + x},${Y + y}`] = OWOP.world.getPixel(X + x, Y + y);
OWOP.world.protection.intervals[`${X + x},${Y + y}`] = setInterval(() => {
if (!OWOP.world.setPixel(X + x, Y + y, OWOP.world.protection.pixels[`${X + x},${Y + y}`])) {
let abc = getFree();
if (BOTS[abc].utils.bucket.allowance >= 1) BOTS[abc].world.setPixel(X + x, Y + y, OWOP.world.protection.pixels[`${X + x},${Y + y}`]);
}
}, 1);
}
return true;
break;
case 2:
if (!chunk) return false;
for (let y = 0; y < 64; y++)
for (let x = 0; x < 64; x++) {
clearInterval(OWOP.world.protection.intervals[`${X + x},${Y + y}`]);
delete OWOP.world.protection.intervals[`${X + x},${Y + y}`];
delete OWOP.world.protection.pixels[`${X + x},${Y + y}`];
}
break;
}
});
}));
OWOP.tools.addToolObject(new OWOP.tools.class("Bot Paste Asset", OWOP.cursors.paste, OWOP.fx.player.RECT_SELECT_ALIGNED(1), false, tool => {
tool.setEvent("mousedown mousemove", async e => {
if (e.buttons === 1) {
if (!selectedAsset) OWOP.chat.local("No asset selected!");
if (typeof selectedAsset === "string") {
// convert
let cnv = document.createElement("canvas");
let ctx = cnv.getContext('2d');
aboab = ctx;
let img = new Image();
img.onload = () => {
cnv.width = 2500;
cnv.height = 2500;
ctx.drawImage(img, 0, 0);
selectedAsset = ctx.getImageData(0, 0, img.naturalWidth, img.naturalHeight);
}
img.src = selectedAsset;
return OWOP.chat.local("Image is ready.");
};
let cC0 = 0;
let cC1 = 0;
let cC2 = 0;
let xX = 0;
let yY = 0;
let x_ = 0;
let y_ = 0;
let I = 0;
let x = !Pixelization ? OWOP.mouse.tileX : Math.floor(OWOP.mouse.tileX / 16) * 16,
y = !Pixelization ? OWOP.mouse.tileY : Math.floor(OWOP.mouse.tileY / 16) * 16;
if (imgpattern === imgpatterns.default) {
async function pastePick() {
let I = 0;
let x = !Pixelization ? OWOP.mouse.tileX : Math.floor(OWOP.mouse.tileX / 16) * 16,
y = !Pixelization ? OWOP.mouse.tileY : Math.floor(OWOP.mouse.tileY / 16) * 16;
for (let Y = 0; Y < selectedAsset.height; Y++) {
for (let X = 0; X < selectedAsset.width; X++) {
let abc = getFree();
if (!OldPaste) {
BOTS[abc].utils.bucket.canSpend(0);
if (BOTS[abc].utils.bucket.allowance <= 1) await sleep(0);
}
BOTS[abc].world.setPixel(x + X, y + Y, [selectedAsset.data[I++], selectedAsset.data[I++], selectedAsset.data[I++]]);
I++;
}
}
}
pastePick();
} else if (imgpattern === imgpatterns.grid) {
async function pastePick() {
if (!stop) {
for (let Y = 0; Y < selectedAsset.height; Y += 2) {
for (let X = 0; X < selectedAsset.width; X++) {
// for(let Y = 0; Y > selectedAsset.height; Y++){
//for(let X = 0; X > selectedAsset.width; X++) {
let abc = getFree();
if (!OldPaste) {
BOTS[abc].utils.bucket.canSpend(0);
if (BOTS[abc].utils.bucket.allowance <= 49) await sleep(0);
}
x_ = X;
//xX = x_;
y_ = Y;
//yY = y_;
BOTS[abc].world.setPixel(x + x_, y + y_, pixColor(aboab, x_, y_));
}
}
for (let Y = 0; Y < selectedAsset.height; Y++) {
for (let X = 0; X < selectedAsset.width; X += 2) {
// for(let Y = 0; Y > selectedAsset.height; Y++){
//for(let X = 0; X > selectedAsset.width; X++) {
let abc = getFree();
if (!OldPaste) {
BOTS[abc].utils.bucket.canSpend(0);
if (BOTS[abc].utils.bucket.allowance <= 49) await sleep(0);
}
x_ = X;
//xX = x_;
y_ = Y;
//yY = y_;
BOTS[abc].world.setPixel(x + x_, y + y_, pixColor(aboab, x_, y_));
}
}
for (let Y = 0; Y < selectedAsset.height; Y++) {
for (let X = 0; X < selectedAsset.width; X++) {
// for(let Y = 0; Y > selectedAsset.height; Y++){
//for(let X = 0; X > selectedAsset.width; X++) {
let abc = getFree();
if (!OldPaste) {
BOTS[abc].utils.bucket.canSpend(0);
if (BOTS[abc].utils.bucket.allowance <= 49) await sleep(0);
}
x_ = X;
//xX = x_;
y_ = Y;
//yY = y_;
BOTS[abc].world.setPixel(x + x_, y + y_, pixColor(aboab, x_, y_));
}
}
}
}
for (let Y = 0; Y < selectedAsset.height; Y++) {
for (let X = 0; X < selectedAsset.width; X++) {
if ([OWOP.world.getPixel(x + X, y + Y)[0], OWOP.world.getPixel(x + X, y + Y)[1], OWOP.world.getPixel(x + X, y + Y)[2]] != pixColor(aboab, X, Y)) {
await pastePick();
await sleep(1000);
X = 0;
Y = 0;
if (stop) {
Y = selectedAsset.height;
X = selectedAsset.width;
}
}
}
} //
} else if (imgpattern === imgpatterns.leftup) {
async function pastePick() {
for (let X = 0; X < selectedAsset.width; X++) {
for (let Y = 0; Y < selectedAsset.height; Y++) {
if (stop) {
Y = selectedAsset.height;
X = selectedAsset.width;
}
// for(let Y = 0; Y > selectedAsset.height; Y++){
//for(let X = 0; X > selectedAsset.width; X++) {
let x_ = (selectedAsset.width - X) - 1;
let y_ = (selectedAsset.height - Y) - 1;
let i = getFree();
if (!OldPaste) {
BOTS[i].utils.bucket.canSpend(0);
if (BOTS[i].utils.bucket.allowance <= 1) {
await sleep(0);
Y--
} else {
BOTS[i].world.setPixel(x + x_, y + y_, pixColor(aboab, x_, y_));
}
}
}
}
// }
//}
}
pastePick();
} else if (imgpattern == imgpatterns.square) {
async function pastePick() {
let x_2 = 1;
let y_2 = selectedAsset.height - 1;
let y_1;
let x_1 = selectedAsset.width - 1;
for (y_ = 0; y_ < selectedAsset.height; y_++) {
for (x_ = 0; x_ < selectedAsset.width; x_++) {
if (stop) {
x_ = selectedAsset.height;
y_ = selectedAsset.width;
y_1 = selectedAsset.height;
}
let abc = getFree();
if (!OldPaste) {
BOTS[abc].utils.bucket.canSpend(0);
if (BOTS[abc].utils.bucket.allowance <= 1) {
await sleep(0);
x_--
} else {
BOTS[abc].world.setPixel(x + x_, y + y_, pixColor(aboab, x_, y_));
}
}
}
y_1 = y_;
if (x_1 > 0) {
for (y_ = 0; y_ < selectedAsset.height; y_++) {
let abc = getFree();
if (!OldPaste) {
BOTS[abc].utils.bucket.canSpend(0);
if (BOTS[abc].utils.bucket.allowance <= 1) {
await sleep(0);
y_--
} else {
BOTS[abc].world.setPixel(x + x_1, y + y_, pixColor(aboab, x_1, y_));
}
}
}
x_1--
}
y_ = y_1;
if (y_2 != 0) {
for (let x_ = selectedAsset.width - 1; x_ > -1; x_--) {
if (!stop) {
let abc = getFree();
if (!OldPaste) {
BOTS[abc].utils.bucket.canSpend(0);
if (BOTS[abc].utils.bucket.allowance <= 1) {
await sleep(0);
x_++
} else {
BOTS[abc].world.setPixel(x + x_, y + y_2, pixColor(aboab, x_, y_2));
}
}
}
}
}
y_2--
y_1 = y_;
if (x_2 < selectedAsset.width) {
for (y_ = selectedAsset.height - 1; y_ > -1; y_--) {
let abc = getFree();
if (!OldPaste) {
BOTS[abc].utils.bucket.canSpend(0);
if (BOTS[abc].utils.bucket.allowance <= 1) {
await sleep(0);
y_++
} else {
BOTS[abc].world.setPixel(x + x_2, y + y_, pixColor(aboab, x_2, y_));
}
}
}
x_2++
}
y_ = y_1;
}
};
pastePick();
};
};
});
}));
};
var chars = [
[0b1111111, 0b1000001, 0b1010111, 0b1010100, 0b1010111, 0b1000001, 0b1111111] /*A*/ ,
[0b1111111, 0b1000001, 0b1010101, 0b1010101, 0b1010101, 0b1001001, 0b1111111] /*B*/ ,
[0b1111111, 0b1000001, 0b1011101, 0b1010101, 0b1010101, 0b1010101, 0b1110111] /*C*/ ,
[0b1111111, 0b1000001, 0b1011101, 0b1010101, 0b1011101, 0b1100011, 0b0111110] /*D*/ ,
[0b1111111, 0b1000001, 0b1010101, 0b1010101, 0b1010101, 0b1011101, 0b1110111] /*E*/ ,
[0b1111111, 0b1000001, 0b1010111, 0b1010100, 0b1010100, 0b1011100, 0b1110000] /*F*/ ,
[0b1111111, 0b1000001, 0b1011101, 0b1010101, 0b1010101, 0b1010001, 0b1111111] /*G*/ ,
[0b1111111, 0b1000001, 0b1110111, 0b0010100, 0b1110111, 0b1000001, 0b1111111] /*H*/ ,
[0b1111111, 0b1000001, 0b1111111] /*I*/ ,
[0b1111111, 0b1010001, 0b1011101, 0b1010101, 0b1011101, 0b1000001, 0b1111111] /*J*/ ,
[0b1111111, 0b1000001, 0b1110111, 0b0110110, 0b1101011, 0b1011101, 0b1110111] /*K*/ ,
[0b1111111, 0b1000001, 0b1111101, 0b0000101, 0b0000101, 0b0000101, 0b0000111] /*L*/ ,
[0b1111111, 0b1000001, 0b1011111, 0b1000001, 0b1011111, 0b1000001, 0b1111111] /*M*/ ,
[0b1111111, 0b1000001, 0b1011111, 0b1000001, 0b1111101, 0b1000001, 0b1111111] /*N*/ ,
[0b1111111, 0b1000001, 0b1011101, 0b1010101, 0b1011101, 0b1000001, 0b1111111] /*O*/ ,
[0b1111111, 0b1000001, 0b1010111, 0b1010100, 0b1010100, 0b1000100, 0b1111100] /*P*/ ,
[0b1111111, 0b1000001, 0b1011101, 0b1010101, 0b1011101, 0b1000011, 0b1111111] /*Q*/ ,
[0b1111111, 0b1000001, 0b1010111, 0b1010100, 0b1010111, 0b1001001, 0b1111111] /*R*/ ,
[0b1111111, 0b1000101, 0b1010101, 0b1010101, 0b1010101, 0b1010001, 0b1111111] /*S*/ ,
[0b1110000, 0b1010000, 0b1011111, 0b1000001, 0b1011111, 0b1010000, 0b1110000] /*T*/ ,
[0b1111111, 0b1000001, 0b1111101, 0b0000101, 0b1111101, 0b1000001, 0b1111111] /*U*/ ,
[0b1111100, 0b1000110, 0b1111011, 0b0001101, 0b1111011, 0b1000110, 0b1111100] /*V*/ ,
[0b1111110, 0b1000011, 0b1111101, 0b0100011, 0b1111101, 0b1000011, 0b1111110] /*W*/ ,
[0b1110111, 0b1011101, 0b1101011, 0b0110110, 0b1101011, 0b1011101, 0b1110111] /*X*/ ,
[0b1111000, 0b1001100, 0b1110111, 0b0011001, 0b1110111, 0b1001100, 0b1111000] /*Y*/ ,
[0b1111111, 0b1010001, 0b1010101, 0b1010101, 0b1010101, 0b1000101, 0b1111111] /*Z*/ ,
];
var NUMS = [
[0b11111, 0b10001, 0b11111] /*0*/ ,
[0b01000, 0b11111] /*1*/ ,
[0b10111, 0b10101, 0b11101] /*2*/ ,
[0b10101, 0b10101, 0b11111] /*3*/ ,
[0b11100, 0b00100, 0b11111] /*4*/ ,
[0b11101, 0b10101, 0b10111] /*5*/ ,
[0b11111, 0b10101, 0b10111] /*6*/ ,
[0b10000, 0b10000, 0b11111] /*7*/ ,
[0b11111, 0b10101, 0b11111] /*8*/ ,
[0b11101, 0b10101, 0b11111] /*9*/
];
var symbols = {
"33": [0b11101] /*!*/ ,
"34": [0b11000, 0b00000, 0b11000] /*"*/ ,
"35": [0b01010, 0b11111, 0b01010, 0b11111, 0b01010] /*#*/ ,
"39": [0b11000] /*'*/ ,
"40": [0b01110, 0b10001] /*(*/ ,
"41": [0b10001, 0b01110] /*)*/ ,
"43": [0b00100, 0b01110, 0b00100] /*+*/ ,
"45": [0b00100, 0b00100, 0b00100] /*-*/ ,
"46": [0b00001] /*.*/ ,
"47": [0b00001, 0b00110, 0b11000] /*/*/ ,
"58": [0b01010] /*:*/ ,
"61": [0b01010, 0b01010, 0b01010] /*=*/ ,
"63": [0b10101, 0b01000] /*?*/ ,
"91": [0b11111, 0b10001] /*[*/ ,
"93": [0b10001, 0b11111] /*]*/
};
function infinityX(t) {
let x = (Math.cos(t*2)-1)/2;
if (Math.abs(t*2) % (4*Math.PI) > 2*Math.PI) return -x;
else return x;
};
function infinityY(t) {
return Math.sin(t*2) / 2;
};
function squareX(angle) {
let x = Math.sin(angle), y = Math.cos(angle);
return x / Math.max(Math.abs(x), Math.abs(y));
};
function squareY(angle) {
let x = Math.sin(angle), y = Math.cos(angle);
return y / Math.max(Math.abs(x), Math.abs(y));
};
function pixColor(img, X, Y, RGB) {
var abab = img.getImageData(X, Y, 1, 1).data
return [abab[0], abab[1], abab[2]]
};
function getRandomInt2(max) {
return Math.floor(Math.random() * max);
};
function dist(x, y) {
return Math.sqrt(x * x + y * y);
};
function append(src, onload) {
var s = document.createElement('script');
s.src = src;
s.onload = onload;
document.body.appendChild(s);
};
setTimeout(install, 2001);
})();