aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLorenz <lo.scherf@gmail.com>2022-08-17 02:07:50 +0200
committerLorenz <lo.scherf@gmail.com>2022-08-17 02:07:50 +0200
commit26d9f454754a01c7c95cc2a16c28236861b17dc0 (patch)
tree37c9098509e7cc71aa375b6f7993a52fb31bfb41
parent59a7994ecc435c469baa8c843dc8c8ed7b71107b (diff)
downloadskyhanni-26d9f454754a01c7c95cc2a16c28236861b17dc0.tar.gz
skyhanni-26d9f454754a01c7c95cc2a16c28236861b17dc0.tar.bz2
skyhanni-26d9f454754a01c7c95cc2a16c28236861b17dc0.zip
add healing to damage change in time
-rw-r--r--src/main/java/at/hannibal2/skyhanni/config/features/Misc.java2
-rw-r--r--src/main/java/at/hannibal2/skyhanni/damageindicator/BossDamageIndicator.kt47
-rw-r--r--src/main/java/at/hannibal2/skyhanni/damageindicator/DamageCounter.kt1
-rw-r--r--src/main/java/at/hannibal2/skyhanni/damageindicator/OldDamage.kt2
4 files changed, 40 insertions, 12 deletions
diff --git a/src/main/java/at/hannibal2/skyhanni/config/features/Misc.java b/src/main/java/at/hannibal2/skyhanni/config/features/Misc.java
index 0c2b0112c..5362db7fa 100644
--- a/src/main/java/at/hannibal2/skyhanni/config/features/Misc.java
+++ b/src/main/java/at/hannibal2/skyhanni/config/features/Misc.java
@@ -73,7 +73,7 @@ public class Misc {
public boolean damageIndicatorHideDamageSplash = false;
@Expose
- @ConfigOption(name = "Damage Over Time", desc = "Show damage over time below the damage indicator")
+ @ConfigOption(name = "Damage Over Time", desc = "Show damage and health over time below the damage indicator")
@ConfigEditorBoolean
@ConfigAccordionId(id = 1)
public boolean damageIndicatorShowDamageOverTime = false;
diff --git a/src/main/java/at/hannibal2/skyhanni/damageindicator/BossDamageIndicator.kt b/src/main/java/at/hannibal2/skyhanni/damageindicator/BossDamageIndicator.kt
index aafbd6a7b..38a415f03 100644
--- a/src/main/java/at/hannibal2/skyhanni/damageindicator/BossDamageIndicator.kt
+++ b/src/main/java/at/hannibal2/skyhanni/damageindicator/BossDamageIndicator.kt
@@ -119,14 +119,31 @@ class BossDamageIndicator {
if (SkyHanniMod.feature.misc.damageIndicatorShowDamageOverTime) {
var diff = 13f
val currentDamage = data.damageCounter.currentDamage
- if (currentDamage != 0L) {
- val format = "§c" + NumberUtil.format(currentDamage)
- RenderUtils.drawLabel(location, format, partialTicks, true, 3.9f, diff)
+ val currentHealing = data.damageCounter.currentHealing
+ if (currentDamage != 0L || currentHealing != 0L) {
+ val formatDamage = "§c" + NumberUtil.format(currentDamage)
+ val formatHealing = "§a+" + NumberUtil.format(currentHealing)
+ val finalResult = if (currentHealing == 0L) {
+ formatDamage
+ } else if (currentDamage == 0L) {
+ formatHealing
+ } else {
+ "$formatDamage §7/ $formatHealing"
+ }
+ RenderUtils.drawLabel(location, finalResult, partialTicks, true, 3.9f, diff)
diff += 9f
}
for (damage in data.damageCounter.oldDamages) {
- val format = "§c" + NumberUtil.format(damage.damage) + "/s"
- RenderUtils.drawLabel(location, format, partialTicks, true, 3.9f, diff)
+ val formatDamage = "§c" + NumberUtil.format(damage.damage) + "/s"
+ val formatHealing = "§a+" + NumberUtil.format(damage.healing) + "/s"
+ val finalResult = if (damage.healing == 0L) {
+ formatDamage
+ } else if (damage.damage == 0L) {
+ formatHealing
+ } else {
+ "$formatDamage §7/ $formatHealing"
+ }
+ RenderUtils.drawLabel(location, finalResult, partialTicks, true, 3.9f, diff)
diff += 9f
}
}
@@ -138,15 +155,16 @@ class BossDamageIndicator {
private fun tickDamage(damageCounter: DamageCounter) {
val now = System.currentTimeMillis()
- if (damageCounter.currentDamage != 0L) {
+ if (damageCounter.currentDamage != 0L || damageCounter.currentHealing != 0L) {
if (damageCounter.firstTick == 0L) {
damageCounter.firstTick = now
}
if (now > damageCounter.firstTick + 1_000) {
- damageCounter.oldDamages.add(OldDamage(now, damageCounter.currentDamage))
+ damageCounter.oldDamages.add(OldDamage(now, damageCounter.currentDamage, damageCounter.currentHealing))
damageCounter.firstTick = 0L
damageCounter.currentDamage = 0
+ damageCounter.currentHealing = 0
}
}
damageCounter.oldDamages.removeIf { now > it.time + 5_000 }
@@ -419,10 +437,19 @@ class BossDamageIndicator {
private fun checkDamage(entityData: EntityData, health: Int, lastHealth: Int, bossType: BossType) {
val damage = lastHealth - health
- if (damage <= 0) return
+ val healing = health - lastHealth
+ if (damage > 0) {
+ val damageCounter = entityData.damageCounter
+ damageCounter.currentDamage += damage
+ }
+ if (healing > 0) {
+ //Hide auto heal every 10 ticks (with rounding errors)
+ if ((healing == 15_000 || healing == 15_001) && bossType == BossType.SLAYER_ZOMBIE_5) return
- val damageCounter = entityData.damageCounter
- damageCounter.currentDamage += damage
+ val damageCounter = entityData.damageCounter
+ damageCounter.currentHealing += healing
+
+ }
}
private fun percentageColor(
diff --git a/src/main/java/at/hannibal2/skyhanni/damageindicator/DamageCounter.kt b/src/main/java/at/hannibal2/skyhanni/damageindicator/DamageCounter.kt
index a7732a8a9..92566a018 100644
--- a/src/main/java/at/hannibal2/skyhanni/damageindicator/DamageCounter.kt
+++ b/src/main/java/at/hannibal2/skyhanni/damageindicator/DamageCounter.kt
@@ -3,6 +3,7 @@ package at.hannibal2.skyhanni.damageindicator
class DamageCounter {
var currentDamage = 0L
+ var currentHealing = 0L
var oldDamages = mutableListOf<OldDamage>()
var firstTick = 0L
diff --git a/src/main/java/at/hannibal2/skyhanni/damageindicator/OldDamage.kt b/src/main/java/at/hannibal2/skyhanni/damageindicator/OldDamage.kt
index 20fb9cbfa..de5070a01 100644
--- a/src/main/java/at/hannibal2/skyhanni/damageindicator/OldDamage.kt
+++ b/src/main/java/at/hannibal2/skyhanni/damageindicator/OldDamage.kt
@@ -1,4 +1,4 @@
package at.hannibal2.skyhanni.damageindicator
-class OldDamage(val time: Long, val damage: Long) {
+class OldDamage(val time: Long, val damage: Long, val healing: Long) {
} \ No newline at end of file