9f77572fb0
-> Manager handles all ticks -> advantage: Much easier to add new simulators, because you only have to register them in the manager - moved sand and gravel simulation to a Simulator-class (cSandSimulator) - Made Squid a little bit more funny and realistic, because it dies now when it´s not in water -Escaping mobs run now faster than normal (They just walked away before :D) git-svn-id: http://mc-server.googlecode.com/svn/trunk@125 0a769ca7-a7f5-676a-18bf-c427514a06d6
40 lines
725 B
C++
40 lines
725 B
C++
#include "cPassiveMonster.h"
|
|
#include "MersenneTwister.h"
|
|
|
|
|
|
cPassiveMonster::cPassiveMonster()
|
|
{
|
|
m_EMPersonality = PASSIVE;
|
|
}
|
|
|
|
cPassiveMonster::~cPassiveMonster()
|
|
{
|
|
}
|
|
|
|
void cPassiveMonster::TakeDamage(int a_Damage, cEntity* a_Instigator)
|
|
{
|
|
cMonster::TakeDamage(a_Damage, a_Instigator);
|
|
if(a_Instigator != this)
|
|
m_EMState = ESCAPING;
|
|
}
|
|
|
|
void cPassiveMonster::Tick(float a_Dt)
|
|
{
|
|
cMonster::Tick(a_Dt);
|
|
|
|
m_SeePlayerInterval += a_Dt;
|
|
|
|
if(m_SeePlayerInterval > 1)
|
|
{
|
|
MTRand r1;
|
|
int rem = r1.randInt() % 3 + 1; //check most of the time but miss occasionally
|
|
|
|
m_SeePlayerInterval = 0.0;
|
|
if(rem >= 2) {
|
|
if(m_EMState == ESCAPING)
|
|
{
|
|
CheckEventLostPlayer();
|
|
}
|
|
}
|
|
}
|
|
} |