您需要先安装一个扩展,例如 篡改猴、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("Bar Graph", "showBarGraph", function() { // showBars = !showBars; // if (showBars) { // showText = false; // buildStarbase = false; // buildFighters = false; // } // }); vgapMap.prototype.spMenuItem("Text", "showText", function() { showText = !showText; if (showText) { showBars = false; buildStarbase = false; buildFighters = false; } }); vgapMap.prototype.spMenuItem("Build Starbase", "buildStarbase", function() { buildStarbase = !buildStarbase; if (buildStarbase) { showBars = false; showText = false; buildFighters = false; } }); vgapMap.prototype.spMenuItem("Build Fighters", "buildFighters", function() { buildFighters = !buildFighters; if (buildFighters) { 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) { var v = !resources[i].showRes; resources[i].showRes = v; } } }, 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) { 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 j = 0; j < resources.length; ++j) { r = resources[j]; if (r.name == "Molybdenum") { mol = r.surface; mol2 = r.mined + r.target; } if (r.name == "Duranium") { dur = r.surface; dur2 = r.mined + r.target; } if (r.name == "Tritanium") { tri = r.surface; tri2 = r.mined + r.target; } if (r.name == "Megacredits") { mc = r.surface; sp = r.supplies; mc2 = r.mined + r.target; } } if (buildStarbase) { if (!vgap.getStarbase(planet.id)) { if (dur >= 120 && tri >= 302 && mol >= 430 && mc >= 900) { radius = 9 * this.zoom; this.drawCircle(ctx, x1, y1, radius, "green", 6); } } if (!vgap.getStarbase(planet.id)) { if (dur2 >= 120 && tri2 >= 302 && mol2 >= 430 && mc2 >= 900) { radius = 9 * this.zoom; this.drawCircle(ctx, x1, y1, radius, "yellow", 6); } } } else if (buildFighters) { fighters = Math.floor(Math.min(sp/5, tri/3, mol/2)); ctx.fillStyle = "cyan"; x2 = this.screenX(planet.x + 6.5 * this.zoom); y2 = this.screenY(planet.y + 0 * 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);