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/CaveSpider.cpp | 64 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 64 insertions(+) create mode 100644 Minecraft.World/CaveSpider.cpp (limited to 'Minecraft.World/CaveSpider.cpp') diff --git a/Minecraft.World/CaveSpider.cpp b/Minecraft.World/CaveSpider.cpp new file mode 100644 index 00000000..5f7c6028 --- /dev/null +++ b/Minecraft.World/CaveSpider.cpp @@ -0,0 +1,64 @@ +#include "stdafx.h" +#include "SharedConstants.h" +#include "net.minecraft.world.effect.h" +#include "net.minecraft.world.level.h" +#include "net.minecraft.world.h" +#include "..\Minecraft.Client\Textures.h" +#include "CaveSpider.h" + + + +CaveSpider::CaveSpider(Level *level) : Spider(level) +{ + // 4J Stu - This function call had to be moved here from the Entity ctor to ensure that the derived version of the function is called + health = getMaxHealth(); + + this->textureIdx = TN_MOB_CAVE_SPIDER; // 4J was "/mob/cavespider.png"; + this->setSize(0.7f, 0.5f); +} + +int CaveSpider::getMaxHealth() +{ + return 12; +} + +float CaveSpider::getModelScale() +{ + return .7f; +} + + +bool CaveSpider::doHurtTarget(shared_ptr target) +{ + if (Spider::doHurtTarget(target)) + { + if ( dynamic_pointer_cast(target) != NULL) + { + int poisonTime = 0; + if (level->difficulty <= Difficulty::EASY) + { + // No poison! + } + else if (level->difficulty == Difficulty::NORMAL) + { + poisonTime = 7; + } + else if (level->difficulty == Difficulty::HARD) + { + poisonTime = 15; + } + + if (poisonTime > 0) { + dynamic_pointer_cast(target)->addEffect(new MobEffectInstance(MobEffect::poison->id, poisonTime * SharedConstants::TICKS_PER_SECOND, 0)); + } + } + + return true; + } + return false; +} + +void CaveSpider::finalizeMobSpawn() +{ + // do nothing +} \ No newline at end of file -- cgit v1.2.3