您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
shows minerals at planets and ships in several formats.
当前为
// ==UserScript== // @name showMinerals // @description shows minerals at planets and ships in several formats. // @include http://play.planets.nu/* // @include http://test.planets.nu/* // @include http://planets.nu/* // @version 3.0.0 // @homepage https://greasyfork.org/en/users/32642-stephen-piper // @namespace https://greasyfork.org/users/32642 // ==/UserScript== function wrapper() { var resources = [ { name : "Neutronium", showRes : false, color : "red", surface : 0, ground : 0 }, { name : "Duranium", showRes : false, color : "cyan", surface : 0, ground : 0 }, { name : "Tritanium", showRes : false, color : "orange", surface : 0, ground : 0 }, { name : "Molybdenum", showRes : false, color : "violet", surface : 0, ground : 0 }, { name : "Megacredits", showRes : false, color : "lightgreen", surface : 0, ground : 0 } ]; var showBars = false; var showText = false; var buildStarbase = false; var buildFighters = false; function showMinerals() { } showMinerals.prototype = { loadControls : function() { // debugger; this.clearData(); if (vgapMap.prototype.spMenuItem != undefined) { for (var i = 0; i < resources.length; ++i) { // weird declaration fits the color into the existing class vgapMap.prototype.spMenuItem(resources[i].name, "showMinerals\' style=\'color:" + resources[i].color, function() { showMinerals.prototype.toggleRes(event.target.innerHTML); }); } vgapMap.prototype.spMenuItem("Text", "showText", function() { showText = !showText; showBars = false; buildStarbase = false; buildFighters = false; vgap.map.draw(); }); // vgapMap.prototype.spMenuItem("Bar Graph", "showBarGraph", function() { // showBars = !showBars; // if (showBars) { // showText = false; // buildStarbase = false; // buildFighters = false; // } // }); vgapMap.prototype.spMenuItem("Build Starbase", "buildStarbase", function() { buildStarbase = !buildStarbase; showMinerals.prototype.clearRes(); showBars = false; showText = false; buildFighters = false; }); vgapMap.prototype.spMenuItem("Build Fighters", "buildFighters", function() { buildFighters = !buildFighters; showMinerals.prototype.clearRes(); showBars = false; showText = false; buildStarbase = false; }); vgapMap.prototype.spMenuItem("Clear", "_massClear", function() { showMinerals.prototype.clearData(); }); } }, // display minerals toggleRes : function(name) { vgap.map.showresources = name; for (var i = 0; i < resources.length; ++i) { if (resources[i].name == name) { v = !resources[i].showRes; resources[i].showRes = v; buildFighters = false; buildStarbase = false; break; } } vgap.map.draw(); }, clearRes : function() { // vgap.map.showresources = false; for (var i = 0; i < resources.length; ++i) { resources[i].showRes = false; } vgap.map.draw(); }, clearData : function() { vgap.map.showresources = false; showBars = false; showText = false; buildStarbase = false; buildFighters = false; for (var i = 0; i < resources.length; ++i) { resources[i].showRes = false; resources[i].surface = 0; resources[i].ground = 0; } }, nativeTaxAmount : function(c, ntr) { var nt = 0; if (c.nativeclans > 0) { if (c.race == 6 && ntr > 20) { // borg == 6 ntr = 20; } var nt = (c.nativeclans / 100) * (ntr / 10) * (c.nativegovernment / 5); nt = c.nativetype == 5 ? 0 : nt; // amorphous == 5 nt = c.nativetype == 6 ? 2 * nt : nt; // insect == 6 nt = c.race == 1 ? 2 * nt : nt; // feds == 1 nt = Math.round(nt); } return nt; }, miningRate (p, ground, density) { m = vgap.miningRate(p, density); m = m > ground ? ground : Math.round(m); return m; }, nativesupport : function(c) { ns = c.clans; ns *= c.race == 1 ? 2 : 1; // feds == 1 ns *= c.nativetype == 6 ? 2 : 1; // insect == 6 return ns; } }; var oldRenderResource = vgapMap.prototype.renderResource; vgapMap.prototype.renderResource = function(ctx) { // replace completely, pretty sure i want to do this // oldRenderResource.apply(this, arguments); for (var d = 0; d < vgap.myplanets.length; d++) { var planet = vgap.myplanets[d]; for (var i = 0; i < resources.length; ++i) { resources[i].surface = 0; resources[i].supplies = 0; resources[i].ground = 0; resources[i].target = 0; resources[i].mined = 0; } for (var i = 0; i < resources.length; ++i) { r = resources[i]; if (r.name == "Molybdenum") { r.surface = planet.molybdenum; r.ground = planet.groundmolybdenum; r.mined = showMinerals.prototype.miningRate (planet, planet.groundmolybdenum, planet.densitymolybdenum); // console.log(planet.id+"p "+r.surface); } if (r.name == "Neutronium") { r.surface = planet.neutronium; r.ground = planet.groundneutronium; r.mined = showMinerals.prototype.miningRate (planet, planet.groundneutronium, planet.densityneutronium); } if (r.name == "Duranium") { r.surface = planet.duranium; r.ground = planet.groundduranium; r.mined = showMinerals.prototype.miningRate (planet, planet.groundduranium, planet.densityduranium); } if (r.name == "Tritanium") { r.surface = planet.tritanium; r.ground = planet.groundtritanium; r.mined = showMinerals.prototype.miningRate (planet, planet.groundtritanium, planet.densitytritanium); } if (r.name == "Megacredits") { r.surface = planet.megacredits + planet.supplies; r.supplies = planet.supplies; r.ground = 0; r.mined = planet.factories; nt = showMinerals.prototype.nativeTaxAmount(planet, planet.nativetaxrate); ns = showMinerals.prototype.nativesupport(planet); r.mined += Math.min( nt , ns); } } for (var k = 0; k < vgap.myships.length; ++k) { var ship = vgap.myships[k]; t = Math.dist(ship.targetx, ship.targety, planet.x, planet.y) <= 3; p = ship.x == planet.x && ship.y == planet.y; for (var i = 0; i < resources.length; ++i) { r = resources[i]; if (p && t) { if (r.name == "Molybdenum") r.surface += ship.molybdenum; if (r.name == "Neutronium") r.surface += ship.neutronium; if (r.name == "Duranium") r.surface += ship.duranium; if (r.name == "Tritanium") r.surface += ship.tritanium; if (r.name == "Megacredits") { r.surface += ship.megacredits + ship.supplies; r.supplies += ship.supplies; } } if (!p & t) { if (r.name == "Molybdenum") r.target += ship.molybdenum; if (r.name == "Neutronium") r.target += ship.neutronium; if (r.name == "Duranium") r.target += ship.duranium; if (r.name == "Tritanium") r.target += ship.tritanium; if (r.name == "Megacredits") r.target += ship.megacredits + ship.supplies; } } } var x1 = this.screenX(planet.x); var y1 = this.screenY(planet.y); if (buildStarbase || buildFighters) { for (var i = 0; i < resources.length; ++i) { r = resources[i]; if (r.name == "Molybdenum") { var mol = r.surface; var mol2 = mol + r.mined + r.target; } if (r.name == "Neutronium") { var neu = r.surface; var neu2 = neu + r.mined + r.target; } if (r.name == "Duranium") { var dur = r.surface; var dur2 = dur + r.mined + r.target; } if (r.name == "Tritanium") { var tri = r.surface; var tri2 = tri + r.mined + r.target; } if (r.name == "Megacredits") { var mc = r.surface; var sp = r.supplies; var mc2 = mc + r.mined + r.target; } } if (buildStarbase) { if (!vgap.getStarbase(planet.id)) { if (dur >= 120 && tri >= 302 && mol >= 430 && mc >= 900) { this.drawCircle(ctx, x1, y1, 9 * this.zoom, "green", 4); } else if (!vgap.getStarbase(planet.id)) { if (dur2 >= 120 && tri2 >= 302 && mol2 >= 430 && mc2 >= 900) { this.drawCircle(ctx, x1, y1, 9 * this.zoom, "yellow", 4); } } } } else if (buildFighters) { fighters = Math.floor(Math.min(sp/5, tri/3, mol/2)); if (fighters > 0) { ctx.fillStyle = "orange"; x2 = this.screenX(planet.x + 7 * this.zoom); y2 = this.screenY(planet.y + 1 * this.zoom); ctx.fillText(fighters, x2, y2); }}} else { for (var i = 0; i < resources.length; ++i) { if (resources[i].showRes == true) { var color = resources[i].color; // if (showBars) { // x1 = this.screenX(planet.x + (4 + i * 4) * this.zoom); // y1 = this.screenY(planet.y); // // var x2 = this.screenX(planet.x + (6 + i) * this.zoom); // var y2 = this.screenY(planet.y + Math.sqrt(resources[i].surface) * // this.zoom); // // this.drawLine(ctx, x1, y1, x1, y2, color, 4); // this.drawCircle(ctx, x1, y1, 0, color, 1); // why // // } else if (showText) { var radius; f = resources[i].surface + "-" + (resources[i].surface + resources[i].mined + resources[i].target); ctx.fillStyle = color; x2 = this.screenX(planet.x + 6.5 * this.zoom); y2 = this.screenY(planet.y - (i - 2) * 5.5 * this.zoom); ctx.fillText(f, x2, y2) } else { if (resources[i].ground > 0) { radius = Math.sqrt(resources[i].ground) * this.zoom; this.drawCircle(ctx, x1, y1, radius, color, 1); } if (resources[i].surface > 0) { radius = Math.sqrt(resources[i].surface) * this.zoom; this.drawCircle(ctx, x1, y1, radius, color, 2); } } } } } } }; var oldLoadControls = vgapMap.prototype.loadControls; vgapMap.prototype.loadControls = function() { oldLoadControls.apply(this, arguments); showMinerals.prototype.loadControls(); }; } var script = document.createElement("script"); script.type = "application/javascript"; script.textContent = "(" + wrapper + ")();"; document.body.appendChild(script);