Added void damage
This commit is contained in:
parent
010bc94a34
commit
c8f8597774
@ -55,6 +55,7 @@ cEntity::cEntity(eEntityType a_EntityType, double a_X, double a_Y, double a_Z, d
|
|||||||
, m_TicksSinceLastBurnDamage(0)
|
, m_TicksSinceLastBurnDamage(0)
|
||||||
, m_TicksSinceLastLavaDamage(0)
|
, m_TicksSinceLastLavaDamage(0)
|
||||||
, m_TicksSinceLastFireDamage(0)
|
, m_TicksSinceLastFireDamage(0)
|
||||||
|
, m_TicksSinceLastVoidDamage(0)
|
||||||
, m_TicksLeftBurning(0)
|
, m_TicksLeftBurning(0)
|
||||||
, m_WaterSpeed(0, 0, 0)
|
, m_WaterSpeed(0, 0, 0)
|
||||||
, m_Width(a_Width)
|
, m_Width(a_Width)
|
||||||
@ -472,6 +473,11 @@ void cEntity::Tick(float a_Dt, cChunk & a_Chunk)
|
|||||||
{
|
{
|
||||||
TickBurning(a_Chunk);
|
TickBurning(a_Chunk);
|
||||||
}
|
}
|
||||||
|
if ((a_Chunk.IsValid()) && (GetPosY() < -46))
|
||||||
|
{
|
||||||
|
TickInVoid(a_Chunk);
|
||||||
|
}
|
||||||
|
else { m_TicksSinceLastVoidDamage = 0; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -803,6 +809,23 @@ void cEntity::TickBurning(cChunk & a_Chunk)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void cEntity::TickInVoid(cChunk & a_Chunk)
|
||||||
|
{
|
||||||
|
if (m_TicksSinceLastVoidDamage == 20)
|
||||||
|
{
|
||||||
|
TakeDamage(dtInVoid, NULL, 2, 0);
|
||||||
|
m_TicksSinceLastVoidDamage = 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_TicksSinceLastVoidDamage++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/// Called when the entity starts burning
|
/// Called when the entity starts burning
|
||||||
void cEntity::OnStartedBurning(void)
|
void cEntity::OnStartedBurning(void)
|
||||||
{
|
{
|
||||||
|
@ -256,6 +256,9 @@ public:
|
|||||||
/// Updates the state related to this entity being on fire
|
/// Updates the state related to this entity being on fire
|
||||||
virtual void TickBurning(cChunk & a_Chunk);
|
virtual void TickBurning(cChunk & a_Chunk);
|
||||||
|
|
||||||
|
/// Handles when the entity is in the void
|
||||||
|
virtual void TickInVoid(cChunk & a_Chunk);
|
||||||
|
|
||||||
/// Called when the entity starts burning
|
/// Called when the entity starts burning
|
||||||
virtual void OnStartedBurning(void);
|
virtual void OnStartedBurning(void);
|
||||||
|
|
||||||
@ -378,6 +381,9 @@ protected:
|
|||||||
/// Time, in ticks, until the entity extinguishes its fire
|
/// Time, in ticks, until the entity extinguishes its fire
|
||||||
int m_TicksLeftBurning;
|
int m_TicksLeftBurning;
|
||||||
|
|
||||||
|
/// Time, in ticks, since the last damage dealt by the void. Reset to zero when moving out of the void.
|
||||||
|
int m_TicksSinceLastVoidDamage;
|
||||||
|
|
||||||
virtual void Destroyed(void) {} // Called after the entity has been destroyed
|
virtual void Destroyed(void) {} // Called after the entity has been destroyed
|
||||||
|
|
||||||
void SetWorld(cWorld * a_World) { m_World = a_World; }
|
void SetWorld(cWorld * a_World) { m_World = a_World; }
|
||||||
|
Loading…
Reference in New Issue
Block a user