diff options
author | Tiger Wang <ziwei.tiger@hotmail.co.uk> | 2014-05-25 00:21:39 +0200 |
---|---|---|
committer | Tiger Wang <ziwei.tiger@hotmail.co.uk> | 2014-05-25 00:21:39 +0200 |
commit | f55f5ec47f67dcc31e56bc364297aaf60d75b0c3 (patch) | |
tree | 62262220c9342b0eab368f553a836d736a39d972 /src/Mobs/Wither.cpp | |
parent | Update CompositeChat.h (diff) | |
parent | Update README.md (diff) | |
download | cuberite-f55f5ec47f67dcc31e56bc364297aaf60d75b0c3.tar cuberite-f55f5ec47f67dcc31e56bc364297aaf60d75b0c3.tar.gz cuberite-f55f5ec47f67dcc31e56bc364297aaf60d75b0c3.tar.bz2 cuberite-f55f5ec47f67dcc31e56bc364297aaf60d75b0c3.tar.lz cuberite-f55f5ec47f67dcc31e56bc364297aaf60d75b0c3.tar.xz cuberite-f55f5ec47f67dcc31e56bc364297aaf60d75b0c3.tar.zst cuberite-f55f5ec47f67dcc31e56bc364297aaf60d75b0c3.zip |
Diffstat (limited to 'src/Mobs/Wither.cpp')
-rw-r--r-- | src/Mobs/Wither.cpp | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/src/Mobs/Wither.cpp b/src/Mobs/Wither.cpp index 5b6e895e1..170f4fdc0 100644 --- a/src/Mobs/Wither.cpp +++ b/src/Mobs/Wither.cpp @@ -2,7 +2,9 @@ #include "Globals.h" // NOTE: MSVC stupidness requires this to be the same across all modules #include "Wither.h" + #include "../World.h" +#include "../Entities/Player.h" @@ -100,3 +102,35 @@ void cWither::GetDrops(cItems & a_Drops, cEntity * a_Killer) + +void cWither::KilledBy(cEntity * a_Killer) +{ + super::KilledBy(a_Killer); + + class cPlayerCallback : public cPlayerListCallback + { + Vector3f m_Pos; + + virtual bool Item(cPlayer * a_Player) + { + // TODO 2014-05-21 xdot: Vanilla minecraft uses an AABB check instead of a radius one + double Dist = (a_Player->GetPosition() - m_Pos).Length(); + if (Dist < 50.0) + { + // If player is close, award achievement + a_Player->AwardAchievement(achKillWither); + } + return false; + } + + public: + cPlayerCallback(const Vector3f & a_Pos) : m_Pos(a_Pos) {} + + } PlayerCallback(GetPosition()); + + m_World->ForEachPlayer(PlayerCallback); +} + + + + |