diff options
author | Mattes D <github@xoft.cz> | 2013-11-05 17:22:31 +0100 |
---|---|---|
committer | Mattes D <github@xoft.cz> | 2013-11-05 17:22:31 +0100 |
commit | e65ce130127b3a56e12421d745b98549c0669a95 (patch) | |
tree | 52472269f5b9635e3370333b5dbc00fd97700975 /source/Mobs/Skeleton.cpp | |
parent | Protocol 1.7: Added more client-bound packets. (diff) | |
parent | Fixed indentation. (diff) | |
download | cuberite-e65ce130127b3a56e12421d745b98549c0669a95.tar cuberite-e65ce130127b3a56e12421d745b98549c0669a95.tar.gz cuberite-e65ce130127b3a56e12421d745b98549c0669a95.tar.bz2 cuberite-e65ce130127b3a56e12421d745b98549c0669a95.tar.lz cuberite-e65ce130127b3a56e12421d745b98549c0669a95.tar.xz cuberite-e65ce130127b3a56e12421d745b98549c0669a95.tar.zst cuberite-e65ce130127b3a56e12421d745b98549c0669a95.zip |
Diffstat (limited to 'source/Mobs/Skeleton.cpp')
-rw-r--r-- | source/Mobs/Skeleton.cpp | 42 |
1 files changed, 41 insertions, 1 deletions
diff --git a/source/Mobs/Skeleton.cpp b/source/Mobs/Skeleton.cpp index 37a724848..509c2191e 100644 --- a/source/Mobs/Skeleton.cpp +++ b/source/Mobs/Skeleton.cpp @@ -7,7 +7,6 @@ - cSkeleton::cSkeleton(bool IsWither) : super("Skeleton", mtSkeleton, "mob.skeleton.hurt", "mob.skeleton.death", 0.6, 1.8), m_bIsWither(IsWither) @@ -28,3 +27,44 @@ void cSkeleton::GetDrops(cItems & a_Drops, cEntity * a_Killer) + +void cSkeleton::MoveToPosition(const Vector3f & a_Position) +{ + m_Destination = a_Position; + + // If the destination is in the sun and if it is not night AND the skeleton isn't on fire then block the movement. + if (!IsOnFire() && m_World->GetTimeOfDay() < 13187 && m_World->GetBlockSkyLight((int) a_Position.x, (int) a_Position.y, (int) a_Position.z) == 15) + { + m_bMovingToDestination = false; + return; + } + m_bMovingToDestination = true; +} + + + + + +void cSkeleton::Attack(float a_Dt) +{ + m_AttackInterval += a_Dt * m_AttackRate; + + if (m_Target != NULL && m_AttackInterval > 3.0) + { + // Setting this higher gives us more wiggle room for attackrate + Vector3d Speed = GetLookVector() * 20; + Speed.y = Speed.y + 1; + cArrowEntity * Arrow = new cArrowEntity(this, GetPosX(), GetPosY() + 1, GetPosZ(), Speed); + if (Arrow == NULL) + { + return; + } + if (!Arrow->Initialize(m_World)) + { + delete Arrow; + return; + } + m_World->BroadcastSpawnEntity(*Arrow); + m_AttackInterval = 0.0; + } +}
\ No newline at end of file |