aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/SwellGoal.cpp
diff options
context:
space:
mode:
authordaoge_cmd <3523206925@qq.com>2026-03-01 12:16:08 +0800
committerdaoge_cmd <3523206925@qq.com>2026-03-01 12:16:08 +0800
commitb691c43c44ff180d10e7d4a9afc83b98551ff586 (patch)
tree3e9849222cbc6ba49f2f1fc6e5fe7179632c7390 /Minecraft.World/SwellGoal.cpp
parentdef8cb415354ac390b7e89052a50605285f1aca9 (diff)
Initial commit
Diffstat (limited to 'Minecraft.World/SwellGoal.cpp')
-rw-r--r--Minecraft.World/SwellGoal.cpp54
1 files changed, 54 insertions, 0 deletions
diff --git a/Minecraft.World/SwellGoal.cpp b/Minecraft.World/SwellGoal.cpp
new file mode 100644
index 00000000..9065ba16
--- /dev/null
+++ b/Minecraft.World/SwellGoal.cpp
@@ -0,0 +1,54 @@
+#include "stdafx.h"
+#include "net.minecraft.world.entity.ai.control.h"
+#include "net.minecraft.world.entity.ai.sensing.h"
+#include "net.minecraft.world.entity.ai.navigation.h"
+#include "net.minecraft.world.entity.monster.h"
+#include "SwellGoal.h"
+
+SwellGoal::SwellGoal(Creeper *creeper)
+{
+ target = weak_ptr<Mob>();
+
+ this->creeper = creeper;
+ setRequiredControlFlags(Control::MoveControlFlag);
+}
+
+bool SwellGoal::canUse()
+{
+ shared_ptr<Mob> target = creeper->getTarget();
+ return creeper->getSwellDir() > 0 || (target != NULL && (creeper->distanceToSqr(target) < 3 * 3));
+}
+
+void SwellGoal::start()
+{
+ creeper->getNavigation()->stop();
+ target = weak_ptr<Mob>(creeper->getTarget());
+}
+
+void SwellGoal::stop()
+{
+ target = weak_ptr<Mob>();
+}
+
+void SwellGoal::tick()
+{
+ if (target.lock() == NULL)
+ {
+ creeper->setSwellDir(-1);
+ return;
+ }
+
+ if (creeper->distanceToSqr(target.lock()) > 7 * 7)
+ {
+ creeper->setSwellDir(-1);
+ return;
+ }
+
+ if (!creeper->getSensing()->canSee(target.lock()))
+ {
+ creeper->setSwellDir(-1);
+ return;
+ }
+
+ creeper->setSwellDir(1);
+}