blob: 942673f0972044d78428c4beb154b8a81e7fb51e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
package fyresmodjam.blessings.standard;
import cpw.mods.fml.common.gameevent.TickEvent.ServerTickEvent;
import fyresmodjam.blessings.Blessing;
import fyresmodjam.misc.DamageSources;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraftforge.event.entity.living.LivingHurtEvent;
// TODO
// replace this with a blessing that nullifies fire, and a mark that
// does that plus the damage boost
public class InfernoBlessing extends StandardBlessing {
public InfernoBlessing() {
super("Inferno");
}
@Override
public String name() {
return "Inferno";
}
@Override
public String description() {
return "Benefit: Take no fire damage";
// return "Benefit: Take no fire damage, and do increased damage while on
// fire\nDrawback: Take damge while wet";
}
@Override
public void commonTick(ServerTickEvent stev, EntityPlayer play) {
if (play.isWet() && play.ticksExisted % 10 == 0) {
play.attackEntityFrom(DamageSources.inferno, 1.0F);
}
}
@Override
public float onIncomingDamage(LivingHurtEvent event, float damageMultiplier) {
if (event.source.isFireDamage() || event.source.getDamageType().equals("inFire")
|| event.source.getDamageType().equals("onFire") || event.source.getDamageType().equals("lava")) {
event.setCanceled(true);
return 0;
}
return damageMultiplier;
}
@Override
public float onOutgoingDamage(LivingHurtEvent event, float damageMultiplier) {
if (event.source.getEntity().isBurning()) {
// return damageMultiplier + 0.35f;
}
return damageMultiplier;
}
}
|