- Fixed Bug #99 -> Mobs no longer bother you in creative mode
- refactored many things in the Monster system git-svn-id: http://mc-server.googlecode.com/svn/trunk@112 0a769ca7-a7f5-676a-18bf-c427514a06d6
This commit is contained in:
73
source/cAggressiveMonster.cpp
Normal file
73
source/cAggressiveMonster.cpp
Normal file
@@ -0,0 +1,73 @@
|
||||
#include "cAggressiveMonster.h"
|
||||
|
||||
#include "Vector3f.h"
|
||||
#include "cPlayer.h"
|
||||
|
||||
|
||||
cAggressiveMonster::cAggressiveMonster()
|
||||
: m_ChaseTime(999999)
|
||||
{
|
||||
m_EMPersonality = AGGRESSIVE;
|
||||
}
|
||||
|
||||
cAggressiveMonster::~cAggressiveMonster()
|
||||
{
|
||||
}
|
||||
|
||||
//What to do if in Chasing State
|
||||
void cAggressiveMonster::InStateChasing(float a_Dt) {
|
||||
cMonster::InStateChasing(a_Dt);
|
||||
m_ChaseTime += a_Dt;
|
||||
if( m_Target )
|
||||
{
|
||||
if(m_Target->GetEntityType() == cEntity::E_PLAYER)
|
||||
{
|
||||
cPlayer * Player = (cPlayer *) m_Target;
|
||||
if(Player->GetGameMode() == 1)
|
||||
{
|
||||
m_EMState = IDLE;
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
Vector3f Pos = Vector3f( m_Pos );
|
||||
Vector3f Their = Vector3f( m_Target->GetPosition() );
|
||||
if( (Their - Pos).Length() <= m_AttackRange) {
|
||||
cMonster::Attack(a_Dt);
|
||||
}
|
||||
MoveToPosition( Their + Vector3f(0, 0.65f, 0) );
|
||||
} else if( m_ChaseTime > 5.f ) {
|
||||
m_ChaseTime = 0;
|
||||
m_EMState = IDLE;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
void cAggressiveMonster::EventSeePlayer(cEntity *a_Entity)
|
||||
{
|
||||
cMonster::EventSeePlayer(a_Entity);
|
||||
m_EMState = CHASING;
|
||||
}
|
||||
|
||||
void cAggressiveMonster::Tick(float a_Dt)
|
||||
{
|
||||
cMonster::Tick(a_Dt);
|
||||
|
||||
m_SeePlayerInterval += a_Dt;
|
||||
|
||||
if(m_SeePlayerInterval > 1)
|
||||
{
|
||||
int rem = rand() % 3 + 1; //check most of the time but miss occasionally
|
||||
|
||||
m_SeePlayerInterval = 0.0;
|
||||
if(rem >= 2)
|
||||
{
|
||||
if(m_EMState == CHASING){
|
||||
CheckEventLostPlayer();
|
||||
} else {
|
||||
CheckEventSeePlayer();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user