aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/me
diff options
context:
space:
mode:
authorSpencer <75862693+TacoMonkey11@users.noreply.github.com>2022-10-24 20:15:44 -0400
committerSpencer <75862693+TacoMonkey11@users.noreply.github.com>2022-10-24 20:15:44 -0400
commit7dc7a2185d5d92152554f35a95cd906a60fd5107 (patch)
tree568146fbd4a6a76220b030e6a5d1cf31d8d2d275 /src/main/java/me
parentb7f3f933bffdb07172c3e957002dbcae39371fbb (diff)
downloadSkyblocker-7dc7a2185d5d92152554f35a95cd906a60fd5107.tar.gz
Skyblocker-7dc7a2185d5d92152554f35a95cd906a60fd5107.tar.bz2
Skyblocker-7dc7a2185d5d92152554f35a95cd906a60fd5107.zip
Optimise DwarvenHud
Diffstat (limited to 'src/main/java/me')
-rw-r--r--src/main/java/me/xmrvizzy/skyblocker/SkyblockerMod.java2
-rw-r--r--src/main/java/me/xmrvizzy/skyblocker/skyblock/dwarven/DwarvenHud.java54
2 files changed, 33 insertions, 23 deletions
diff --git a/src/main/java/me/xmrvizzy/skyblocker/SkyblockerMod.java b/src/main/java/me/xmrvizzy/skyblocker/SkyblockerMod.java
index 6b5558cf..8cd71770 100644
--- a/src/main/java/me/xmrvizzy/skyblocker/SkyblockerMod.java
+++ b/src/main/java/me/xmrvizzy/skyblocker/SkyblockerMod.java
@@ -5,6 +5,7 @@ import me.xmrvizzy.skyblocker.discord.DiscordRPCManager;
import me.xmrvizzy.skyblocker.skyblock.BackpackPreview;
import me.xmrvizzy.skyblocker.skyblock.StatusBarTracker;
import me.xmrvizzy.skyblocker.skyblock.dungeon.DungeonBlaze;
+import me.xmrvizzy.skyblocker.skyblock.dwarven.DwarvenHud;
import me.xmrvizzy.skyblocker.utils.Scheduler;
import me.xmrvizzy.skyblocker.utils.Utils;
@@ -22,6 +23,7 @@ public class SkyblockerMod {
scheduler.scheduleCyclic(discordRPCManager::update, 100);
scheduler.scheduleCyclic(DungeonBlaze::update, 4);
scheduler.scheduleCyclic(BackpackPreview::tick, 50);
+ scheduler.scheduleCyclic(DwarvenHud::update, 40);
}
public static SkyblockerMod getInstance() {
diff --git a/src/main/java/me/xmrvizzy/skyblocker/skyblock/dwarven/DwarvenHud.java b/src/main/java/me/xmrvizzy/skyblocker/skyblock/dwarven/DwarvenHud.java
index a75ab412..6af480ea 100644
--- a/src/main/java/me/xmrvizzy/skyblocker/skyblock/dwarven/DwarvenHud.java
+++ b/src/main/java/me/xmrvizzy/skyblocker/skyblock/dwarven/DwarvenHud.java
@@ -18,8 +18,10 @@ public class DwarvenHud {
public static MinecraftClient client = MinecraftClient.getInstance();
+ public static List<Commission> commissionList = new ArrayList<>();
- public static final List<Pattern> COMMISSIONS = List.of(
+
+ public static final List<Pattern> COMMISSIONS = Stream.of(
"(?:Titanium|Mithril|Hard Stone) Miner",
"(?:Ice Walker|Goblin|Goblin Raid|Automaton|Sludge|Team Treasurite Member|Yog|Boss Corleone|Thyst) Slayer",
"(?:Lava Springs|Cliffside Veins|Rampart's Quarry|Upper Mines|Royal Mines) Mithril",
@@ -32,33 +34,39 @@ public class DwarvenHud {
"(?:Ruby|Amber|Sapphire|Jade|Amethyst|Topaz) Gemstone Collector",
"(?:Amber|Sapphire|Jade|Amethyst|Topaz) Crystal Hunter",
"Chest Looter"
- ).stream().map(s -> Pattern.compile("^.*(" + s + "): (\\d+\\.?\\d*%|DONE)"))
+ ).map(s -> Pattern.compile("^.*(" + s + "): (\\d+\\.?\\d*%|DONE)"))
.collect(Collectors.toList());
public static void init(){
HudRenderCallback.EVENT.register((matrixStack, tickDelta) -> {
- if (SkyblockerConfig.get().locations.dwarvenMines.dwarvenHud.enabled) {
- int hudX = SkyblockerConfig.get().locations.dwarvenMines.dwarvenHud.x;
- int hudY = SkyblockerConfig.get().locations.dwarvenMines.dwarvenHud.y;
- List<Commission> commissions = new ArrayList<>();
- client.getNetworkHandler().getPlayerList().forEach(playerListEntry -> {
- if (playerListEntry.getDisplayName() != null) {
- for (Pattern pattern : COMMISSIONS) {
- Matcher matcher = pattern.matcher(playerListEntry.getDisplayName().getString());
- if (matcher.find()) {
- commissions.add(new Commission(matcher.group(1), matcher.group(2)));
- }
+ if (!SkyblockerConfig.get().locations.dwarvenMines.dwarvenHud.enabled || client.player == null || commissionList.isEmpty()) return;
+ render(matrixStack, SkyblockerConfig.get().locations.dwarvenMines.dwarvenHud.x, SkyblockerConfig.get().locations.dwarvenMines.dwarvenHud.y, commissionList);
+ });
+ }
- }
- }
- });
- if (commissions.size() > 0){
- if (SkyblockerConfig.get().locations.dwarvenMines.dwarvenHud.enableBackground)
- DrawableHelper.fill(matrixStack, hudX, hudY, hudX + 200, hudY + (20 * commissions.size()), 0x64000000);
- int y = 0;
- for (Commission commission : commissions) {
- client.textRenderer.drawWithShadow(matrixStack, Text.literal(commission.commission).styled(style -> style.withColor(Formatting.AQUA)).append(Text.literal(": " + commission.progression).styled(style -> style.withColor(Formatting.GREEN))), hudX + 5, hudY + y + 5, 0xFFFFFFFF);
- y += 20;
+ public static void render(MatrixStack matrixStack, int hudX, int hudY, List<Commission> commissions) {
+ if (commissions.size() > 0){
+ if (SkyblockerConfig.get().locations.dwarvenMines.dwarvenHud.enableBackground)
+ DrawableHelper.fill(matrixStack, hudX, hudY, hudX + 200, hudY + (20 * commissions.size()), 0x64000000);
+ int y = 0;
+ for (Commission commission : commissions) {
+ client.textRenderer.drawWithShadow(matrixStack, Text.literal(commission.commission).styled(style -> style.withColor(Formatting.AQUA)).append(Text.literal(": " + commission.progression).styled(style -> style.withColor(Formatting.GREEN))), hudX + 5, hudY + y + 5, 0xFFFFFFFF);
+ y += 20;
+ }
+ }
+ }
+
+ public static void update() {
+ commissionList = new ArrayList<>();
+ if (client.player == null || !SkyblockerConfig.get().locations.dwarvenMines.dwarvenHud.enabled) return;
+
+ client.getNetworkHandler().getPlayerList().forEach(playerListEntry -> {
+ if (playerListEntry.getDisplayName() != null) {
+ for (Pattern pattern : COMMISSIONS) {
+ Matcher matcher = pattern.matcher(playerListEntry.getDisplayName().getString());
+ if (matcher.find()) {
+ commissionList.add(new Commission(matcher.group(1), matcher.group(2)));
}
+
}
}
});