aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/io
diff options
context:
space:
mode:
authorVixid <52578495+VixidDev@users.noreply.github.com>2023-04-04 21:29:23 +0100
committerGitHub <noreply@github.com>2023-04-04 22:29:23 +0200
commit86b772dc5825010b504826ee10bd1ba675c21227 (patch)
tree4f1510c6358a62b0e37b338b4e8a0ddc9c237e0a /src/main/java/io
parent93cdc3e03c3654f560204c23017fbf1e9f720a6c (diff)
downloadNotEnoughUpdates-86b772dc5825010b504826ee10bd1ba675c21227.tar.gz
NotEnoughUpdates-86b772dc5825010b504826ee10bd1ba675c21227.tar.bz2
NotEnoughUpdates-86b772dc5825010b504826ee10bd1ba675c21227.zip
Profit per RNGMeter fixes (#653)
Co-authored-by: Vixid <52578495+Vixid1@users.noreply.github.com>
Diffstat (limited to 'src/main/java/io')
-rw-r--r--src/main/java/io/github/moulberry/notenoughupdates/core/util/StringUtils.java1
-rw-r--r--src/main/java/io/github/moulberry/notenoughupdates/listener/ItemTooltipRngListener.java46
2 files changed, 41 insertions, 6 deletions
diff --git a/src/main/java/io/github/moulberry/notenoughupdates/core/util/StringUtils.java b/src/main/java/io/github/moulberry/notenoughupdates/core/util/StringUtils.java
index c7c118bb..ec50633f 100644
--- a/src/main/java/io/github/moulberry/notenoughupdates/core/util/StringUtils.java
+++ b/src/main/java/io/github/moulberry/notenoughupdates/core/util/StringUtils.java
@@ -85,6 +85,7 @@ public class StringUtils {
}
public static String shortNumberFormat(double n, int iteration) {
+ if (n < 0) return "-" + shortNumberFormat(-n, iteration);
if (n < 1000) {
if (n % 1 == 0) {
return Integer.toString((int) n);
diff --git a/src/main/java/io/github/moulberry/notenoughupdates/listener/ItemTooltipRngListener.java b/src/main/java/io/github/moulberry/notenoughupdates/listener/ItemTooltipRngListener.java
index d6d7087f..06d294a3 100644
--- a/src/main/java/io/github/moulberry/notenoughupdates/listener/ItemTooltipRngListener.java
+++ b/src/main/java/io/github/moulberry/notenoughupdates/listener/ItemTooltipRngListener.java
@@ -31,12 +31,14 @@ import io.github.moulberry.notenoughupdates.util.ItemResolutionQuery;
import io.github.moulberry.notenoughupdates.util.ItemUtils;
import io.github.moulberry.notenoughupdates.util.Utils;
import net.minecraft.item.ItemStack;
+import net.minecraft.util.EnumChatFormatting;
import net.minecraftforge.event.entity.player.ItemTooltipEvent;
import net.minecraftforge.fml.common.eventhandler.EventPriority;
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;
import org.lwjgl.input.Keyboard;
import java.util.ArrayList;
+import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
@@ -59,6 +61,8 @@ public class ItemTooltipRngListener {
private final Pattern SLAYER_INVENTORY_TITLE_PATTERN = Pattern.compile("(.+) RNG Meter");
+ private final Pattern TIER_AMOUNT = Pattern.compile("§5§o§7Tier (.+) amount: §a(\\d+).*");
+
private final Map<String, Integer> dungeonData = new LinkedHashMap<>();
private final Map<String, LinkedHashMap<String, Integer>> slayerData = new LinkedHashMap<>();
@@ -115,7 +119,7 @@ public class ItemTooltipRngListener {
if (NotEnoughUpdates.INSTANCE.config.tooltipTweaks.rngMeterProfitPerUnit) {
if (!NotEnoughUpdates.INSTANCE.config.tooltipTweaks.rngMeterRunsNeeded) {
String name = Utils.getOpenChestName().contains("Catacombs") ? "Score" : "XP";
- String formatCoinsPer = getFormatCoinsPer(event.itemStack, needed, 1, name);
+ String formatCoinsPer = getFormatCoinsPer(event.itemStack, needed, 1, 1, 0, name);
if (formatCoinsPer != null) {
newToolTip.add(line);
newToolTip.add(formatCoinsPer);
@@ -137,18 +141,19 @@ public class ItemTooltipRngListener {
event.toolTip.addAll(newToolTip);
}
- private String getFormatCoinsPer(ItemStack stack, int needed, int multiplier, String label) {
+ private String getFormatCoinsPer(ItemStack stack, int needed, int multiplier, int amountPerTier, int cost, String label) {
String internalName = neu.manager.createItemResolutionQuery().withItemStack(stack).resolveInternalName();
- double profit = neu.manager.auctionManager.getBazaarOrBin(internalName, false);
+ double profit = neu.manager.auctionManager.getBazaarOrBin(internalName, false) * amountPerTier;
if (profit <= 0) return null;
//ask hypixel nicely to release a 'chest price api' with 4 dimensions for us. the 4 dimensions needed are: item name, floor, normal/mm, s/s+
// double chestPrice = grabChestPrice(stack, internalName);
// profit -= chestPrice;
- double coinsPer = (profit / needed) * multiplier;
+ double coinsPer = ((profit / needed) * multiplier) - cost;
String format = StringUtils.shortNumberFormat(coinsPer);
- return "§7Coins per " + label + ": §6" + format + " coins";
+ EnumChatFormatting profitIndicator = coinsPer >= 0 ? EnumChatFormatting.GREEN : EnumChatFormatting.RED;
+ return "§7Coins per " + label + ": " + profitIndicator + format + " coins";
}
private void fractionDisplay(List<String> newToolTip, String line) {
@@ -311,8 +316,18 @@ public class ItemTooltipRngListener {
toolTip.add(
" §7" + labelPlural + " completed: §e" + runsHavingFormat + " §7(of §e" + runsNeededFormat + " §7needed)");
+ int amountPerTier = parseAmountFromTooltip(toolTip);
+
+ int cost = 0;
+ if (repoCategory.equals("slayer")) {
+ JsonObject slayerCost = Constants.MISC;
+ if (slayerCost.has("slayer_cost")) {
+ cost = slayerCost.getAsJsonArray("slayer_cost").get(currentSelected).getAsInt();
+ }
+ }
+
if (NotEnoughUpdates.INSTANCE.config.tooltipTweaks.rngMeterProfitPerUnit) {
- String formatCoinsPer = getFormatCoinsPer(stack, needed, gainPerRun, labelSingular);
+ String formatCoinsPer = getFormatCoinsPer(stack, needed, gainPerRun, amountPerTier, cost, labelSingular);
if (formatCoinsPer != null) {
toolTip.add(" " + formatCoinsPer);
}
@@ -324,6 +339,25 @@ public class ItemTooltipRngListener {
}
}
+ private int parseAmountFromTooltip(List<String> tooltip) {
+ Map<Integer, Integer> tierToAmount = new HashMap<>();
+
+ for (String line : tooltip) {
+ Matcher amountMatcher = TIER_AMOUNT.matcher(line);
+ if (amountMatcher.matches()) {
+ try {
+ int tier = Utils.parseRomanNumeral(amountMatcher.group(1));
+ int lowerBoundDrop = Integer.parseInt(amountMatcher.group(2));
+ tierToAmount.put(tier, lowerBoundDrop);
+ } catch (NumberFormatException e) {
+ e.printStackTrace();
+ }
+ }
+ }
+
+ return tierToAmount.get(currentSelected + 1) == null ? 1 : tierToAmount.get(currentSelected + 1);
+ }
+
private int getRepoScore(ItemStack stack, String repoCategory) {
ItemResolutionQuery query =
NotEnoughUpdates.INSTANCE.manager.createItemResolutionQuery().withItemStack(stack).withCurrentGuiContext();