aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/OfferFlowerGoal.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/OfferFlowerGoal.cpp
parentdef8cb415354ac390b7e89052a50605285f1aca9 (diff)
Initial commit
Diffstat (limited to 'Minecraft.World/OfferFlowerGoal.cpp')
-rw-r--r--Minecraft.World/OfferFlowerGoal.cpp44
1 files changed, 44 insertions, 0 deletions
diff --git a/Minecraft.World/OfferFlowerGoal.cpp b/Minecraft.World/OfferFlowerGoal.cpp
new file mode 100644
index 00000000..b604ea84
--- /dev/null
+++ b/Minecraft.World/OfferFlowerGoal.cpp
@@ -0,0 +1,44 @@
+#include "stdafx.h"
+#include "net.minecraft.world.entity.ai.control.h"
+#include "net.minecraft.world.entity.npc.h"
+#include "net.minecraft.world.entity.animal.h"
+#include "net.minecraft.world.level.h"
+#include "net.minecraft.world.phys.h"
+#include "OfferFlowerGoal.h"
+
+OfferFlowerGoal::OfferFlowerGoal(VillagerGolem *golem)
+{
+ this->golem = golem;
+ setRequiredControlFlags(Control::MoveControlFlag | Control::LookControlFlag);
+}
+
+bool OfferFlowerGoal::canUse()
+{
+ if (!golem->level->isDay()) return false;
+ if (golem->getRandom()->nextInt(8000) != 0) return false;
+ villager = weak_ptr<Villager>(dynamic_pointer_cast<Villager>( golem->level->getClosestEntityOfClass(typeid(Villager), golem->bb->grow(6, 2, 6), golem->shared_from_this()) ));
+ return villager.lock() != NULL;
+}
+
+bool OfferFlowerGoal::canContinueToUse()
+{
+ return _tick > 0 && villager.lock() != NULL;
+}
+
+void OfferFlowerGoal::start()
+{
+ _tick = OFFER_TICKS;
+ golem->offerFlower(true);
+}
+
+void OfferFlowerGoal::stop()
+{
+ golem->offerFlower(false);
+ villager = weak_ptr<Villager>();
+}
+
+void OfferFlowerGoal::tick()
+{
+ golem->getLookControl()->setLookAt(villager.lock(), 30, 30);
+ --_tick;
+} \ No newline at end of file