aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.Client/EntityTracker.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.Client/EntityTracker.h
parentdef8cb415354ac390b7e89052a50605285f1aca9 (diff)
Initial commit
Diffstat (limited to 'Minecraft.Client/EntityTracker.h')
-rw-r--r--Minecraft.Client/EntityTracker.h36
1 files changed, 36 insertions, 0 deletions
diff --git a/Minecraft.Client/EntityTracker.h b/Minecraft.Client/EntityTracker.h
new file mode 100644
index 00000000..82b01d07
--- /dev/null
+++ b/Minecraft.Client/EntityTracker.h
@@ -0,0 +1,36 @@
+#pragma once
+#include "..\Minecraft.World\HashExtension.h"
+#include "..\Minecraft.World\JavaIntHash.h"
+class Entity;
+class ServerPlayer;
+class TrackedEntity;
+class MinecraftServer;
+class Packet;
+
+using namespace std;
+
+class EntityTracker
+{
+private:
+ ServerLevel *level;
+ unordered_set<shared_ptr<TrackedEntity> > entities;
+ unordered_map<int, shared_ptr<TrackedEntity> , IntKeyHash2, IntKeyEq> entityMap; // was IntHashMap
+ int maxRange;
+
+public:
+ EntityTracker(ServerLevel *level);
+ void addEntity(shared_ptr<Entity> e);
+ void addEntity(shared_ptr<Entity> e, int range, int updateInterval);
+ void addEntity(shared_ptr<Entity> e, int range, int updateInterval, bool trackDeltas);
+ void removeEntity(shared_ptr<Entity> e);
+ void removePlayer(shared_ptr<Entity> e); // 4J added
+ void tick();
+ void broadcast(shared_ptr<Entity> e, shared_ptr<Packet> packet);
+ void broadcastAndSend(shared_ptr<Entity> e, shared_ptr<Packet> packet);
+ void clear(shared_ptr<ServerPlayer> serverPlayer);
+ void updateMaxRange(); // AP added for Vita
+
+
+ // 4J-JEV: Added, needed access to tracked entity of a riders mount.
+ shared_ptr<TrackedEntity> getTracker(shared_ptr<Entity> entity);
+};