Fix position update

This commit is contained in:
Németh Noel 2021-05-01 04:27:21 +02:00
parent dbd0c302d5
commit 3abef8c9a7
2 changed files with 3 additions and 5 deletions

View File

@ -693,7 +693,8 @@ public class Entity implements Viewable, Tickable, EventHandler, DataContainer,
* *
* @param notFromListener {@code true} if the client triggered this action * @param notFromListener {@code true} if the client triggered this action
*/ */
protected void sendPositionUpdate(final boolean notFromListener) { @ApiStatus.Internal
public void sendPositionUpdate(final boolean notFromListener) {
final boolean viewChange = !position.hasSimilarView(lastSyncedPosition); final boolean viewChange = !position.hasSimilarView(lastSyncedPosition);
final double distanceX = Math.abs(position.getX()-lastSyncedPosition.getX()); final double distanceX = Math.abs(position.getX()-lastSyncedPosition.getX());
final double distanceY = Math.abs(position.getY()-lastSyncedPosition.getY()); final double distanceY = Math.abs(position.getY()-lastSyncedPosition.getY());
@ -1357,8 +1358,6 @@ public class Entity implements Viewable, Tickable, EventHandler, DataContainer,
position.setY(y); position.setY(y);
position.setZ(z); position.setZ(z);
sendPositionUpdate(false);
if (hasPassenger()) { if (hasPassenger()) {
for (Entity passenger : getPassengers()) { for (Entity passenger : getPassengers()) {
passenger.refreshPosition(x, y, z); passenger.refreshPosition(x, y, z);
@ -1416,8 +1415,6 @@ public class Entity implements Viewable, Tickable, EventHandler, DataContainer,
this.lastPosition.setPitch(position.getPitch()); this.lastPosition.setPitch(position.getPitch());
position.setYaw(yaw); position.setYaw(yaw);
position.setPitch(pitch); position.setPitch(pitch);
sendPositionUpdate(false);
} }
/** /**

View File

@ -90,6 +90,7 @@ public class PlayerPositionListener {
player.refreshPosition(newPosition.getX(), newPosition.getY(), newPosition.getZ()); player.refreshPosition(newPosition.getX(), newPosition.getY(), newPosition.getZ());
player.refreshView(newPosition.getYaw(), newPosition.getPitch()); player.refreshView(newPosition.getYaw(), newPosition.getPitch());
player.refreshOnGround(onGround); player.refreshOnGround(onGround);
player.sendPositionUpdate(false);
} else { } else {
player.teleport(player.getPosition()); player.teleport(player.getPosition());
} }