From b691c43c44ff180d10e7d4a9afc83b98551ff586 Mon Sep 17 00:00:00 2001 From: daoge_cmd <3523206925@qq.com> Date: Sun, 1 Mar 2026 12:16:08 +0800 Subject: Initial commit --- Minecraft.World/RestrictOpenDoorGoal.cpp | 49 ++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 Minecraft.World/RestrictOpenDoorGoal.cpp (limited to 'Minecraft.World/RestrictOpenDoorGoal.cpp') diff --git a/Minecraft.World/RestrictOpenDoorGoal.cpp b/Minecraft.World/RestrictOpenDoorGoal.cpp new file mode 100644 index 00000000..e8620a71 --- /dev/null +++ b/Minecraft.World/RestrictOpenDoorGoal.cpp @@ -0,0 +1,49 @@ +#include "stdafx.h" +#include "net.minecraft.world.entity.ai.navigation.h" +#include "net.minecraft.world.entity.ai.village.h" +#include "net.minecraft.world.entity.h" +#include "net.minecraft.world.level.h" +#include "RestrictOpenDoorGoal.h" + +RestrictOpenDoorGoal::RestrictOpenDoorGoal(PathfinderMob *mob) +{ + this->mob = mob; +} + +bool RestrictOpenDoorGoal::canUse() +{ + if (mob->level->isDay()) return false; + shared_ptr village = mob->level->villages->getClosestVillage(Mth::floor(mob->x), Mth::floor(mob->y), Mth::floor(mob->z), 16); + if (village == NULL) return false; + shared_ptr _doorInfo = village->getClosestDoorInfo(Mth::floor(mob->x), Mth::floor(mob->y), Mth::floor(mob->z)); + if (_doorInfo == NULL) return false; + doorInfo = _doorInfo; + return _doorInfo->distanceToInsideSqr(Mth::floor(mob->x), Mth::floor(mob->y), Mth::floor(mob->z)) < 1.5 * 1.5; +} + +bool RestrictOpenDoorGoal::canContinueToUse() +{ + if (mob->level->isDay()) return false; + shared_ptr _doorInfo = doorInfo.lock(); + if ( _doorInfo == NULL ) return false; + return !_doorInfo->removed && _doorInfo->isInsideSide(Mth::floor(mob->x), Mth::floor(mob->z)); +} + +void RestrictOpenDoorGoal::start() +{ + mob->getNavigation()->setCanOpenDoors(false); + mob->getNavigation()->setCanPassDoors(false); +} + +void RestrictOpenDoorGoal::stop() +{ + mob->getNavigation()->setCanOpenDoors(true); + mob->getNavigation()->setCanPassDoors(true); + doorInfo = weak_ptr(); +} + +void RestrictOpenDoorGoal::tick() +{ + shared_ptr _doorInfo = doorInfo.lock(); + if ( _doorInfo ) _doorInfo->incBookingCount(); +} \ No newline at end of file -- cgit v1.2.3