diff options
author | andrew <xdotftw@gmail.com> | 2014-03-24 11:29:19 +0100 |
---|---|---|
committer | andrew <xdotftw@gmail.com> | 2014-03-24 11:29:19 +0100 |
commit | 6b77dc74ade3d8088da09d26c1b701d92ef28e9e (patch) | |
tree | 78e16164d1668d628ef0f545a5e62f5cbc1025fc /src/Mobs/Wither.cpp | |
parent | Plugins can set flying speed. (diff) | |
download | cuberite-6b77dc74ade3d8088da09d26c1b701d92ef28e9e.tar cuberite-6b77dc74ade3d8088da09d26c1b701d92ef28e9e.tar.gz cuberite-6b77dc74ade3d8088da09d26c1b701d92ef28e9e.tar.bz2 cuberite-6b77dc74ade3d8088da09d26c1b701d92ef28e9e.tar.lz cuberite-6b77dc74ade3d8088da09d26c1b701d92ef28e9e.tar.xz cuberite-6b77dc74ade3d8088da09d26c1b701d92ef28e9e.tar.zst cuberite-6b77dc74ade3d8088da09d26c1b701d92ef28e9e.zip |
Diffstat (limited to '')
-rw-r--r-- | src/Mobs/Wither.cpp | 52 |
1 files changed, 51 insertions, 1 deletions
diff --git a/src/Mobs/Wither.cpp b/src/Mobs/Wither.cpp index c46e0beab..0e42194ac 100644 --- a/src/Mobs/Wither.cpp +++ b/src/Mobs/Wither.cpp @@ -2,14 +2,64 @@ #include "Globals.h" // NOTE: MSVC stupidness requires this to be the same across all modules #include "Wither.h" +#include "../World.h" cWither::cWither(void) : - super("Wither", mtWither, "mob.wither.hurt", "mob.wither.death", 0.9, 4.0) + super("Wither", mtWither, "mob.wither.hurt", "mob.wither.death", 0.9, 4.0), + m_InvulnerableTicks(220) { + SetMaxHealth(300); + + SetHealth(GetMaxHealth() / 3); +} + + + + + +void cWither::DoTakeDamage(TakeDamageInfo & a_TDI) +{ + if (a_TDI.DamageType == dtDrowning) + { + return; + } + + if (m_InvulnerableTicks > 0) + { + return; + } + + super::DoTakeDamage(a_TDI); +} + + + + + +void cWither::Tick(float a_Dt, cChunk & a_Chunk) +{ + super::Tick(a_Dt, a_Chunk); + + if (m_InvulnerableTicks > 0) + { + unsigned int NewTicks = m_InvulnerableTicks - 1; + + if (NewTicks == 0) + { + m_World->DoExplosionAt(7.0, GetPosX(), GetPosY(), GetPosZ(), false, esWitherBirth, this); + } + + m_InvulnerableTicks = NewTicks; + + if ((NewTicks % 10) == 0) + { + Heal(10); + } + } } |