NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript== // @name Slither.io - Lenda Clan by vplenda // @namespace LendaClan.vp // @version 1.3 // @description LendaClan by VpLenda// @author Vplenda no lags,+Fps // @match http://slither.io/* // @run-at document-body // @grant none // ==/UserScript== // : // (function(w) { var modVersion = "v1.3", renderMode = 2, // 3 - normal, 2 - optimized, 1 - simple (mobile) normalMode = false, gameFPS = null, positionHUD = null, ipHUD = null, fpsHUD = null, styleHUD = "color: #fad44c; font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif; font-size: 20px; position: fixed; opacity: 0.35; z-index: 7;", inpNick = null, currentIP = null, retry = 0, bgImage = null; function init() { // Append DIVs appendDiv("position-hud", "nsi", styleHUD + "right: 30; bottom: 120px;"); appendDiv("ip-hud", "nsi", styleHUD + "right: 30; bottom: 150px;"); appendDiv("fps-hud", "nsi", styleHUD + "right: 30; bottom: 170px;"); positionHUD = document.getElementById("position-hud"); ipHUD = document.getElementById("ip-hud"); fpsHUD = document.getElementById("fps-hud"); // Add zoom if (/firefox/i.test(navigator.userAgent)) { document.addEventListener("DOMMouseScroll", zoom, false); } else { document.body.onmousewheel = zoom; } // Quick resp (ESC) w.onkeydown = function(e) { if (e.keyCode == 27) { forceConnect(); } } // Hijack console log /* if (w.console) { w.console.logOld = console.log; w.console.log = getConsoleLog; } */ // Set menu setMenu(); // Set leaderboard setLeaderboard(); // Set graphics setGraphics(); // Update loop updateLoop(); // Show FPS showFPS(); } // Append DIV function appendDiv(id, className, style) { var div = document.createElement("div"); if (id) { div.id = id; } if (className) { div.className = className; } if (style) { div.style = style; } document.body.appendChild(div); } // Zoom function zoom(e) { if (!w.gsc) { return; } w.gsc *= Math.pow(0.9, e.wheelDelta / -120 || e.detail / 2 || 0); } // Get console log function getConsoleLog(log) { //w.console.logOld(log); if (log.indexOf("FPS") != -1) { gameFPS = log; } } // Set menu function setMenu() { var login = document.getElementById("login"); if (login) { // Load settings loadSettings(); // Message var div = document.createElement("div"); div.style.width = "300px"; div.style.color = "#fad44c"; div.style.fontFamily = "'Lucida Sans Unicode', 'Lucida Grande', sans-serif"; div.style.fontSize = "20px"; div.style.textAlign = "center"; div.style.opacity = "0.2"; div.style.margin = "0 auto"; div.style.padding = "10px 0"; div.textContent = " "; login.appendChild(div); // Message var div = document.createElement("div"); div.style.width = "300px"; div.style.color = "#fad44c"; div.style.fontFamily = "'Lucida Sans Unicode', 'Lucida Grande', sans-serif"; div.style.fontSize = "20px"; div.style.textAlign = "center"; div.style.opacity = "0.2"; div.style.margin = "0 auto"; div.style.padding = "10px 0"; div.textContent = " "; login.appendChild(div); // Message2 var div = document.createElement("div"); div.style.width = "300px"; div.style.color = "#fad44c"; div.style.fontFamily = "'Lucida Sans Unicode', 'Lucida Grande', sans-serif"; div.style.fontSize = "15px"; div.style.textAlign = "center"; div.style.opacity = "0.1"; div.style.margin = "0 auto"; div.style.padding = "10px 0"; div.textContent = "Passe No canal do Criador"; login.appendChild(div); // Menu container var sltMenu = document.createElement("div"); sltMenu.style.width = "260px"; sltMenu.style.color = "#fad44c"; sltMenu.style.backgroundColor = "#1e262e"; sltMenu.style.borderRadius = "29px"; sltMenu.style.fontFamily = "'Lucida Sans Unicode', 'Lucida Grande', sans-serif"; sltMenu.style.fontSize = "20px"; sltMenu.style.textAlign = "center"; sltMenu.style.margin = "0 auto 100px auto"; sltMenu.style.padding = "10px 14px"; sltMenu.innerHTML = "<strong>Slither.io - LendaClan</strong> <strong>" + modVersion + "</strong>"; login.appendChild(sltMenu); // IP input container var div = document.createElement("div"); div.style.color = "#8058D0"; div.style.backgroundColor = "#4C447C"; div.style.borderRadius = "29px"; div.style.margin = "10 auto"; div.style.padding = "8px"; sltMenu.appendChild(div); // IP input var input = document.createElement("input"); input.id = "server-ip"; input.type = "text"; input.placeholder = "Server IP"; input.style.height = "24px"; input.style.display = "inline-block"; input.style.background = "none"; input.style.color = "#e0e0ff"; input.style.border = "none"; input.style.outline = "none"; div.appendChild(input); // Connect (play) button var button = document.createElement("input"); button.id = "connect-btn"; button.type = "button"; button.value = "Play"; button.style.height = "24px"; button.style.display = "inline-block"; button.style.borderRadius = "12px"; button.style.color = "#FFF"; button.style.backgroundColor = "#56ac81"; button.style.border = "none"; button.style.outline = "none"; button.style.cursor = "pointer"; button.style.padding = "0 20px"; div.appendChild(button); // Select server container var div = document.createElement("div"); div.style.backgroundColor = "#919191"; div.style.borderRadius = "29px"; div.style.margin = "10 auto"; div.style.padding = "8px"; sltMenu.appendChild(div); // Select server var select = document.createElement("select"); select.id = "select-srv"; select.style.background = "none"; select.style.border = "none"; select.style.outline = "none"; var option = document.createElement("option"); option.value = ""; option.text = "-- Select a server --"; select.appendChild(option); div.appendChild(select); // Select graph container var div = document.createElement("div"); div.style.backgroundColor = "#A5A5A5"; div.style.borderRadius = "29px"; div.style.margin = "10 auto"; div.style.padding = "8px"; sltMenu.appendChild(div); // Select graph var select = document.createElement("select"); select.id = "select-graph"; select.style.background = "none"; select.style.border = "none"; select.style.outline = "none"; div.appendChild(select); var option = document.createElement("option"); option.value = "3"; option.text = "Graphics: normal"; select.appendChild(option); var option = document.createElement("option"); option.value = "2"; option.text = "Graphics: optimized"; select.appendChild(option); var option = document.createElement("option"); option.value = "1"; option.text = "Graphics: low"; select.appendChild(option); // Menu footer sltMenu.innerHTML += '<a href="https://www.youtube.com/channel/UCQKXYBeXtmCe4PQ6gwWg-1A" target="_blank" style="color: #FFF; opacity: 0.35;">Canal do Criador /a> '; // Get IP input inpIP = document.getElementById("server-ip"); // Get nick var nick = document.getElementById("nick"); nick.addEventListener("input", getNick, false); // Force connect var connectBtn = document.getElementById("connect-btn"); connectBtn.onclick = forceConnect; // Get servers list getServersList(); // Set graphic mode var selectGraph = document.getElementById("select-graph"); if (renderMode == 1) { selectGraph.selectedIndex = 2; } else if (renderMode == 2) { selectGraph.selectedIndex = 1; } else { selectGraph.selectedIndex = 0; normalMode = true; } selectGraph.onchange = function() { var mode = selectGraph.value; if (mode) { renderMode = mode; localStorage.setItem("rendermode", renderMode); } }; resizeView(); } else { setTimeout(setMenu, 100); } } // Load settings function loadSettings() { if (w.localStorage.getItem("nick") != null) { var nick = w.localStorage.getItem("nick"); document.getElementById("nick").value = nick; } if (w.localStorage.getItem("rendermode") != null) { var mode = parseInt(w.localStorage.getItem("rendermode")); if (mode >= 1 && mode <= 3) { renderMode = mode; } } } // Get nick function getNick() { var nick = document.getElementById("nick").value; w.localStorage.setItem("nick", nick); } // Connection status function connectionStatus() { if (!w.connecting || retry == 10) { w.forcing = false; retry = 0; return; } retry++; setTimeout(connectionStatus, 1000); } // Force connect function forceConnect() { if (inpIP.value.length == 0 || !w.connect) { return; } w.forcing = true; if (!w.bso) { w.bso = {}; } var srv = inpIP.value.trim().split(":"); w.bso.ip = srv[0]; w.bso.po = srv[1]; w.connect(); setTimeout(connectionStatus, 1000); } // Get servers list function getServersList() { if (w.sos && w.sos.length > 0) { var selectSrv = document.getElementById("select-srv"); for (var i = 0; i < sos.length; i++) { var srv = sos[i]; var option = document.createElement("option"); option.value = srv.ip + ":" + srv.po; option.text = (i + 1) + ". " + option.value; selectSrv.appendChild(option); } selectSrv.onchange = function() { var srv = selectSrv.value; inpIP.value = srv; }; } else { setTimeout(getServersList, 100); } } // Resize view function resizeView() { if (w.resize) { w.lww = 0; // Reset width (force resize) w.wsu = 0; // Clear ad space w.resize(); var wh = Math.ceil(w.innerHeight); if (wh < 800) { var login = document.getElementById("login"); w.lgbsc = wh / 800; login.style.top = - (Math.round(wh * (1 - w.lgbsc) * 1E5) / 1E5) + "px"; if (w.trf) { w.trf(login, "scale(" + w.lgbsc + "," + w.lgbsc + ")"); } } } else { setTimeout(resizeView, 100); } } // Set leaderboard function setLeaderboard() { if (w.lbh) { w.lbh.textContent = "LendaClan por VP "; w.lbh.style.fontSize = "25px"; } else { setTimeout(setLeaderboard, 100); } } // Set normal mode function setNormalMode() { normalMode = true; w.ggbg = true; if (!w.bgp2 && bgImage) { w.bgp2 = bgImage; } w.render_mode = 2; } // Set graphics function setGraphics() { if (renderMode == 3) { if (!normalMode) { setNormalMode(); } return; } if (normalMode) { normalMode = false; } if (w.want_quality && w.want_quality != 0) { w.want_quality = 0; w.localStorage.setItem("qual", "0"); w.grqi.src = "/s/lowquality.png"; } if (w.ggbg && w.gbgmc) { w.ggbg = false; } if (w.bgp2) { bgImage = w.bgp2; w.bgp2 = null; } if (w.high_quality) { w.high_quality = false; } if (w.gla && w.gla != 0) { w.gla = 0; } if (w.render_mode && w.render_mode != renderMode) { w.render_mode = renderMode; } } // Show FPS function showFPS() { if (w.playing && fpsHUD && w.fps && w.lrd_mtm) { if (Date.now() - w.lrd_mtm > 970) { fpsHUD.textContent = "FPS: " + w.fps; } } setTimeout(showFPS, 30); } // Update loop function updateLoop() { setGraphics(); if (w.playing) { if (positionHUD) { positionHUD.textContent = "X: " + (~~w.view_xx || 0) + " Y: " + (~~w.view_yy || 0); } if (inpIP && w.bso && currentIP != w.bso.ip + ":" + w.bso.po) { currentIP = w.bso.ip + ":" + w.bso.po; inpIP.value = currentIP; if (ipHUD) { ipHUD.textContent = "IP: " + currentIP; } } } setTimeout(updateLoop, 1000); } // Init init(); })(window); (function() { if (localStorage.savec) { document.body.style.backgroundColor = localStorage.getItem("savec"); } var parent = document.getElementById('playh'); var div = document.createElement('div'); var input = document.createElement('input'); var button = document.createElement('span'); input.type = 'color'; input.style.margin = '2px'; input.style.background = 'rgba(0, 0, 0, 0) none repeat scroll 0 0'; input.style.border = '0 none'; input.style.color = '#e0e0ff'; input.style.fontSize = '15px'; input.id = 'nice'; input.value = '#161c22'; button.textContent = 'Change!'; button.style.cursor = 'pointer'; button.style.color = '#FFF'; button.style.borderRadius = '24px'; button.style.margin = '2px'; button.style.padding = '2px 6px'; button.style.background = 'linear-gradient(180deg, #9DA, #485)'; button.onclick = function() { colour(); }; div.appendChild(input); div.appendChild(button); parent.appendChild(div); })(); function colour(){ theColour = document.getElementById('nice').value; localStorage.setItem("savec", theColour); document.body.style.backgroundColor = localStorage.getItem("savec"); } const TARGET_FPS = 30; // Custom logging function - disabled by default window.log = function() { if (window.logDebugging) { console.log.apply(console, arguments); } }; window.getSnakeLength = function() { return (Math.floor( 150 * (window.fpsls[window.snake.sct] + window.snake.fam / window.fmlts[window.snake.sct] - 1) - 50) / 10); }; window.getSnakeWidth = function(sc) { if (sc === undefined) sc = window.snake.sc; return sc * 29.0; }; var canvas = window.canvas = (function() { return { // Ratio of screen size divided by canvas size. canvasRatio: { x: window.mc.width / window.ww, y: window.mc.height / window.hh }, // Spoofs moving the mouse to the provided coordinates. setMouseCoordinates: function(point) { window.xm = point.x; window.ym = point.y; }, // Convert snake-relative coordinates to absolute screen coordinates. mouseToScreen: function(point) { var screenX = point.x + (window.ww / 2); var screenY = point.y + (window.hh / 2); return { x: screenX, y: screenY }; }, // Convert screen coordinates to canvas coordinates. screenToCanvas: function(point) { var canvasX = window.csc * (point.x * canvas.canvasRatio.x) - parseInt(window.mc.style.left); var canvasY = window.csc * (point.y * canvas.canvasRatio.y) - parseInt(window.mc.style.top); return { x: canvasX, y: canvasY }; }, // Convert map coordinates to mouse coordinates. mapToMouse: function(point) { var mouseX = (point.x - window.snake.xx) * window.gsc; var mouseY = (point.y - window.snake.yy) * window.gsc; return { x: mouseX, y: mouseY }; }, // Map cordinates to Canvas cordinate shortcut mapToCanvas: function(point) { var c = canvas.mapToMouse(point); c = canvas.mouseToScreen(c); c = canvas.screenToCanvas(c); return c; }, // Map to Canvas coordinate conversion for drawing circles. // Radius also needs to scale by .gsc circleMapToCanvas: function(circle) { var newCircle = canvas.mapToCanvas(circle); return canvas.circle( newCircle.x, newCircle.y, circle.radius * window.gsc ); }, // Constructor for point type point: function(x, y) { var p = { x: Math.round(x), y: Math.round(y) }; return p; }, // Constructor for rect type rect: function(x, y, w, h) { var r = { x: Math.round(x), y: Math.round(y), width: Math.round(w), height: Math.round(h) }; return r; }, // Constructor for circle type circle: function(x, y, r) { var c = { x: Math.round(x), y: Math.round(y), radius: Math.round(r) }; return c; }, // Fast atan2 fastAtan2: function(y, x) { const QPI = Math.PI / 4; const TQPI = 3 * Math.PI / 4; var r = 0.0; var angle = 0.0; var abs_y = Math.abs(y) + 1e-10; if (x < 0) { r = (x + abs_y) / (abs_y - x); angle = TQPI; } else { r = (x - abs_y) / (x + abs_y); angle = QPI; } angle += (0.1963 * r * r - 0.9817) * r; if (y < 0) { return -angle; } return angle; }, // Adjusts zoom in response to the mouse wheel. setZoom: function(e) { // Scaling ratio if (window.gsc) { window.gsc *= Math.pow(0.9, e.wheelDelta / -120 || e.detail / 2 || 0); window.desired_gsc = window.gsc; } }, // Restores zoom to the default value. resetZoom: function() { window.gsc = 0.9; window.desired_gsc = 0.9; }, // Maintains Zoom maintainZoom: function() { if (window.desired_gsc !== undefined) { window.gsc = window.desired_gsc; } }, // Sets background to the given image URL. // Defaults to slither.io's own background. setBackground: function(url) { url = typeof url !== 'undefined' ? url : '/s/bg45.jpg'; window.ii.src = url; }, // Draw a rectangle on the canvas. drawRect: function(rect, color, fill, alpha) { if (alpha === undefined) alpha = 1; var context = window.mc.getContext('2d'); var lc = canvas.mapToCanvas({x: rect.x, y: rect.y}); context.save(); context.globalAlpha = alpha; context.strokeStyle = color; context.rect(lc.x, lc.y, rect.width * window.gsc, rect.height * window.gsc); context.stroke(); if (fill) { context.fillStyle = color; context.fill(); } context.restore(); }, // Draw a circle on the canvas. drawCircle: function(circle, color, fill, alpha) { if (alpha === undefined) alpha = 1; if (circle.radius === undefined) circle.radius = 5; var context = window.mc.getContext('2d'); var drawCircle = canvas.circleMapToCanvas(circle); context.save(); context.globalAlpha = alpha; context.beginPath(); context.strokeStyle = color; context.arc(drawCircle.x, drawCircle.y, drawCircle.radius, 0, Math.PI * 2); context.stroke(); if (fill) { context.fillStyle = color; context.fill(); } context.restore(); }, // Draw an angle. // @param {number} start -- where to start the angle // @param {number} angle -- width of the angle // @param {bool} danger -- green if false, red if true drawAngle: function(start, angle, color, fill, alpha) { if (alpha === undefined) alpha = 0.6; var context = window.mc.getContext('2d'); context.save(); context.globalAlpha = alpha; context.beginPath(); context.moveTo(window.mc.width / 2, window.mc.height / 2); context.arc(window.mc.width / 2, window.mc.height / 2, window.gsc * 100, start, angle); context.lineTo(window.mc.width / 2, window.mc.height / 2); context.closePath(); context.stroke(); if (fill) { context.fillStyle = color; context.fill(); } context.restore(); }, // Draw a line on the canvas. drawLine: function(p1, p2, color, width) { if (width === undefined) width = 5; var context = window.mc.getContext('2d'); var dp1 = canvas.mapToCanvas(p1); var dp2 = canvas.mapToCanvas(p2); context.save(); context.beginPath(); context.lineWidth = width * window.gsc; context.strokeStyle = color; context.moveTo(dp1.x, dp1.y); context.lineTo(dp2.x, dp2.y); context.stroke(); context.restore(); }, // Given the start and end of a line, is point left. isLeft: function(start, end, point) { return ((end.x - start.x) * (point.y - start.y) - (end.y - start.y) * (point.x - start.x)) > 0; }, // Get distance squared getDistance2: function(x1, y1, x2, y2) { var distance2 = Math.pow(x1 - x2, 2) + Math.pow(y1 - y2, 2); return distance2; }, getDistance2FromSnake: function(point) { point.distance = canvas.getDistance2(window.snake.xx, window.snake.yy, point.xx, point.yy); return point; }, // Check if point in Rect pointInRect: function(point, rect) { if (rect.x <= point.x && rect.y <= point.y && rect.x + rect.width >= point.x && rect.y + rect.height >= point.y) { return true; } return false; }, // Check if circles intersect circleIntersect: function(circle1, circle2) { var bothRadii = circle1.radius + circle2.radius; // Pretends the circles are squares for a quick collision check. // If it collides, do the more expensive circle check. if (circle1.x + bothRadii > circle2.x && circle1.y + bothRadii > circle2.y && circle1.x < circle2.x + bothRadii && circle1.y < circle2.y + bothRadii) { var distance2 = canvas.getDistance2(circle1.x, circle1.y, circle2.x, circle2.y); if (distance2 < bothRadii * bothRadii) { if (window.visualDebugging) { var collisionPointCircle = canvas.circle( ((circle1.x * circle2.radius) + (circle2.x * circle1.radius)) / bothRadii, ((circle1.y * circle2.radius) + (circle2.y * circle1.radius)) / bothRadii, 5 ); canvas.drawCircle(circle2, 'red', true); canvas.drawCircle(collisionPointCircle, 'cyan', true); } return true; } } return false; } }; })(); var bot = window.bot = (function() { return { isBotRunning: false, isBotEnabled: true, lookForFood: false, collisionPoints: [], collisionAngles: [], scores: [], foodTimeout: undefined, sectorBoxSide: 0, defaultAccel: 0, sectorBox: {}, currentFood: {}, MID_X: 0, MID_Y: 0, MAP_R: 0, quickRespawn: function() { window.dead_mtm = 0; window.login_fr = 0; bot.isBotRunning = false; window.forcing = true; window.connect(); window.forcing = false; }, // angleBetween - get the smallest angle between two angles (0-pi) angleBetween: function(a1, a2) { var r1 = 0.0; var r2 = 0.0; r1 = (a1 - a2) % Math.PI; r2 = (a2 - a1) % Math.PI; return r1 < r2 ? -r1 : r2; }, // Avoid headPoint avoidHeadPoint: function(collisionPoint) { var cehang = canvas.fastAtan2( collisionPoint.yy - window.snake.yy, collisionPoint.xx - window.snake.xx); var diff = bot.angleBetween(window.snake.ehang, cehang); // var dir = diff > 0 ? -Math.PI / 2 : Math.PI / 2; // bot.changeHeading(dir); // return; if (Math.abs(diff) > 3 * Math.PI / 4) { var dir = diff > 0 ? -Math.PI / 2 : Math.PI / 2; bot.changeHeading(dir); } else { bot.avoidCollisionPoint(collisionPoint); } }, // Change heading by ang // +0-pi turn left // -0-pi turn right changeHeading: function(angle) { var heading = { x: window.snake.xx + 500 * window.snake.cos, y: window.snake.yy + 500 * window.snake.sin }; var cos = Math.cos(-angle); var sin = Math.sin(-angle); window.goalCoordinates = { x: Math.round( cos * (heading.x - window.snake.xx) - sin * (heading.y - window.snake.yy) + window.snake.xx), y: Math.round( sin * (heading.x - window.snake.xx) + cos * (heading.y - window.snake.yy) + window.snake.yy) }; canvas.setMouseCoordinates(canvas.mapToMouse(window.goalCoordinates)); }, // Avoid collison point by ang // ang radians <= Math.PI (180deg) avoidCollisionPoint: function(collisionPoint, ang) { if (ang === undefined || ang > Math.PI) { ang = Math.PI; } var end = { x: window.snake.xx + 2000 * window.snake.cos, y: window.snake.yy + 2000 * window.snake.sin }; if (window.visualDebugging) { canvas.drawLine( {x: window.snake.xx, y: window.snake.yy}, end, 'orange', 5); canvas.drawLine( {x: window.snake.xx, y: window.snake.yy}, {x: collisionPoint.xx, y: collisionPoint.yy}, 'red', 5); } var cos = Math.cos(ang); var sin = Math.sin(ang); if (canvas.isLeft( { x: window.snake.xx, y: window.snake.yy }, end, { x: collisionPoint.xx, y: collisionPoint.yy })) { sin = -sin; } window.goalCoordinates = { x: Math.round( cos * (collisionPoint.xx - window.snake.xx) - sin * (collisionPoint.yy - window.snake.yy) + window.snake.xx), y: Math.round( sin * (collisionPoint.xx - window.snake.xx) + cos * (collisionPoint.yy - window.snake.yy) + window.snake.yy) }; canvas.setMouseCoordinates(canvas.mapToMouse(window.goalCoordinates)); }, // Sorting by property 'distance' sortDistance: function(a, b) { return a.distance - b.distance; }, // get collision angle index, expects angle +/i 0 to Math.PI getAngleIndex: function(angle) { const ARCSIZE = Math.PI / 4; var index; if (angle < 0) { angle += 2 * Math.PI; } index = Math.round(angle * (1 / ARCSIZE)); if (index === (2 * Math.PI) / ARCSIZE) { return 0; } return index; }, // Add to collisionAngles if distance is closer addCollisionAngle: function(sp) { var ang = canvas.fastAtan2( Math.round(sp.yy - window.snake.yy), Math.round(sp.xx - window.snake.xx)); var aIndex = bot.getAngleIndex(ang); var actualDistance = Math.round( sp.distance - (Math.pow(window.getSnakeWidth(window.snakes[sp.snake].sc), 2) / 2)); if (bot.collisionAngles[aIndex] === undefined) { bot.collisionAngles[aIndex] = { x: Math.round(sp.xx), y: Math.round(sp.yy), ang: ang, snake: sp.snake, distance: actualDistance }; } else if (bot.collisionAngles[aIndex].distance > sp.distance) { bot.collisionAngles[aIndex].x = Math.round(sp.xx); bot.collisionAngles[aIndex].y = Math.round(sp.yy); bot.collisionAngles[aIndex].ang = ang; bot.collisionAngles[aIndex].snake = sp.snake; bot.collisionAngles[aIndex].distance = actualDistance; } }, // Get closest collision point per snake. getCollisionPoints: function() { var scPoint; bot.collisionPoints = []; bot.collisionAngles = []; for (var snake = 0, ls = window.snakes.length; snake < ls; snake++) { scPoint = undefined; if (window.snakes[snake].id !== window.snake.id && window.snakes[snake].alive_amt === 1) { if (window.visualDebugging) { canvas.drawCircle(canvas.circle( window.snakes[snake].xx, window.snakes[snake].yy, window.getSnakeWidth(window.snakes[snake].sc) / 2), 'red', false); } scPoint = { xx: window.snakes[snake].xx, yy: window.snakes[snake].yy, snake: snake }; canvas.getDistance2FromSnake(scPoint); bot.addCollisionAngle(scPoint); for (var pts = 0, lp = window.snakes[snake].pts.length; pts < lp; pts++) { if (!window.snakes[snake].pts[pts].dying && canvas.pointInRect( {x: window.snakes[snake].pts[pts].xx, y: window.snakes[snake].pts[pts].yy}, bot.sectorBox) ) { var collisionPoint = { xx: window.snakes[snake].pts[pts].xx, yy: window.snakes[snake].pts[pts].yy, snake: snake }; if (window.visualDebugging && true === false) { canvas.drawCircle(canvas.circle( collisionPoint.xx, collisionPoint.yy, window.getSnakeWidth(window.snakes[snake].sc) / 2), '#00FF00', false); } canvas.getDistance2FromSnake(collisionPoint); bot.addCollisionAngle(collisionPoint); if (scPoint === undefined || scPoint.distance > collisionPoint.distance) { scPoint = collisionPoint; } } } } if (scPoint !== undefined) { bot.collisionPoints.push(scPoint); if (window.visualDebugging) { canvas.drawCircle(canvas.circle( scPoint.xx, scPoint.yy, window.getSnakeWidth(window.snakes[scPoint.snake].sc) / 2 ), 'red', false); } } } if (canvas.getDistance2(bot.MID_X, bot.MID_Y, window.snake.xx, window.snake.yy) > Math.pow(bot.MAP_R - 1000, 2)) { var midAng = canvas.fastAtan2( window.snake.yy - bot.MID_X, window.snake.xx - bot.MID_Y); scPoint = { xx: bot.MID_X + bot.MAP_R * Math.cos(midAng), yy: bot.MID_Y + bot.MAP_R * Math.sin(midAng), snake: -1 }; bot.collisionPoints.push(scPoint); if (window.visualDebugging) { canvas.drawCircle(canvas.circle( scPoint.xx, scPoint.yy, window.getSnakeWidth(1) * 5 ), 'yellow', false); } } bot.collisionPoints.sort(bot.sortDistance); if (window.visualDebugging) { for (var i = 0; i < bot.collisionAngles.length; i++) { if (bot.collisionAngles[i] !== undefined) { canvas.drawLine( {x: window.snake.xx, y: window.snake.yy}, {x: bot.collisionAngles[i].x, y: bot.collisionAngles[i].y}, '#99ffcc', 2); } } } }, // Checks to see if you are going to collide with anything in the collision detection radius checkCollision: function(r) { if (!window.collisionDetection) return false; r = Number(r); var xx = Number(window.snake.xx.toFixed(3)); var yy = Number(window.snake.yy.toFixed(3)); window.snake.cos = Math.cos(window.snake.ang).toFixed(3); window.snake.sin = Math.sin(window.snake.ang).toFixed(3); const speedMult = window.snake.sp / 5.78; const widthMult = window.getSnakeWidth(); var headCircle = canvas.circle( xx, yy, speedMult * r / 2 * widthMult / 2 ); var fullHeadCircle = canvas.circle( xx, yy, r * widthMult / 2 ); var sidecircle_r = canvas.circle( window.snake.lnp.xx - ((window.snake.lnp.yy + window.snake.sin * window.getSnakeWidth()) - window.snake.lnp.yy), window.snake.lnp.yy + ((window.snake.lnp.xx + window.snake.cos * window.getSnakeWidth()) - window.snake.lnp.xx), window.getSnakeWidth() * speedMult ); var sidecircle_l = canvas.circle( window.snake.lnp.xx + ((window.snake.lnp.yy + window.snake.sin * window.getSnakeWidth()) - window.snake.lnp.yy), window.snake.lnp.yy - ((window.snake.lnp.xx + window.snake.cos * window.getSnakeWidth()) - window.snake.lnp.xx), window.getSnakeWidth() * speedMult ); window.snake.sidecircle_r = sidecircle_r; window.snake.sidecircle_l = sidecircle_l; if (window.visualDebugging) { canvas.drawCircle(fullHeadCircle, 'red'); canvas.drawCircle(headCircle, 'blue', false); // canvas.drawCircle(sidecircle_r, 'orange', true, 0.3); // canvas.drawCircle(sidecircle_l, 'orange', true, 0.3); } bot.getCollisionPoints(); if (bot.collisionPoints.length === 0) return false; for (var i = 0; i < bot.collisionPoints.length; i++) { // -1 snake is special case for non snake object. var colR = bot.collisionPoints[i].snake === -1 ? window.getSnakeWidth(1) * 5 : window.getSnakeWidth(window.snakes[bot.collisionPoints[i].snake].sc) / 2; var collisionCircle = canvas.circle( bot.collisionPoints[i].xx, bot.collisionPoints[i].yy, colR ); if (canvas.circleIntersect(headCircle, collisionCircle)) { window.setAcceleration(bot.defaultAccel); bot.avoidCollisionPoint(bot.collisionPoints[i]); return true; } if (bot.collisionPoints[i].snake !== -1) { var eHeadCircle = canvas.circle( window.snakes[bot.collisionPoints[i].snake].xx, window.snakes[bot.collisionPoints[i].snake].yy, colR ); if (canvas.circleIntersect(fullHeadCircle, eHeadCircle)) { if (window.snakes[bot.collisionPoints[i].snake].sp > 10) { window.setAcceleration(1); } else { window.setAcceleration(bot.defaultAccel); } bot.avoidHeadPoint({ xx: window.snakes[bot.collisionPoints[i].snake].xx, yy: window.snakes[bot.collisionPoints[i].snake].yy }); return true; } } } window.setAcceleration(bot.defaultAccel); return false; }, sortScore: function(a, b) { return b.score - a.score; }, // 2.546 ~ 1 / (Math.PI / 8) - round angle difference up to nearest 22.5 degrees. // Round food up to nearest 5, square for distance^2 scoreFood: function(f) { f.score = Math.pow(Math.ceil(f.sz / 5) * 5, 2) / f.distance / (Math.ceil(f.da * 2.546) / 2.546); }, computeFoodGoal: function() { var foodClusters = []; var foodGetIndex = []; var fi = 0; var sw = window.getSnakeWidth(); for (var i = 0; i < window.foods.length && window.foods[i] !== null; i++) { var a; var da; var distance; var sang = window.snake.ehang; var f = window.foods[i]; if (!f.eaten && !( canvas.circleIntersect( canvas.circle(f.xx, f.yy, 2), window.snake.sidecircle_l) || canvas.circleIntersect( canvas.circle(f.xx, f.yy, 2), window.snake.sidecircle_r))) { var cx = Math.round(Math.round(f.xx / sw) * sw); var cy = Math.round(Math.round(f.yy / sw) * sw); var csz = Math.round(f.sz); if (foodGetIndex[cx + '|' + cy] === undefined) { foodGetIndex[cx + '|' + cy] = fi; a = canvas.fastAtan2(cy - window.snake.yy, cx - window.snake.xx); da = Math.min( (2 * Math.PI) - Math.abs(a - sang), Math.abs(a - sang)); distance = Math.round( canvas.getDistance2(cx, cy, window.snake.xx, window.snake.yy)); foodClusters[fi] = { x: cx, y: cy, a: a, da: da, sz: csz, distance: distance, score: 0.0 }; fi++; } else { foodClusters[foodGetIndex[cx + '|' + cy]].sz += csz; } } } foodClusters.forEach(bot.scoreFood); foodClusters.sort(bot.sortScore); for (i = 0; i < foodClusters.length; i++) { var aIndex = bot.getAngleIndex(foodClusters[i].a); if (bot.collisionAngles[aIndex] === undefined || (bot.collisionAngles[aIndex].distance - Math.pow(window.getSnakeWidth(), 2) > foodClusters[i].distance && foodClusters[i].sz > 10) ) { bot.currentFood = foodClusters[i]; return; } } bot.currentFood = {x: bot.MID_X, y: bot.MID_Y}; }, foodAccel: function() { var aIndex = 0; if (bot.currentFood && bot.currentFood.sz > 60) { aIndex = bot.getAngleIndex(bot.currentFood.a); if ( bot.collisionAngles[aIndex] && bot.collisionAngles[aIndex].distance > bot.currentFood.distance * 2) { return 1; } if (bot.collisionAngles[aIndex] === undefined) { return 1; } } return bot.defaultAccel; }, // Loop version of collision check collisionLoop: function() { bot.MID_X = window.grd; bot.MID_Y = window.grd; bot.MAP_R = window.grd * 0.98; bot.sectorBoxSide = Math.floor(Math.sqrt(window.sectors.length)) * window.sector_size; bot.sectorBox = canvas.rect( window.snake.xx - (bot.sectorBoxSide / 2), window.snake.yy - (bot.sectorBoxSide / 2), bot.sectorBoxSide, bot.sectorBoxSide); // if (window.visualDebugging) canvas.drawRect(bot.sectorBox, '#c0c0c0', true, 0.1); if (bot.checkCollision(window.collisionRadiusMultiplier)) { bot.lookForFood = false; if (bot.foodTimeout) { window.clearTimeout(bot.foodTimeout); bot.foodTimeout = window.setTimeout(bot.foodTimer, 1000 / TARGET_FPS * 4); } } else { bot.lookForFood = true; if (bot.foodTimeout === undefined) { bot.foodTimeout = window.setTimeout(bot.foodTimer, 1000 / TARGET_FPS * 4); } window.setAcceleration(bot.foodAccel()); } }, // Timer version of food check foodTimer: function() { if (window.playing && bot.lookForFood && window.snake !== null && window.snake.alive_amt === 1) { bot.computeFoodGoal(); window.goalCoordinates = bot.currentFood; canvas.setMouseCoordinates(canvas.mapToMouse(window.goalCoordinates)); } bot.foodTimeout = undefined; } }; })(); var userInterface = window.userInterface = (function() { // Save the original slither.io functions so we can modify them, or reenable them later. var original_keydown = document.onkeydown; var original_onmouseDown = window.onmousedown; var original_oef = window.oef; var original_redraw = window.redraw; var original_onmousemove = window.onmousemove; window.oef = function() {}; window.redraw = function() {}; return { overlays: {}, initOverlays: function() { var botOverlay = document.createElement('div'); botOverlay.style.position = 'fixed'; botOverlay.style.right = '5px'; botOverlay.style.bottom = '112px'; botOverlay.style.width = '150px'; botOverlay.style.height = '85px'; // botOverlay.style.background = 'rgba(0, 0, 0, 0.5)'; botOverlay.style.color = '#C0C0C0'; botOverlay.style.fontFamily = 'Consolas, Verdana'; botOverlay.style.zIndex = 999; botOverlay.style.fontSize = '14px'; botOverlay.style.padding = '5px'; botOverlay.style.borderRadius = '5px'; botOverlay.className = 'nsi'; document.body.appendChild(botOverlay); var serverOverlay = document.createElement('div'); serverOverlay.style.position = 'fixed'; serverOverlay.style.right = '5px'; serverOverlay.style.bottom = '5px'; serverOverlay.style.width = '160px'; serverOverlay.style.height = '14px'; serverOverlay.style.color = '#C0C0C0'; serverOverlay.style.fontFamily = 'Consolas, Verdana'; serverOverlay.style.zIndex = 999; serverOverlay.style.fontSize = '14px'; serverOverlay.className = 'nsi'; document.body.appendChild(serverOverlay); var prefOverlay = document.createElement('div'); prefOverlay.style.position = 'fixed'; prefOverlay.style.left = '10px'; prefOverlay.style.top = '75px'; prefOverlay.style.width = '260px'; prefOverlay.style.height = '210px'; // prefOverlay.style.background = 'rgba(0, 0, 0, 0.5)'; prefOverlay.style.color = '#C0C0C0'; prefOverlay.style.fontFamily = 'Consolas, Verdana'; prefOverlay.style.zIndex = 999; prefOverlay.style.fontSize = '14px'; prefOverlay.style.padding = '5px'; prefOverlay.style.borderRadius = '5px'; prefOverlay.className = 'nsi'; document.body.appendChild(prefOverlay); var statsOverlay = document.createElement('div'); statsOverlay.style.position = 'fixed'; statsOverlay.style.left = '10px'; statsOverlay.style.top = '295px'; statsOverlay.style.width = '140px'; statsOverlay.style.height = '210px'; // statsOverlay.style.background = 'rgba(0, 0, 0, 0.5)'; statsOverlay.style.color = '#C0C0C0'; statsOverlay.style.fontFamily = 'Consolas, Verdana'; statsOverlay.style.zIndex = 998; statsOverlay.style.fontSize = '14px'; statsOverlay.style.padding = '5px'; statsOverlay.style.borderRadius = '5px'; statsOverlay.className = 'nsi'; document.body.appendChild(statsOverlay); userInterface.overlays.botOverlay = botOverlay; userInterface.overlays.serverOverlay = serverOverlay; userInterface.overlays.prefOverlay = prefOverlay; userInterface.overlays.statsOverlay = statsOverlay; }, toggleOverlays: function() { Object.keys(userInterface.overlays).forEach(function(okey) { var oVis = userInterface.overlays[okey].style.visibility !== 'hidden' ? 'hidden' : 'visible'; userInterface.overlays[okey].style.visibility = oVis; window.visualDebugging = oVis === 'visible'; }); }, // Save variable to local storage savePreference: function(item, value) { window.localStorage.setItem(item, value); userInterface.onPrefChange(); }, // Load a variable from local storage loadPreference: function(preference, defaultVar) { var savedItem = window.localStorage.getItem(preference); if (savedItem !== null) { if (savedItem === 'true') { window[preference] = true; } else if (savedItem === 'false') { window[preference] = false; } else { window[preference] = savedItem; } window.log('Setting found for ' + preference + ': ' + window[preference]); } else { window[preference] = defaultVar; window.log('No setting found for ' + preference + '. Used default: ' + window[preference]); } userInterface.onPrefChange(); return window[preference]; }, // Saves username when you click on "Play" button playButtonClickListener: function() { userInterface.saveNick(); userInterface.loadPreference('autoRespawn', false); userInterface.onPrefChange(); }, // Preserve nickname saveNick: function() { var nick = document.getElementById('nick').value; userInterface.savePreference('savedNick', nick); }, // Hide top score hideTop: function() { var nsidivs = document.querySelectorAll('div.nsi'); for (var i = 0; i < nsidivs.length; i++) { if (nsidivs[i].style.top === '4px' && nsidivs[i].style.width === '300px') { nsidivs[i].style.visibility = 'hidden'; bot.isTopHidden = true; window.topscore = nsidivs[i]; } } }, // Store FPS data framesPerSecond: { fps: 0, fpsTimer: function() { if (window.playing && window.fps && window.lrd_mtm) { if (Date.now() - window.lrd_mtm > 970) { userInterface.framesPerSecond.fps = window.fps; } } } }, onkeydown: function(e) { // Original slither.io onkeydown function + whatever is under it original_keydown(e); if (window.playing) { // Letter `T` to toggle bot if (e.keyCode === 84) { bot.isBotEnabled = !bot.isBotEnabled; } // Letter 'U' to toggle debugging (console) if (e.keyCode === 85) { window.logDebugging = !window.logDebugging; console.log('Log debugging set to: ' + window.logDebugging); userInterface.savePreference('logDebugging', window.logDebugging); } // Letter 'Y' to toggle debugging (visual) if (e.keyCode === 89) { window.visualDebugging = !window.visualDebugging; console.log('Visual debugging set to: ' + window.visualDebugging); userInterface.savePreference('visualDebugging', window.visualDebugging); } // Letter 'I' to toggle autorespawn if (e.keyCode === 73) { window.autoRespawn = !window.autoRespawn; console.log('Automatic Respawning set to: ' + window.autoRespawn); userInterface.savePreference('autoRespawn', window.autoRespawn); } // Letter 'H' to toggle hidden mode if (e.keyCode === 72) { userInterface.toggleOverlays(); } // Letter 'O' to change rendermode (visual) if (e.keyCode === 79) { userInterface.toggleMobileRendering(!window.mobileRender); } // Letter 'C' to toggle Collision detection / enemy avoidance if (e.keyCode === 67) { window.collisionDetection = !window.collisionDetection; console.log('collisionDetection set to: ' + window.collisionDetection); userInterface.savePreference('collisionDetection', window.collisionDetection); } // Letter 'A' to increase collision detection radius if (e.keyCode === 65) { window.collisionRadiusMultiplier++; console.log( 'collisionRadiusMultiplier set to: ' + window.collisionRadiusMultiplier); userInterface.savePreference( 'collisionRadiusMultiplier', window.collisionRadiusMultiplier); } // Letter 'S' to decrease collision detection radius if (e.keyCode === 83) { if (window.collisionRadiusMultiplier > 1) { window.collisionRadiusMultiplier--; console.log( 'collisionRadiusMultiplier set to: ' + window.collisionRadiusMultiplier); userInterface.savePreference( 'collisionRadiusMultiplier', window.collisionRadiusMultiplier); } } // Letter 'Z' to reset zoom if (e.keyCode === 90) { canvas.resetZoom(); } // Letter 'Q' to quit to main menu if (e.keyCode === 81) { window.autoRespawn = false; userInterface.quit(); } // 'ESC' to quickly respawn if (e.keyCode === 27) { bot.quickRespawn(); } // Save nickname when you press "Enter" if (e.keyCode === 13) { userInterface.saveNick(); } userInterface.onPrefChange(); } }, onmousedown: function(e) { if (window.playing) { switch (e.which) { // "Left click" to manually speed up the slither case 1: bot.defaultAccel = 1; if (!bot.isBotEnabled) { original_onmouseDown(e); } break; // "Right click" to toggle bot in addition to the letter "T" case 3: bot.isBotEnabled = !bot.isBotEnabled; break; } } else { original_onmouseDown(e); } userInterface.onPrefChange(); }, onmouseup: function() { bot.defaultAccel = 0; }, // Manual mobile rendering toggleMobileRendering: function(mobileRendering) { window.mobileRender = mobileRendering; window.log('Mobile rendering set to: ' + window.mobileRender); userInterface.savePreference('mobileRender', window.mobileRender); // Set render mode if (window.mobileRender) { canvas.setBackground( ''); window.render_mode = 1; window.want_quality = 0; window.high_quality = false; } else { canvas.setBackground(); window.render_mode = 2; window.want_quality = 1; window.high_quality = true; } }, // Update stats overlay. updateStats: function() { var oContent = []; if (bot.scores.length === 0) return; oContent.push('games played: ' + bot.scores.length); oContent.push('avg score: ' + Math.round( bot.scores.reduce(function(a, b) { return a + b; }) / (bot.scores.length))); for (var i = 0; i < bot.scores.length && i < 10; i++) { oContent.push(i + 1 + '. ' + bot.scores[i]); } userInterface.overlays.statsOverlay.innerHTML = oContent.join('<br/>'); }, onPrefChange: function() { // Set static display options here. var oContent = []; var ht = userInterface.handleTextColor; oContent.push('Vers�o: ' + GM_info.script.version); oContent.push('[T] Inteligencia Artificial: ' + ht(bot.isBotEnabled)); oContent.push('[C] Colisao Detectada: ' + ht(window.collisionDetection)); oContent.push('[O] Renderizacao Rapida: ' + ht(window.mobileRender)); oContent.push('[A/S] radius multiplier: ' + window.collisionRadiusMultiplier); oContent.push('[I] Renascimento Automatico: ' + ht(window.autoRespawn)); oContent.push('[Y] visual debugging: ' + ht(window.visualDebugging)); oContent.push('[U] log debugging: ' + ht(window.logDebugging)); oContent.push('[Rodinha do Mouse] zoom'); oContent.push('[Z] Resetar Zoom'); oContent.push('[ESC] Renascimento Manual'); oContent.push('[Q] Volte ao Menu'); userInterface.overlays.prefOverlay.innerHTML = oContent.join('<br/>'); }, onFrameUpdate: function() { // Botstatus overlay var oContent = []; if (window.playing && window.snake !== null) { oContent.push('fps: ' + userInterface.framesPerSecond.fps); // Display the X and Y of the snake oContent.push('x: ' + (Math.round(window.snake.xx) || 0) + ' y: ' + (Math.round(window.snake.yy) || 0)); if (window.goalCoordinates) { oContent.push('target'); oContent.push('x: ' + window.goalCoordinates.x + ' y: ' + window.goalCoordinates.y); if (window.goalCoordinates.sz) { oContent.push('sz: ' + window.goalCoordinates.sz); } } if (window.bso !== undefined && userInterface.overlays.serverOverlay.innerHTML !== window.bso.ip + ':' + window.bso.po) { userInterface.overlays.serverOverlay.innerHTML = window.bso.ip + ':' + window.bso.po; } } userInterface.overlays.botOverlay.innerHTML = oContent.join('<br/>'); if (window.playing && window.visualDebugging) { // Only draw the goal when a bot has a goal. if (window.goalCoordinates && bot.isBotEnabled) { var headCoord = {x: window.snake.xx, y: window.snake.yy}; canvas.drawLine( headCoord, window.goalCoordinates, 'green'); canvas.drawCircle(window.goalCoordinates, 'red', true); } } }, oefTimer: function() { var start = Date.now(); canvas.maintainZoom(); original_oef(); original_redraw(); if (window.playing && bot.isBotEnabled && window.snake !== null) { window.onmousemove = function() { }; bot.isBotRunning = true; bot.collisionLoop(); } else if (bot.isBotEnabled && bot.isBotRunning) { bot.isBotRunning = false; if (window.lastscore && window.lastscore.childNodes[1]) { bot.scores.push(parseInt(window.lastscore.childNodes[1].innerHTML)); bot.scores.sort(function(a, b) { return b - a; }); userInterface.updateStats(); } if (window.autoRespawn) { window.connect(); } } if (!bot.isBotEnabled || !bot.isBotRunning) { window.onmousemove = original_onmousemove; } userInterface.onFrameUpdate(); setTimeout(userInterface.oefTimer, (1000 / TARGET_FPS) - (Date.now() - start)); }, // Quit to menu quit: function() { if (window.playing && window.resetGame) { window.want_close_socket = true; window.dead_mtm = 0; if (window.play_btn) { window.play_btn.setEnabled(true); } window.resetGame(); } }, // Update the relation between the screen and the canvas. onresize: function() { window.resize(); // Canvas different size from the screen (often bigger). canvas.canvasRatio = { x: window.mc.width / window.ww, y: window.mc.height / window.hh }; }, handleTextColor: function(enabled) { return '<span style=\"color:' + (enabled ? 'green;\">enabled' : 'red;\">disabled') + '</span>'; } }; })(); function setMenu() { var login = document.getElementById("login"); if (login) { var div = document.createElement("div"); div.style.width = "700px"; div.style.color = "#85f9ae"; div.style.fontFamily = "'Arial'"; div.style.fontSize = "13px"; div.style.textAlign = "center"; div.style.opacity = "2"; div.style.margin = "0 auto"; div.style.padding = "5px 0"; div.style.lineHeight = "18px"; login.appendChild(div); var stmenu = document.createElement("div"); stmenu.style.width = "400px"; stmenu.style.color = "#8058D0"; stmenu.style.borderRadius = "4px"; stmenu.style.fontFamily = "'Arial'"; stmenu.style.fontSize = "14px"; stmenu.style.textAlign = "center"; stmenu.style.margin = "0 auto 100px auto"; stmenu.style.padding = "0 14px"; stmenu.innerHTML = "Script feito para remover o lag e acabar com a queda de fps <a style='color:#8058D0;' target='_blank' href='https://www.youtube.com/channel/UCoBGsoKsFo7YoRvh-cqOWdg'> https://www.youtube.com/channel/UCoBGsoKsFo7YoRvh-cqOWdg [CLIQUE AQUI]</a>"; login.appendChild(stmenu); stmenu.appendChild(div); stmenu.innerHTML += '<a href="https://www.youtube.com/channel/UCQKXYBeXtmCe4PQ6gwWg-1A" target="_blank" style="color:#00cbea;opacity:2;text-decoration:none;">Mod dos Lendas criado por: https://www.youtube.com/channel/UCQKXYBeXtmCe4PQ6gwWg-1A</a> | <a href="https://www.youtube.com/channel/UCoBGsoKsFo7YoRvh-cqOWdg" target="_blank" style="color:#85f9ae;opacity:2;text-decoration:none;">Canal dos LENDAS:https://www.youtube.com/channel/UCoBGsoKsFo7YoRvh-cqOWdg </a>'; } } setMenu(); // Main (function() { window.play_btn.btnf.addEventListener('click', userInterface.playButtonClickListener); document.onkeydown = userInterface.onkeydown; window.onmousedown = userInterface.onmousedown; window.addEventListener('mouseup', userInterface.onmouseup); window.onresize = userInterface.onresize; // Hide top score userInterface.hideTop(); // Overlays userInterface.initOverlays(); // Load preferences userInterface.loadPreference('logDebugging', false); userInterface.loadPreference('visualDebugging', false); userInterface.loadPreference('autoRespawn', false); userInterface.loadPreference('mobileRender', false); userInterface.loadPreference('collisionDetection', true); userInterface.loadPreference('collisionRadiusMultiplier', 10); window.nick.value = userInterface.loadPreference('savedNick', 'Slither.io-bot'); // Listener for mouse wheel scroll - used for setZoom function document.body.addEventListener('mousewheel', canvas.setZoom); document.body.addEventListener('DOMMouseScroll', canvas.setZoom); // Set render mode if (window.mobileRender) { userInterface.toggleMobileRendering(true); } else { userInterface.toggleMobileRendering(false); } // Unblocks all skins without the need for FB sharing. window.localStorage.setItem('edttsg', '1'); // Remove social window.social.remove(); // Maintain fps setInterval(userInterface.framesPerSecond.fpsTimer, 80); // Start! userInterface.oefTimer(); })();