PaperMC/Spigot-Server-Patches/Add-player-view-distance-API.patch

111 lines
4.9 KiB
Diff
Raw Normal View History

2015-07-01 10:01:42 +02:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
From: Byteflux <byte@byteflux.net>
2016-03-01 00:09:49 +01:00
Date: Wed, 2 Mar 2016 14:35:27 -0600
2015-07-01 10:01:42 +02:00
Subject: [PATCH] Add player view distance API
diff --git a/src/main/java/net/minecraft/server/EntityPlayer.java b/src/main/java/net/minecraft/server/EntityPlayer.java
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
--- a/src/main/java/net/minecraft/server/EntityPlayer.java
+++ b/src/main/java/net/minecraft/server/EntityPlayer.java
@@ -0,0 +0,0 @@ public class EntityPlayer extends EntityHuman implements ICrafting {
2016-03-01 00:09:49 +01:00
public boolean f;
public int ping;
public boolean viewingCredits;
+ public int viewDistance; // Paper - Player view distance API
2015-07-01 10:01:42 +02:00
2016-03-01 00:09:49 +01:00
// CraftBukkit start
public String displayName;
2015-07-01 10:01:42 +02:00
@@ -0,0 +0,0 @@ public class EntityPlayer extends EntityHuman implements ICrafting {
public EntityPlayer(MinecraftServer minecraftserver, WorldServer worldserver, GameProfile gameprofile, PlayerInteractManager playerinteractmanager) {
super(worldserver, gameprofile);
2016-03-01 00:09:49 +01:00
+ this.viewDistance = world.spigotConfig.viewDistance; // Paper - Player view distance API
2015-07-01 10:01:42 +02:00
playerinteractmanager.player = this;
this.playerInteractManager = playerinteractmanager;
BlockPosition blockposition = worldserver.getSpawn();
diff --git a/src/main/java/net/minecraft/server/PlayerChunkMap.java b/src/main/java/net/minecraft/server/PlayerChunkMap.java
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
--- a/src/main/java/net/minecraft/server/PlayerChunkMap.java
+++ b/src/main/java/net/minecraft/server/PlayerChunkMap.java
@@ -0,0 +0,0 @@ public class PlayerChunkMap {
int i = (int) entityplayer.d >> 4;
int j = (int) entityplayer.e >> 4;
2016-03-01 00:09:49 +01:00
- for (int k = i - this.j; k <= i + this.j; ++k) {
- for (int l = j - this.j; l <= j + this.j; ++l) {
+ // Paper start - Player view distance API
2015-07-01 10:01:42 +02:00
+ for (int k = i - entityplayer.viewDistance; k <= i + entityplayer.viewDistance; ++k) {
+ for (int l = j - entityplayer.viewDistance; l <= j + entityplayer.viewDistance; ++l) {
2016-03-01 00:09:49 +01:00
+ // Paper end
PlayerChunk playerchunk = this.b(k, l);
2015-07-01 10:01:42 +02:00
2016-03-01 00:09:49 +01:00
if (playerchunk != null) {
2015-07-01 10:01:42 +02:00
@@ -0,0 +0,0 @@ public class PlayerChunkMap {
if (d2 >= 64.0D) {
int k = (int) entityplayer.d >> 4;
int l = (int) entityplayer.e >> 4;
2016-03-01 00:09:49 +01:00
- int i1 = this.j;
+ int i1 = entityplayer.viewDistance; // Paper - Player view distance API
2015-07-01 10:01:42 +02:00
int j1 = i - k;
int k1 = j - l;
2016-03-01 00:09:49 +01:00
2015-07-01 10:01:42 +02:00
@@ -0,0 +0,0 @@ public class PlayerChunkMap {
}
}
2016-03-01 00:09:49 +01:00
// CraftBukkit end
+
+ // Paper start - Player view distance API
2015-07-01 10:01:42 +02:00
+ public void updateViewDistance(EntityPlayer player, int viewDistance) {
+ viewDistance = MathHelper.clamp(viewDistance, 3, 32);
+ if (viewDistance != player.viewDistance) {
+ int cx = (int) player.locX >> 4;
+ int cz = (int) player.locZ >> 4;
+
+ if (viewDistance - player.viewDistance > 0) {
+ for (int x = cx - viewDistance; x <= cx + viewDistance; ++x) {
+ for (int z = cz - viewDistance; z <= cz + viewDistance; ++z) {
2016-03-01 00:09:49 +01:00
+ PlayerChunk playerchunkmap_playerchunk = this.c(x, z);
2015-07-01 10:01:42 +02:00
+
2016-03-01 00:09:49 +01:00
+ if (!playerchunkmap_playerchunk.c.contains(player)) {
2015-07-01 10:01:42 +02:00
+ playerchunkmap_playerchunk.a(player);
+ }
+ }
+ }
+ } else {
+ for (int x = cx - player.viewDistance; x <= cx + player.viewDistance; ++x) {
+ for (int z = cz - player.viewDistance; z <= cz + player.viewDistance; ++z) {
+ if (!this.a(x, z, cx, cz, viewDistance)) {
2016-03-01 00:09:49 +01:00
+ this.c(x, z).b(player);
2015-07-01 10:01:42 +02:00
+ }
+ }
+ }
+ }
+
+ player.viewDistance = viewDistance;
+ }
+ }
2016-03-01 00:09:49 +01:00
+ // Paper end
}
2015-07-01 10:01:42 +02:00
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
@@ -0,0 +0,0 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
return this.getHandle().affectsSpawning;
2016-03-01 00:09:49 +01:00
}
2016-03-01 00:09:49 +01:00
+ @Override
+ public int getViewDistance() {
+ return getHandle().viewDistance;
+ }
2015-07-01 10:01:42 +02:00
+
2016-03-01 00:09:49 +01:00
+ @Override
+ public void setViewDistance(int viewDistance) {
+ ((WorldServer) getHandle().world).getPlayerChunkMap().updateViewDistance(getHandle(), viewDistance);
+ }
+
2016-03-01 00:09:49 +01:00
// Spigot start
private final Player.Spigot spigot = new Player.Spigot()
{
2015-08-29 10:12:41 +02:00
--