// ==UserScript== // @name The Ultimate Ratio Script (time, score/min, projected times) // @namespace http://tampermonkey.net/ // @version 1.8.3 // @description Uses time from your computer to calculate your ratio and expected time to get milestones based on that // @author MrCheese#4666 // @match https://diep.io/ // @grant none // @downloadURL https://update.greasyfork.icu/scripts/425726/The%20Ultimate%20Ratio%20Script%20%28time%2C%20scoremin%2C%20projected%20times%29.user.js // @updateURL https://update.greasyfork.icu/scripts/425726/The%20Ultimate%20Ratio%20Script%20%28time%2C%20scoremin%2C%20projected%20times%29.meta.js // ==/UserScript== (function() { 'use strict'; // Add HTML elements const textContainer = document.createElement("div"); const gui = document.createElement("div"); document.body.appendChild(textContainer); document.body.appendChild(gui); // Enabled/disabled lines var dispLine1 = false; var dispLine2 = true; var dispLine3 = true; var dispLine4 = false; var dispLine5 = true; var dispLine6 = true; // Set variables var time = '00:00:00'; var rawTime = 0; var rawRatio = 0; var showText = true; var _100k = false; var _500k = false; var _1m = false; var _1_5m = false; var _2m = false; var _100kTime = '100k 00:00:00'; var _500kTime = '500k 00:00:00'; var _1mTime = '1.0m 00:00:00'; var _1_5mTime = '1.5m 00:00:00'; var _2mTime = '2.0m 00:00:00'; var ratio = '0/min'; updateText(); gui.outerHTML = `
`; if (localStorage.getItem('menu') == 'hide') { menu.style.display = "block"; } else { localStorage.setItem('menu', 'hide'); } addButtonListener('button1'); addButtonListener('button2'); addButtonListener('button3'); addButtonListener('button4'); addButtonListener('button5'); addButtonListener('button6'); updateGui(); function addButtonListener(id) { document.getElementById(id).addEventListener("click", function() {buttonAction(id)}); document.getElementById(id).addEventListener("mouseenter", function() {lightenColor(id)}); document.getElementById(id).addEventListener("mouseleave", function() {resetColor(id)}); } function lightenColor(id) { document.getElementById(id).style.opacity = '100%' } function resetColor(id) { document.getElementById(id).style.opacity = '75%' } // Removes "diep.io" text above the minimap to preserve space (by ABC) const crx = CanvasRenderingContext2D.prototype; crx.fillText = new Proxy(crx.fillText, { apply: function(f, _this, args) { const text = args[0]; if (args[0] === "diep.io") { args[0] = ""; } f.apply(_this, args); } }); crx.strokeText = new Proxy(crx.strokeText, { apply: function(f, _this, args) { const text = args[0]; if (args[0] === "diep.io") { args[0] = ""; } f.apply(_this, args); } }); // Button action function buttonAction(id) { let button = document.getElementById(id); if (button.value == "on") button.value = "off" else button.value = "on" if (id == 'button1') { if (dispLine1 == true) dispLine1 = false else dispLine1 = true } if (id == 'button2') { if (dispLine2 == true) dispLine2 = false else dispLine2 = true } if (id == 'button3') { if (dispLine3 == true) dispLine3 = false else dispLine3 = true } if (id == 'button4') { if (dispLine4 == true) dispLine4 = false else dispLine4 = true } if (id == 'button5') { if (dispLine5 == true) dispLine5 = false else dispLine5 = true } if (id == 'button6') { if (dispLine6 == true) dispLine6 = false else dispLine6 = true } updateText(); updateGui(); } // Update GUI function updateGui() { let button1Text = '100k: ' + document.getElementById('button1').value; let button2Text = '500k: ' + document.getElementById('button2').value; let button3Text = '1.0m: ' + document.getElementById('button3').value; let button4Text = '1.5m: ' + document.getElementById('button4').value; let button5Text = '2.0m: ' + document.getElementById('button5').value; let button6Text = 'Ratio: ' + document.getElementById('button6').value; document.getElementById('button1').innerHTML = button1Text; document.getElementById('button2').innerHTML = button2Text; document.getElementById('button3').innerHTML = button3Text; document.getElementById('button4').innerHTML = button4Text; document.getElementById('button5').innerHTML = button5Text; document.getElementById('button6').innerHTML = button6Text; } // Reset times at the start of each round function resetTimes() { _100kTime = '100k 00:00:00'; _500kTime = '500k 00:00:00'; _1mTime = '1.0m 00:00:00'; _1_5mTime = '1.5m 00:00:00'; _2mTime = '2.0m 00:00:00'; ratio = '0/min'; } // Press X to toggle text and Z to toggle menu document.body.onkeydown = function(e) { if (e.keyCode === 88) { if (showText == false) { textContainer.style.opacity = '100%'; showText = true; } else { textContainer.style.opacity = '0%'; showText = false; } } if (e.keyCode === 90) { var menu = document.getElementById('menu'); if (menu.style.display === "none") { menu.style.display = "block"; } else { menu.style.display = "none"; } } } // Get current score (by ABC) let _rScore = "0"; CanvasRenderingContext2D.prototype.fillText = new Proxy(CanvasRenderingContext2D.prototype.fillText, { apply(fillRect, ctx, [text, x, y, ...blah]) { if (text.startsWith('Score: ')) _rScore = text fillRect.call(ctx, text, x, y, ...blah); } }); const getScore = () => { if (!input.should_prevent_unload()) return -1; return parseFloat(_rScore.slice(7).replace(/,/g, '')); } // Parse time for projected score times function timeParse(score) { let _time = (score / rawRatio) * 60; let hours = 0; let minutes = 0; let seconds = 0; if (_time >= 3600) { hours = Math.round(_time / 3600 - 0.5); _time -= hours * 3600; if (hours < 10) hours = '0' + hours; } else hours = '00'; if (_time >= 60) { minutes = Math.round(_time / 60 - 0.5); _time -= minutes * 60; if (minutes < 10) minutes = '0' + minutes; } else minutes = '00'; if (_time !== 0) { seconds = Math.round(_time); if (seconds < 10) seconds = '0' + seconds; } else seconds = '00'; let parsedTime = hours + ':' + minutes + ':' + seconds; return parsedTime; } // Update text function updateText() { let line1 = _100kTime; let line2 = _500kTime; let line3 = _1mTime; let line4 = _1_5mTime; let line5 = _2mTime; let line6 = ratio; if (dispLine1 == false) line1 = '' if (dispLine2 == false) line2 = '' if (dispLine3 == false) line3 = '' if (dispLine4 == false) line4 = '' if (dispLine5 == false) line5 = '' if (dispLine6 == false) line6 = '' textContainer.innerHTML = `