aboutsummaryrefslogtreecommitdiff
path: root/src/main
diff options
context:
space:
mode:
Diffstat (limited to 'src/main')
-rw-r--r--src/main/java/at/hannibal2/skyhanni/features/fishing/SeaCreatureFeatures.kt51
-rw-r--r--src/main/java/at/hannibal2/skyhanni/utils/TimeLimitedCache.kt2
-rw-r--r--src/main/java/at/hannibal2/skyhanni/utils/TimeLimitedSet.kt6
3 files changed, 39 insertions, 20 deletions
diff --git a/src/main/java/at/hannibal2/skyhanni/features/fishing/SeaCreatureFeatures.kt b/src/main/java/at/hannibal2/skyhanni/features/fishing/SeaCreatureFeatures.kt
index e19593859..9dfab5c2b 100644
--- a/src/main/java/at/hannibal2/skyhanni/features/fishing/SeaCreatureFeatures.kt
+++ b/src/main/java/at/hannibal2/skyhanni/features/fishing/SeaCreatureFeatures.kt
@@ -3,17 +3,21 @@ package at.hannibal2.skyhanni.features.fishing
import at.hannibal2.skyhanni.SkyHanniMod
import at.hannibal2.skyhanni.config.ConfigUpdaterMigrator
import at.hannibal2.skyhanni.config.features.combat.damageindicator.DamageIndicatorConfig
+import at.hannibal2.skyhanni.data.mob.Mob
import at.hannibal2.skyhanni.events.LorenzWorldChangeEvent
import at.hannibal2.skyhanni.events.MobEvent
import at.hannibal2.skyhanni.events.RenderEntityOutlineEvent
import at.hannibal2.skyhanni.events.SeaCreatureFishEvent
+import at.hannibal2.skyhanni.features.combat.damageindicator.BossType
import at.hannibal2.skyhanni.features.dungeon.DungeonAPI
import at.hannibal2.skyhanni.utils.LocationUtils.distanceToPlayer
import at.hannibal2.skyhanni.utils.LorenzColor
import at.hannibal2.skyhanni.utils.LorenzUtils
import at.hannibal2.skyhanni.utils.LorenzUtils.baseMaxHealth
+import at.hannibal2.skyhanni.utils.MobUtils.mob
import at.hannibal2.skyhanni.utils.SimpleTimeMark
import at.hannibal2.skyhanni.utils.SoundUtils
+import at.hannibal2.skyhanni.utils.StringUtils.removeColor
import at.hannibal2.skyhanni.utils.TimeLimitedSet
import net.minecraft.entity.Entity
import net.minecraft.entity.EntityLivingBase
@@ -25,31 +29,36 @@ class SeaCreatureFeatures {
private val config get() = SkyHanniMod.feature.fishing.rareCatches
private val damageIndicatorConfig get() = SkyHanniMod.feature.combat.damageIndicator
- private var rareSeaCreatures = listOf<EntityLivingBase>()
private var lastRareCatch = SimpleTimeMark.farPast()
- private var armorStandIds = TimeLimitedSet<Int>(6.minutes)
+ private var rareSeaCreatures = TimeLimitedSet<Mob>(6.minutes)
+ private var entityIds = TimeLimitedSet<Int>(6.minutes)
// TODO remove spawn event, check per tick if can see, cache if already warned about
@SubscribeEvent
fun onMobSpawn(event: MobEvent.Spawn.SkyblockMob) {
if (!isEnabled()) return
- val creature = SeaCreatureManager.allFishingMobs[event.mob.name] ?: return
+ val mob = event.mob
+ val creature = SeaCreatureManager.allFishingMobs[mob.name] ?: return
if (!creature.rare) return
- if (config.highlight && !(damageIndicatorConfig.enabled &&
- DamageIndicatorConfig.BossCategory.SEA_CREATURES in damageIndicatorConfig.bossesToShow)
- ) {
- event.mob.highlight(LorenzColor.GREEN.toColor())
- rareSeaCreatures += event.mob.baseEntity
+ val entity = mob.baseEntity
+ val shouldNotify = entity.entityId !in entityIds
+ entityIds.addIfAbsent(entity.entityId)
+ rareSeaCreatures.add(mob)
+
+ var shouldHighlight = config.highlight
+ if (damageIndicatorConfig.enabled && DamageIndicatorConfig.BossCategory.SEA_CREATURES in damageIndicatorConfig.bossesToShow) {
+ val seaCreaturesBosses =
+ BossType.entries.filter { it.bossTypeToggle == DamageIndicatorConfig.BossCategory.SEA_CREATURES }
+ if (seaCreaturesBosses.any { it.fullName.removeColor() == mob.name }) {
+ shouldHighlight = false
+ }
}
- val id = event.mob.armorStand?.entityId ?: return
- if (armorStandIds.contains(id)) return
- armorStandIds.add(id)
+ if (shouldHighlight) mob.highlight(LorenzColor.GREEN.toColor())
if (lastRareCatch.passedSince() < 1.seconds) return
- if (event.mob.name == "Water Hydra" && event.mob.baseEntity.health == (event.mob.baseEntity.baseMaxHealth.toFloat() / 2)) return
-
- if (config.alertOtherCatches) {
+ if (mob.name == "Water Hydra" && entity.health == (entity.baseMaxHealth.toFloat() / 2)) return
+ if (config.alertOtherCatches && shouldNotify) {
val text = if (config.creatureName) "${creature.displayName} NEARBY!"
else "${creature.rarity.chatColorCode}RARE SEA CREATURE!"
LorenzUtils.sendTitle(text, 1.5.seconds, 3.6, 7f)
@@ -59,7 +68,7 @@ class SeaCreatureFeatures {
@SubscribeEvent
fun onMobDeSpawn(event: MobEvent.DeSpawn.SkyblockMob) {
- rareSeaCreatures.filter { it != event.mob.baseEntity }
+ rareSeaCreatures.remove(event.mob)
}
@SubscribeEvent
@@ -78,8 +87,8 @@ class SeaCreatureFeatures {
@SubscribeEvent
fun onWorldChange(event: LorenzWorldChangeEvent) {
- rareSeaCreatures = listOf()
- armorStandIds.clear()
+ rareSeaCreatures.clear()
+ entityIds.clear()
}
@SubscribeEvent
@@ -97,8 +106,10 @@ class SeaCreatureFeatures {
private fun isEnabled() = LorenzUtils.inSkyBlock && !DungeonAPI.inDungeon() && !LorenzUtils.inKuudraFight
private val getEntityOutlineColor: (entity: Entity) -> Int? = { entity ->
- if (entity is EntityLivingBase && entity in rareSeaCreatures && entity.distanceToPlayer() < 30) {
- LorenzColor.GREEN.toColor().rgb
- } else null
+ (entity as? EntityLivingBase)?.mob?.let { mob ->
+ if (mob in rareSeaCreatures && entity.distanceToPlayer() < 30) {
+ LorenzColor.GREEN.toColor().rgb
+ } else null
+ }
}
}
diff --git a/src/main/java/at/hannibal2/skyhanni/utils/TimeLimitedCache.kt b/src/main/java/at/hannibal2/skyhanni/utils/TimeLimitedCache.kt
index caf5b7734..e17389c52 100644
--- a/src/main/java/at/hannibal2/skyhanni/utils/TimeLimitedCache.kt
+++ b/src/main/java/at/hannibal2/skyhanni/utils/TimeLimitedCache.kt
@@ -25,6 +25,8 @@ class TimeLimitedCache<K: Any, V: Any>(
fun clear() = cache.invalidateAll()
+ fun remove(key: K) = cache.invalidate(key)
+
fun entries(): Set<Map.Entry<K, V>> = cache.asMap().entries
fun values(): Collection<V> = cache.asMap().values
diff --git a/src/main/java/at/hannibal2/skyhanni/utils/TimeLimitedSet.kt b/src/main/java/at/hannibal2/skyhanni/utils/TimeLimitedSet.kt
index aab5595da..242d06cf0 100644
--- a/src/main/java/at/hannibal2/skyhanni/utils/TimeLimitedSet.kt
+++ b/src/main/java/at/hannibal2/skyhanni/utils/TimeLimitedSet.kt
@@ -13,6 +13,12 @@ class TimeLimitedSet<T : Any>(
cache[element] = Unit
}
+ fun addIfAbsent(element: T) {
+ if (!contains(element)) add(element)
+ }
+
+ fun remove(element: T) = cache.remove(element)
+
operator fun contains(element: T): Boolean = cache.containsKey(element)
fun clear() = cache.clear()