From 41c68c40eb41d0a4d063b541138242bbfe27b30b Mon Sep 17 00:00:00 2001 From: hannibal2 <24389977+hannibal00212@users.noreply.github.com> Date: Sun, 22 Jan 2023 13:31:48 +0100 Subject: Changed load logic for ReputationHelper. --- .../damageindicator/DamageIndicatorManager.kt | 2 +- .../CrimsonIsleReputationHelper.kt | 25 ++++++----- .../dailykuudra/DailyKuudraBossHelper.kt | 48 +++++++++------------- .../dailyquest/DailyQuestHelper.kt | 4 +- .../reputationhelper/dailyquest/QuestLoader.kt | 14 +------ .../miniboss/DailyMiniBossHelper.kt | 39 +++++++----------- 6 files changed, 55 insertions(+), 77 deletions(-) (limited to 'src/main/java/at/hannibal2/skyhanni') diff --git a/src/main/java/at/hannibal2/skyhanni/features/damageindicator/DamageIndicatorManager.kt b/src/main/java/at/hannibal2/skyhanni/features/damageindicator/DamageIndicatorManager.kt index 48abd66ff..f98e5da94 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/damageindicator/DamageIndicatorManager.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/damageindicator/DamageIndicatorManager.kt @@ -166,7 +166,7 @@ class DamageIndicatorManager { ) if (data.dead) data.deathLocation = loc loc - } + }.add(-0.5, 0.0, -0.5) event.drawDynamicText(location, healthText, sizeHealth, smallestDistanceVew = smallestDistanceVew) diff --git a/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/CrimsonIsleReputationHelper.kt b/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/CrimsonIsleReputationHelper.kt index e4fb1055b..627467f03 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/CrimsonIsleReputationHelper.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/CrimsonIsleReputationHelper.kt @@ -6,9 +6,9 @@ import at.hannibal2.skyhanni.data.IslandType import at.hannibal2.skyhanni.events.RepositoryReloadEvent import at.hannibal2.skyhanni.features.nether.reputationhelper.dailykuudra.DailyKuudraBossHelper import at.hannibal2.skyhanni.features.nether.reputationhelper.dailyquest.DailyQuestHelper -import at.hannibal2.skyhanni.features.nether.reputationhelper.dailyquest.quest.UnknownQuest import at.hannibal2.skyhanni.features.nether.reputationhelper.miniboss.DailyMiniBossHelper import at.hannibal2.skyhanni.utils.LorenzUtils +import at.hannibal2.skyhanni.utils.LorenzVec import at.hannibal2.skyhanni.utils.RenderUtils.renderStringsAndItems import com.google.gson.JsonObject import net.minecraftforge.client.event.RenderGameOverlayEvent @@ -27,7 +27,6 @@ class CrimsonIsleReputationHelper(skyHanniMod: SkyHanniMod) { private val display = mutableListOf>() private var dirty = true - private var loaded = false init { skyHanniMod.loadModule(questHelper) @@ -37,18 +36,12 @@ class CrimsonIsleReputationHelper(skyHanniMod: SkyHanniMod) { @SubscribeEvent fun onRepoReload(event: RepositoryReloadEvent) { - questHelper.quests.removeIf { it is UnknownQuest} repoData = event.getConstant("CrimsonIsleReputation")!! - if (!loaded) { - loaded = true - miniBossHelper.init() - kuudraBossHelper.init() + miniBossHelper.load() + kuudraBossHelper.load() - questHelper.loadConfig() - miniBossHelper.loadConfig() - kuudraBossHelper.loadConfig() - } + questHelper.load() } @SubscribeEvent @@ -99,4 +92,14 @@ class CrimsonIsleReputationHelper(skyHanniMod: SkyHanniMod) { kuudraBossHelper.reset() update() } + + fun readLocationData(data: JsonObject): LorenzVec? { + val locationData = data["location"]?.asJsonArray ?: return null + if (locationData.size() == 0) return null + + val x = locationData[0].asDouble - 1 + val y = locationData[1].asDouble + val z = locationData[2].asDouble - 1 + return LorenzVec(x, y, z) + } } \ No newline at end of file diff --git a/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/dailykuudra/DailyKuudraBossHelper.kt b/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/dailykuudra/DailyKuudraBossHelper.kt index 73fbac7dd..aff27f79a 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/dailykuudra/DailyKuudraBossHelper.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/dailykuudra/DailyKuudraBossHelper.kt @@ -24,32 +24,6 @@ class DailyKuudraBossHelper(private val reputationHelper: CrimsonIsleReputationH private var kuudraLocation: LorenzVec? = null private var allKuudraDone = true - fun init() { - val repoData = reputationHelper.repoData - val jsonElement = repoData["KUUDRA"] - var tier = 1 - for ((displayName, extraData) in jsonElement.asJsonObject.entrySet()) { - val data = extraData.asJsonObject - val displayItem = data["item"]?.asString - - val locationData = data["location"]?.asJsonArray - val location: LorenzVec? = if (locationData == null || locationData.size() == 0) { - null - } else { - val x = locationData[0].asDouble - val y = locationData[1].asDouble - val z = locationData[2].asDouble - LorenzVec(x, y, z) - } - kuudraTiers.add(KuudraTier(displayName, displayItem, location, tier)) - if (location != null) { - kuudraLocation = location - } - - tier++ - } - } - @SubscribeEvent fun onRenderWorld(event: RenderWorldLastEvent) { if (!LorenzUtils.inSkyBlock) return @@ -128,8 +102,26 @@ class DailyKuudraBossHelper(private val reputationHelper: CrimsonIsleReputationH .forEach { SkyHanniMod.feature.hidden.crimsonIsleKuudraTiersDone.add(it.name) } } - fun loadConfig() { - println("loadConfig") + fun load() { + kuudraTiers.clear() + + //Repo + val repoData = reputationHelper.repoData + val jsonElement = repoData["KUUDRA"] + var tier = 1 + for ((displayName, extraData) in jsonElement.asJsonObject.entrySet()) { + val data = extraData.asJsonObject + val displayItem = data["item"]?.asString + val location = reputationHelper.readLocationData(data) + kuudraTiers.add(KuudraTier(displayName, displayItem, location, tier)) + if (location != null) { + kuudraLocation = location + } + + tier++ + } + + //Config for (name in SkyHanniMod.feature.hidden.crimsonIsleKuudraTiersDone) { getByDisplayName(name)!!.doneToday = true } diff --git a/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/dailyquest/DailyQuestHelper.kt b/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/dailyquest/DailyQuestHelper.kt index 3a72c2f68..d31f29396 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/dailyquest/DailyQuestHelper.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/dailyquest/DailyQuestHelper.kt @@ -302,7 +302,9 @@ class DailyQuestHelper(val reputationHelper: CrimsonIsleReputationHelper) { latestTrophyFishInInventory = 0 } - fun loadConfig() { + fun load() { + reset() + loader.loadConfig() latestTrophyFishInInventory = SkyHanniMod.feature.hidden.crimsonIsleLatestTrophyFishInInventory } diff --git a/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/dailyquest/QuestLoader.kt b/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/dailyquest/QuestLoader.kt index d48d28fd3..e4bba6494 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/dailyquest/QuestLoader.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/dailyquest/QuestLoader.kt @@ -5,13 +5,12 @@ import at.hannibal2.skyhanni.features.nether.reputationhelper.dailyquest.quest.* import at.hannibal2.skyhanni.utils.InventoryUtils.getInventoryName import at.hannibal2.skyhanni.utils.ItemUtils.getLore import at.hannibal2.skyhanni.utils.LorenzUtils -import at.hannibal2.skyhanni.utils.LorenzVec import at.hannibal2.skyhanni.utils.TabListUtils import net.minecraft.client.Minecraft import net.minecraft.client.gui.inventory.GuiChest import net.minecraft.inventory.ContainerChest -class QuestLoader(val dailyQuestHelper: DailyQuestHelper) { +class QuestLoader(private val dailyQuestHelper: DailyQuestHelper) { fun loadFromTabList() { var i = -1 @@ -86,16 +85,7 @@ class QuestLoader(val dailyQuestHelper: DailyQuestHelper) { for ((entryName, extraData) in category.entrySet()) { val data = extraData.asJsonObject val displayItem = data["item"]?.asString - val locationData = data["location"]?.asJsonArray - val location: LorenzVec? = if (locationData == null || locationData.size() == 0) { - null - } else { - val x = locationData[0].asDouble - val y = locationData[1].asDouble - val z = locationData[2].asDouble - LorenzVec(x, y, z) - } - + val location = dailyQuestHelper.reputationHelper.readLocationData(data) if (name.startsWith("$entryName Rank ")) { val split = name.split(" Rank ") val dojoName = split[0] diff --git a/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/miniboss/DailyMiniBossHelper.kt b/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/miniboss/DailyMiniBossHelper.kt index 17b30087f..3b3bdef44 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/miniboss/DailyMiniBossHelper.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/nether/reputationhelper/miniboss/DailyMiniBossHelper.kt @@ -8,7 +8,6 @@ import at.hannibal2.skyhanni.features.nether.reputationhelper.CrimsonIsleReputat import at.hannibal2.skyhanni.test.GriffinUtils.drawWaypointFilled import at.hannibal2.skyhanni.utils.LorenzColor import at.hannibal2.skyhanni.utils.LorenzUtils -import at.hannibal2.skyhanni.utils.LorenzVec import at.hannibal2.skyhanni.utils.NEUItems import at.hannibal2.skyhanni.utils.RenderUtils.drawDynamicText import net.minecraftforge.client.event.RenderWorldLastEvent @@ -20,28 +19,6 @@ class DailyMiniBossHelper(private val reputationHelper: CrimsonIsleReputationHel val miniBosses = mutableListOf() - fun init() { - val repoData = reputationHelper.repoData - val jsonElement = repoData["MINIBOSS"] - for ((displayName, extraData) in jsonElement.asJsonObject.entrySet()) { - val data = extraData.asJsonObject - val displayItem = data["item"]?.asString - val patterns = " *§r§6§l${displayName.uppercase()} DOWN!" - - val locationData = data["location"]?.asJsonArray - val location: LorenzVec? = if (locationData == null || locationData.size() == 0) { - null - } else { - val x = locationData[0].asDouble - val y = locationData[1].asDouble - val z = locationData[2].asDouble - LorenzVec(x, y, z) - } - - miniBosses.add(CrimsonMiniBoss(displayName, displayItem, location, Pattern.compile(patterns))) - } - } - @SubscribeEvent fun onChat(event: LorenzChatEvent) { if (!HyPixelData.skyBlock) return @@ -113,7 +90,21 @@ class DailyMiniBossHelper(private val reputationHelper: CrimsonIsleReputationHel .forEach { SkyHanniMod.feature.hidden.crimsonIsleMiniBossesDoneToday.add(it.displayName) } } - fun loadConfig() { + fun load() { + miniBosses.clear() + + //Repo + val repoData = reputationHelper.repoData + val jsonElement = repoData["MINIBOSS"] + for ((displayName, extraData) in jsonElement.asJsonObject.entrySet()) { + val data = extraData.asJsonObject + val displayItem = data["item"]?.asString + val patterns = " *§r§6§l${displayName.uppercase()} DOWN!" + val location = reputationHelper.readLocationData(data) + miniBosses.add(CrimsonMiniBoss(displayName, displayItem, location, Pattern.compile(patterns))) + } + + //Config for (name in SkyHanniMod.feature.hidden.crimsonIsleMiniBossesDoneToday) { getByDisplayName(name)!!.doneToday = true } -- cgit