Simplify movement processing

This commit is contained in:
TheMode 2021-07-20 07:05:08 +02:00
parent bca3324b56
commit 1dc80d6b87
2 changed files with 16 additions and 35 deletions

View File

@ -16,42 +16,27 @@ public class PlayerPositionListener {
} }
public static void playerLookListener(ClientPlayerRotationPacket packet, Player player) { public static void playerLookListener(ClientPlayerRotationPacket packet, Player player) {
final var playerPosition = player.getPosition(); processMovement(player, player.getPosition().withView(packet.yaw, packet.pitch), packet.onGround);
final double x = playerPosition.x();
final double y = playerPosition.y();
final double z = playerPosition.z();
final float yaw = packet.yaw;
final float pitch = packet.pitch;
final boolean onGround = packet.onGround;
processMovement(player, x, y, z, yaw, pitch, onGround);
} }
public static void playerPositionListener(ClientPlayerPositionPacket packet, Player player) { public static void playerPositionListener(ClientPlayerPositionPacket packet, Player player) {
final var playerPosition = player.getPosition(); processMovement(player, player.getPosition().withCoord(packet.x, packet.y, packet.z), packet.onGround);
final float yaw = playerPosition.yaw();
final float pitch = playerPosition.pitch();
final boolean onGround = packet.onGround;
processMovement(player,
packet.x, packet.y, packet.z,
yaw, pitch, onGround);
} }
public static void playerPositionAndLookListener(ClientPlayerPositionAndRotationPacket packet, Player player) { public static void playerPositionAndLookListener(ClientPlayerPositionAndRotationPacket packet, Player player) {
final float yaw = packet.yaw; processMovement(player, new Pos(packet.x, packet.y, packet.z, packet.yaw, packet.pitch), packet.onGround);
final float pitch = packet.pitch;
final boolean onGround = packet.onGround;
processMovement(player,
packet.x, packet.y, packet.z,
yaw, pitch, onGround);
} }
public static void teleportConfirmListener(ClientTeleportConfirmPacket packet, Player player) { public static void teleportConfirmListener(ClientTeleportConfirmPacket packet, Player player) {
final int packetTeleportId = packet.teleportId; player.refreshReceivedTeleportId(packet.teleportId);
player.refreshReceivedTeleportId(packetTeleportId);
} }
private static void processMovement(@NotNull Player player, double x, double y, double z, private static void processMovement(@NotNull Player player, @NotNull Pos newPosition, boolean onGround) {
float yaw, float pitch, boolean onGround) { final var currentPosition = player.getPosition();
if (currentPosition.equals(newPosition)) {
// For some reason, the position is the same
return;
}
final Instance instance = player.getInstance(); final Instance instance = player.getInstance();
// Prevent moving before the player spawned, probably a modified client (or high latency?) // Prevent moving before the player spawned, probably a modified client (or high latency?)
if (instance == null) { if (instance == null) {
@ -61,17 +46,9 @@ public class PlayerPositionListener {
if (player.getLastSentTeleportId() != player.getLastReceivedTeleportId()) { if (player.getLastSentTeleportId() != player.getLastReceivedTeleportId()) {
return; return;
} }
final var currentPosition = player.getPosition();
final var newPosition = new Pos(x, y, z, yaw, pitch);
if (currentPosition.equals(newPosition)) {
// For some reason, the position is the same
return;
}
// Try to move in an unloaded chunk, prevent it // Try to move in an unloaded chunk, prevent it
if (!currentPosition.sameChunk(newPosition) && !ChunkUtils.isLoaded(instance, x, z)) { if (!currentPosition.sameChunk(newPosition) && !ChunkUtils.isLoaded(instance, newPosition)) {
player.teleport(player.getPosition()); player.teleport(currentPosition);
return; return;
} }

View File

@ -81,6 +81,10 @@ public final class ChunkUtils {
return isLoaded(chunk); return isLoaded(chunk);
} }
public static boolean isLoaded(@NotNull Instance instance, @NotNull Point point) {
return isLoaded(instance, point.x(), point.z());
}
public static Chunk retrieve(Instance instance, Chunk originChunk, double x, double z) { public static Chunk retrieve(Instance instance, Chunk originChunk, double x, double z) {
final int chunkX = getChunkCoordinate(x); final int chunkX = getChunkCoordinate(x);
final int chunkZ = getChunkCoordinate(z); final int chunkZ = getChunkCoordinate(z);