aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0914-Configurable-entity-tracking-range-by-Y-coordinate.patch
diff options
context:
space:
mode:
authormaxcom1 <[email protected]>2024-03-23 22:26:17 +0100
committerGitHub <[email protected]>2024-03-23 17:26:17 -0400
commitb6001403e9703cadaa6e8c8558e732b91c3c6d6e (patch)
treea8c57bbc334a8ad48d4ad2b43db335667b142bee /patches/server/0914-Configurable-entity-tracking-range-by-Y-coordinate.patch
parent9ec7dfcbc41c6e625de0050b6997160a75df9f44 (diff)
downloadPaper-b6001403e9703cadaa6e8c8558e732b91c3c6d6e.tar.gz
Paper-b6001403e9703cadaa6e8c8558e732b91c3c6d6e.zip
Add methods to change entity physics (#10334)
Diffstat (limited to 'patches/server/0914-Configurable-entity-tracking-range-by-Y-coordinate.patch')
-rw-r--r--patches/server/0914-Configurable-entity-tracking-range-by-Y-coordinate.patch27
1 files changed, 27 insertions, 0 deletions
diff --git a/patches/server/0914-Configurable-entity-tracking-range-by-Y-coordinate.patch b/patches/server/0914-Configurable-entity-tracking-range-by-Y-coordinate.patch
new file mode 100644
index 0000000000..81dacf5aab
--- /dev/null
+++ b/patches/server/0914-Configurable-entity-tracking-range-by-Y-coordinate.patch
@@ -0,0 +1,27 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: ruViolence <[email protected]>
+Date: Tue, 27 Jun 2023 15:38:18 +0800
+Subject: [PATCH] Configurable entity tracking range by Y coordinate
+
+Options to configure entity tracking by Y coordinate, also for each entity category.
+
+diff --git a/src/main/java/net/minecraft/server/level/ChunkMap.java b/src/main/java/net/minecraft/server/level/ChunkMap.java
+index ca24463405f138deb882f319bf84696f52a1f606..aed4f4ac21b8ddc9c9ee7ce5151bbfc8bb6cf7f5 100644
+--- a/src/main/java/net/minecraft/server/level/ChunkMap.java
++++ b/src/main/java/net/minecraft/server/level/ChunkMap.java
+@@ -1741,6 +1741,15 @@ public class ChunkMap extends ChunkStorage implements ChunkHolder.PlayerProvider
+ double d1 = vec3d.x * vec3d.x + vec3d.z * vec3d.z;
+ double d2 = d0 * d0;
+ boolean flag = d1 <= d2 && this.entity.broadcastToPlayer(player) && ChunkMap.this.isChunkTracked(player, this.entity.chunkPosition().x, this.entity.chunkPosition().z);
++ // Paper start - Configurable entity tracking range by Y
++ if (flag && level.paperConfig().entities.trackingRangeY.enabled) {
++ double rangeY = level.paperConfig().entities.trackingRangeY.get(this.entity, -1);
++ if (rangeY != -1) {
++ double vec3d_dy = player.getY() - this.entity.getY();
++ flag = vec3d_dy * vec3d_dy <= rangeY * rangeY;
++ }
++ }
++ // Paper end - Configurable entity tracking range by Y
+
+ // CraftBukkit start - respect vanish API
+ if (!player.getBukkitEntity().canSee(this.entity.getBukkitEntity())) {