diff options
author | admin@omencraft.com <admin@omencraft.com@0a769ca7-a7f5-676a-18bf-c427514a06d6> | 2011-10-26 01:46:01 +0200 |
---|---|---|
committer | admin@omencraft.com <admin@omencraft.com@0a769ca7-a7f5-676a-18bf-c427514a06d6> | 2011-10-26 01:46:01 +0200 |
commit | a26a0e3825bb337a4be0f0c7f171e4cbd450bded (patch) | |
tree | c9c188bb5895275ec6814df5897c1097e404fac0 /source/cSkeleton.cpp | |
parent | Using SSE instructions for noise (terrain generation) (diff) | |
download | cuberite-a26a0e3825bb337a4be0f0c7f171e4cbd450bded.tar cuberite-a26a0e3825bb337a4be0f0c7f171e4cbd450bded.tar.gz cuberite-a26a0e3825bb337a4be0f0c7f171e4cbd450bded.tar.bz2 cuberite-a26a0e3825bb337a4be0f0c7f171e4cbd450bded.tar.lz cuberite-a26a0e3825bb337a4be0f0c7f171e4cbd450bded.tar.xz cuberite-a26a0e3825bb337a4be0f0c7f171e4cbd450bded.tar.zst cuberite-a26a0e3825bb337a4be0f0c7f171e4cbd450bded.zip |
Diffstat (limited to '')
-rw-r--r-- | source/cSkeleton.cpp | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/source/cSkeleton.cpp b/source/cSkeleton.cpp new file mode 100644 index 000000000..84de27d7a --- /dev/null +++ b/source/cSkeleton.cpp @@ -0,0 +1,94 @@ +#include "cSkeleton.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 <stdlib.h> // rand()
+#include <cstring>
+#endif
+
+cSkeleton::cSkeleton() : m_ChaseTime(999999) {
+ m_bBurnable = true;
+ m_EMPersonality = AGGRESSIVE;
+ m_bPassiveAggressive = false;
+ //m_AttackRate = 1;
+ m_MobType = 51;
+ GetMonsterConfig("Skeleton");
+}
+
+cSkeleton::~cSkeleton()
+{
+}
+
+bool cSkeleton::IsA( const char* a_EntityType )
+{
+ //LOG("IsA( cSkeleton ) : %s", a_EntityType);
+ if( strcmp( a_EntityType, "cSkeleton" ) == 0 ) return true;
+ return cMonster::IsA( a_EntityType );
+}
+
+void cSkeleton::Tick(float a_Dt)
+{
+ cMonster::Tick(a_Dt);
+ if (cRoot::Get()->GetWorld()->GetWorldTime() < (12000 + 1000) ) { //if daylight
+ m_EMMetaState = BURNING; // BURN, BABY, BURN! >:D
+ }
+}
+
+void cSkeleton::KilledBy( cEntity* a_Killer )
+{
+ if( (rand() % 5) == 0 )
+ {
+ cPickup* Pickup = new cPickup( (int)(m_Pos->x*32), (int)(m_Pos->y*32), (int)(m_Pos->z*32), cItem( E_ITEM_EGG, 1 ) );
+ Pickup->Initialize();
+ }
+ if( (rand() % 1) == 0 )
+ {
+ cPickup* Pickup = new cPickup( (int)(m_Pos->x*32), (int)(m_Pos->y*32), (int)(m_Pos->z*32), cItem( E_ITEM_FEATHER, 1 ) );
+ Pickup->Initialize();
+ }
+ cMonster::KilledBy( a_Killer );
+}
+
+//What to do if in Idle State
+void cSkeleton::InStateIdle(float a_Dt) {
+ cMonster::InStateIdle(a_Dt);
+}
+
+//What to do if in Chasing State
+void cSkeleton::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 cSkeleton::InStateEscaping(float a_Dt) {
+ cMonster::InStateEscaping(a_Dt);
+}
+
+void cSkeleton::GetMonsterConfig(const char* pm_name) {
+ LOG("I am gettin my attributes: %s", pm_name);
+ cRoot::Get()->GetMonsterConfig()->Get()->AssignAttributes(this,pm_name);
+}
|