From e8f230f24e55469f1aa832bc8dad73db8018ffe1 Mon Sep 17 00:00:00 2001 From: "lapayo94@gmail.com" Date: Sun, 25 Dec 2011 22:47:12 +0000 Subject: - 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 --- source/cSlime.cpp | 65 +++---------------------------------------------------- 1 file changed, 3 insertions(+), 62 deletions(-) (limited to 'source/cSlime.cpp') diff --git a/source/cSlime.cpp b/source/cSlime.cpp index c2cf78061..27ecd050b 100644 --- a/source/cSlime.cpp +++ b/source/cSlime.cpp @@ -1,30 +1,9 @@ #include "cSlime.h" -#include "Vector3f.h" -#include "Vector3d.h" - -#include "Defines.h" - -#include "cRoot.h" -#include "cWorld.h" -#include "cPickup.h" -#include "cItem.h" -#include "cMonsterConfig.h" - -#include "cMCLogger.h" - -#ifndef _WIN32 -#include // rand() -#include -#endif - //TODO Implement sized slimes -cSlime::cSlime() : m_ChaseTime(999999) { - m_bBurnable = true; - m_EMPersonality = AGGRESSIVE; - m_bPassiveAggressive = true; - //m_AttackRate = 1; +cSlime::cSlime() +{ m_MobType = 55; GetMonsterConfig("Slime"); } @@ -35,52 +14,14 @@ cSlime::~cSlime() bool cSlime::IsA( const char* a_EntityType ) { - //LOG("IsA( cSlime ) : %s", a_EntityType); if( strcmp( a_EntityType, "cSlime" ) == 0 ) return true; return cMonster::IsA( a_EntityType ); } -void cSlime::Tick(float a_Dt) -{ - cMonster::Tick(a_Dt); -} - void cSlime::KilledBy( cEntity* a_Killer ) { //TODO: only when tiny cMonster::RandomDropItem(E_ITEM_SLIMEBALL, 0, 2); cMonster::KilledBy( a_Killer ); -} - -//What to do if in Idle State -void cSlime::InStateIdle(float a_Dt) { - cMonster::InStateIdle(a_Dt); -} - -//What to do if in Chasing State -void cSlime::InStateChasing(float a_Dt) { - cMonster::InStateChasing(a_Dt); - m_ChaseTime += a_Dt; - if( m_Target ) - { - 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 cSlime::InStateEscaping(float a_Dt) { - cMonster::InStateEscaping(a_Dt); -} - -void cSlime::GetMonsterConfig(const char* pm_name) { - LOG("I am gettin my attributes: %s", pm_name); - cRoot::Get()->GetMonsterConfig()->Get()->AssignAttributes(this,pm_name); -} +} \ No newline at end of file -- cgit v1.2.3