mirror of
https://github.com/DrPerkyLegit/LCEServerTest.git
synced 2026-06-12 23:51:57 +00:00
removed git history
This commit is contained in:
44
Minecraft.World/OfferFlowerGoal.cpp
Normal file
44
Minecraft.World/OfferFlowerGoal.cpp
Normal file
@@ -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() != nullptr;
|
||||
}
|
||||
|
||||
bool OfferFlowerGoal::canContinueToUse()
|
||||
{
|
||||
return _tick > 0 && villager.lock() != nullptr;
|
||||
}
|
||||
|
||||
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;
|
||||
}
|
||||
Reference in New Issue
Block a user