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/EnderpearlItem.cpp | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 Minecraft.World/EnderpearlItem.cpp (limited to 'Minecraft.World/EnderpearlItem.cpp') diff --git a/Minecraft.World/EnderpearlItem.cpp b/Minecraft.World/EnderpearlItem.cpp new file mode 100644 index 00000000..7a9b6e52 --- /dev/null +++ b/Minecraft.World/EnderpearlItem.cpp @@ -0,0 +1,34 @@ +#include "stdafx.h" +#include "net.minecraft.world.level.h" +#include "net.minecraft.world.entity.player.h" +#include "net.minecraft.world.entity.projectile.h" +#include "EnderpearlItem.h" +#include "SoundTypes.h" + +EnderpearlItem::EnderpearlItem(int id) : Item(id) +{ + this->maxStackSize = 16; +} + +bool EnderpearlItem::TestUse(Level *level, shared_ptr player) +{ + return true; +} + +shared_ptr EnderpearlItem::use(shared_ptr instance, Level *level, shared_ptr player) +{ + // 4J-PB - Not sure why this was disabled for creative mode, so commenting out + //if (player->abilities.instabuild) return instance; + if (player->riding != NULL) return instance; + if (!player->abilities.instabuild) + { + instance->count--; + } + + level->playSound(player, eSoundType_RANDOM_BOW, 0.5f, 0.4f / (random->nextFloat() * 0.4f + 0.8f)); + if (!level->isClientSide) + { + level->addEntity( shared_ptr( new ThrownEnderpearl(level, player) ) ); + } + return instance; +} \ No newline at end of file -- cgit v1.2.3