aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/HangingEntity.h
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/HangingEntity.h
parentdef8cb415354ac390b7e89052a50605285f1aca9 (diff)
Initial commit
Diffstat (limited to 'Minecraft.World/HangingEntity.h')
-rw-r--r--Minecraft.World/HangingEntity.h42
1 files changed, 42 insertions, 0 deletions
diff --git a/Minecraft.World/HangingEntity.h b/Minecraft.World/HangingEntity.h
new file mode 100644
index 00000000..b87915e4
--- /dev/null
+++ b/Minecraft.World/HangingEntity.h
@@ -0,0 +1,42 @@
+
+#pragma once
+
+#include "Entity.h"
+
+class HangingEntity : public Entity
+{
+public:
+ eINSTANCEOF GetType() { return eTYPE_HANGING_ENTITY; }
+private:
+
+ void _init(Level *level);
+ float offs(int w);
+
+ int checkInterval;
+ //eINSTANCEOF eType;
+
+protected:
+ virtual void defineSynchedData() {};
+
+public:
+ int dir;
+ int xTile, yTile, zTile;
+
+ HangingEntity(Level *level);
+ HangingEntity(Level *level, int xTile, int yTile, int zTile, int dir);
+ void setDir(int dir);
+ bool survives();
+
+ virtual void tick();
+ virtual bool isPickable();
+ virtual bool skipAttackInteraction(shared_ptr<Entity> source);
+ virtual bool hurt(DamageSource *source, int damage);
+ virtual void move(double xa, double ya, double za, bool noEntityCubes=false); // 4J - added noEntityCubes parameter
+ virtual void push(double xa, double ya, double za);
+ virtual void addAdditonalSaveData(CompoundTag *tag);
+ virtual void readAdditionalSaveData(CompoundTag *tag);
+
+ virtual int getWidth()=0;
+ virtual int getHeight()=0;
+ virtual void dropItem()=0;
+};