diff options
Diffstat (limited to '')
-rw-r--r-- | src/Mobs/SnowGolem.cpp | 37 | ||||
-rw-r--r-- | src/Mobs/SnowGolem.h | 1 |
2 files changed, 38 insertions, 0 deletions
diff --git a/src/Mobs/SnowGolem.cpp b/src/Mobs/SnowGolem.cpp index 3b66311a1..fabcfb070 100644 --- a/src/Mobs/SnowGolem.cpp +++ b/src/Mobs/SnowGolem.cpp @@ -5,6 +5,7 @@ #include "SnowGolem.h" #include "../BlockInfo.h" #include "../World.h" +#include "../Entities/ThrownSnowballEntity.h" @@ -56,3 +57,39 @@ void cSnowGolem::Tick(std::chrono::milliseconds a_Dt, cChunk & a_Chunk) } } } + + + + + +bool cSnowGolem::Attack(std::chrono::milliseconds a_Dt) +{ + UNUSED(a_Dt); + + // Comment inherited from skeletons + StopMovingToPosition(); // Todo handle this in a better way, the snowman does some uneeded recalcs due to inStateChasing + + if ((GetTarget() != nullptr) && (m_AttackCoolDownTicksLeft == 0)) + { + auto & Random = GetRandomProvider(); + Vector3d Inaccuracy = Vector3d(Random.RandReal<double>(-0.75, 0.75), Random.RandReal<double>(-0.75, 0.75), Random.RandReal<double>(-0.75, 0.75)); + + // The projectile is launched from the head + const auto HeadPos = GetPosition().addedY(1.5); + // It aims around the head / chest + const auto TargetPos = GetTarget()->GetPosition().addedY(GetTarget()->GetHeight() * 0.75); + // With this data, we can calculate the speed + const auto Speed = (TargetPos + Inaccuracy - HeadPos) * 5; + + auto Snowball = std::make_unique<cThrownSnowballEntity>(this, HeadPos, Speed); + auto SnowballPtr = Snowball.get(); + if (!SnowballPtr->Initialize(std::move(Snowball), *GetWorld())) + { + return false; + } + + ResetAttackCooldown(); + return true; + } + return false; +} diff --git a/src/Mobs/SnowGolem.h b/src/Mobs/SnowGolem.h index 8504965cb..6c6e88868 100644 --- a/src/Mobs/SnowGolem.h +++ b/src/Mobs/SnowGolem.h @@ -20,6 +20,7 @@ public: virtual void Tick(std::chrono::milliseconds a_Dt, cChunk & a_Chunk) override; virtual void GetDrops(cItems & a_Drops, cEntity * a_Killer = nullptr) override; + virtual bool Attack(std::chrono::milliseconds a_Dt) override; } ; |