aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.Client/TrackedEntity.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/TrackedEntity.h
parentdef8cb415354ac390b7e89052a50605285f1aca9 (diff)
Initial commit
Diffstat (limited to 'Minecraft.Client/TrackedEntity.h')
-rw-r--r--Minecraft.Client/TrackedEntity.h65
1 files changed, 65 insertions, 0 deletions
diff --git a/Minecraft.Client/TrackedEntity.h b/Minecraft.Client/TrackedEntity.h
new file mode 100644
index 00000000..9fb564a4
--- /dev/null
+++ b/Minecraft.Client/TrackedEntity.h
@@ -0,0 +1,65 @@
+#pragma once
+class Entity;
+//class ServerPlayer;
+#include "ServerPlayer.h"
+class Packet;
+using namespace std;
+
+class EntityTracker;
+
+#define TRACKED_ENTITY_MINIMUM_VIEW_DISTANCE 4
+
+class TrackedEntity
+{
+private:
+ static const int TOLERANCE_LEVEL = 4;
+
+public:
+ shared_ptr<Entity> e;
+
+ int range, updateInterval;
+ int xp, yp, zp, yRotp, xRotp, yHeadRotp;
+ double xap, yap, zap;
+ int tickCount;
+
+private:
+ double xpu, ypu, zpu;
+ bool updatedPlayerVisibility;
+ bool trackDelta;
+ int teleportDelay;
+ shared_ptr<Entity> wasRiding;
+
+public:
+ bool moved;
+
+ unordered_set<shared_ptr<ServerPlayer> , PlayerKeyHash, PlayerKeyEq > seenBy;
+
+ TrackedEntity(shared_ptr<Entity> e, int range, int updateInterval, bool trackDelta);
+
+ void tick(EntityTracker *tracker, vector<shared_ptr<Player> > *players);
+ void broadcast(shared_ptr<Packet> packet);
+ void broadcastAndSend(shared_ptr<Packet> packet);
+ void broadcastRemoved();
+ void removePlayer(shared_ptr<ServerPlayer> sp);
+
+private:
+ bool canBySeenBy(shared_ptr<ServerPlayer> player);
+
+ enum eVisibility
+ {
+ eVisibility_NotVisible = 0,
+ eVisibility_IsVisible = 1,
+ eVisibility_SeenAndVisible = 2,
+ };
+
+ eVisibility isVisible(EntityTracker *tracker, shared_ptr<ServerPlayer> sp, bool forRider = false); // 4J Added forRider
+
+public:
+ void updatePlayer(EntityTracker *tracker, shared_ptr<ServerPlayer> sp);
+ void updatePlayers(EntityTracker *tracker, vector<shared_ptr<Player> > *players);
+private:
+ void sendEntityData(shared_ptr<PlayerConnection> conn);
+ shared_ptr<Packet> getAddEntityPacket();
+public:
+ void clear(shared_ptr<ServerPlayer> sp);
+};