mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-04 23:47:59 +01:00
Simplify movement processing
This commit is contained in:
parent
bca3324b56
commit
1dc80d6b87
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user