summaryrefslogtreecommitdiff
path: root/src/main/java/fyresmodjam/blessings/marks/FalseLifeMark.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/fyresmodjam/blessings/marks/FalseLifeMark.java')
-rw-r--r--src/main/java/fyresmodjam/blessings/marks/FalseLifeMark.java58
1 files changed, 58 insertions, 0 deletions
diff --git a/src/main/java/fyresmodjam/blessings/marks/FalseLifeMark.java b/src/main/java/fyresmodjam/blessings/marks/FalseLifeMark.java
new file mode 100644
index 0000000..88f467a
--- /dev/null
+++ b/src/main/java/fyresmodjam/blessings/marks/FalseLifeMark.java
@@ -0,0 +1,58 @@
+package fyresmodjam.blessings.marks;
+
+import net.minecraft.entity.SharedMonsterAttributes;
+import net.minecraft.potion.Potion;
+import net.minecraft.potion.PotionEffect;
+import net.minecraftforge.event.entity.living.LivingHurtEvent;
+
+public class FalseLifeMark extends Mark {
+
+ @Override
+ public String name() {
+ return "False Life";
+ }
+
+ @Override
+ public String description() {
+ return "BENEFIT - Rally from a fatal injury\nDRAWBACK - Lose permanent health to do so";
+ }
+
+ @Override
+ public float onIncomingDamage(LivingHurtEvent event,
+ float damageMultiplier) {
+ float totalAmount = Math.max(0.5f,
+ event.getAmount() * damageMultiplier);
+
+ if (totalAmount > event.getEntityLiving().getMaxHealth()) {
+ event.setCanceled(true);
+
+ event.getEntityLiving().getEntityAttribute(
+ SharedMonsterAttributes.MAX_HEALTH)
+ .setBaseValue(event.getEntityLiving()
+ .getMaxHealth()
+ / 0.75f);
+
+ event.getEntityLiving().setHealth(
+ event.getEntityLiving().getMaxHealth());
+
+ // TODO figure out potions
+ /*
+ event.getEntityLiving()
+ .addPotionEffect(new PotionEffect(
+ Potion.moveSpeed.id,
+ 30, 1));
+ event.getEntityLiving()
+ .addPotionEffect(new PotionEffect(
+ Potion.resistance.id,
+ 20, 1));
+ event.getEntityLiving()
+ .addPotionEffect(new PotionEffect(
+ Potion.damageBoost.id,
+ 20, 1));
+ */
+ return 0;
+ }
+
+ return damageMultiplier;
+ }
+}