Merge pull request #291 from Kebab11noel/fix/player-sync

Fix player sync
This commit is contained in:
TheMode 2021-05-15 21:25:45 +02:00 committed by GitHub
commit b67e438ddc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 19 additions and 15 deletions

View File

@ -268,7 +268,7 @@ public class Entity implements Viewable, Tickable, EventHandler, DataContainer,
final ChunkCallback endCallback = (chunk) -> { final ChunkCallback endCallback = (chunk) -> {
refreshPosition(teleportPosition); refreshPosition(teleportPosition);
synchronizePosition(); synchronizePosition(true);
OptionalCallback.execute(callback); OptionalCallback.execute(callback);
}; };
@ -594,7 +594,7 @@ public class Entity implements Viewable, Tickable, EventHandler, DataContainer,
// Synchronization and packets... // Synchronization and packets...
if (!isNettyClient) { if (!isNettyClient) {
synchronizePosition(); synchronizePosition(true);
} }
// Verify if velocity packet has to be sent // Verify if velocity packet has to be sent
if (hasVelocity() || (!isNettyClient && gravityTickCount > 0)) { if (hasVelocity() || (!isNettyClient && gravityTickCount > 0)) {
@ -665,7 +665,7 @@ public class Entity implements Viewable, Tickable, EventHandler, DataContainer,
// Scheduled synchronization // Scheduled synchronization
if (!Cooldown.hasCooldown(time, lastAbsoluteSynchronizationTime, getSynchronizationCooldown())) { if (!Cooldown.hasCooldown(time, lastAbsoluteSynchronizationTime, getSynchronizationCooldown())) {
synchronizePosition(); synchronizePosition(false);
} }
if (shouldRemove() && !MinecraftServer.isStopping()) { if (shouldRemove() && !MinecraftServer.isStopping()) {
@ -680,7 +680,7 @@ public class Entity implements Viewable, Tickable, EventHandler, DataContainer,
* The following packets are sent to viewers (check are performed in this order): * The following packets are sent to viewers (check are performed in this order):
* <ol> * <ol>
* <li>{@link EntityTeleportPacket} if {@code distanceX > 8 || distanceY > 8 || distanceZ > 8} * <li>{@link EntityTeleportPacket} if {@code distanceX > 8 || distanceY > 8 || distanceZ > 8}
* <i>(performed using {@link #synchronizePosition()})</i></li> * <i>(performed using {@link #synchronizePosition(boolean)})</i></li>
* <li>{@link EntityPositionAndRotationPacket} if {@code positionChange && viewChange}</li> * <li>{@link EntityPositionAndRotationPacket} if {@code positionChange && viewChange}</li>
* <li>{@link EntityPositionPacket} if {@code positionChange}</li> * <li>{@link EntityPositionPacket} if {@code positionChange}</li>
* <li>{@link EntityRotationPacket} and {@link EntityHeadLookPacket} if {@code viewChange}</li> * <li>{@link EntityRotationPacket} and {@link EntityHeadLookPacket} if {@code viewChange}</li>
@ -698,7 +698,7 @@ public class Entity implements Viewable, Tickable, EventHandler, DataContainer,
final boolean positionChange = (distanceX+distanceY+distanceZ) > 0; final boolean positionChange = (distanceX+distanceY+distanceZ) > 0;
if (distanceX > 8 || distanceY > 8 || distanceZ > 8) { if (distanceX > 8 || distanceY > 8 || distanceZ > 8) {
synchronizePosition(); synchronizePosition(true);
// #synchronizePosition sets sync fields, it's safe to return // #synchronizePosition sets sync fields, it's safe to return
return; return;
} else if (positionChange && viewChange) { } else if (positionChange && viewChange) {
@ -1583,9 +1583,11 @@ public class Entity implements Viewable, Tickable, EventHandler, DataContainer,
* {@link EntityTeleportPacket} to viewers, in case of a player this is * {@link EntityTeleportPacket} to viewers, in case of a player this is
* overridden in order to send an additional {@link PlayerPositionAndLookPacket} * overridden in order to send an additional {@link PlayerPositionAndLookPacket}
* to itself. * to itself.
* @param includeSelf if {@code true} and this is a {@link Player} an additional {@link PlayerPositionAndLookPacket}
* will be sent to the player itself
*/ */
@ApiStatus.Internal @ApiStatus.Internal
protected void synchronizePosition() { protected void synchronizePosition(boolean includeSelf) {
final Position pos = position.clone(); final Position pos = position.clone();
final EntityTeleportPacket entityTeleportPacket = new EntityTeleportPacket(); final EntityTeleportPacket entityTeleportPacket = new EntityTeleportPacket();
entityTeleportPacket.entityId = getEntityId(); entityTeleportPacket.entityId = getEntityId();

View File

@ -661,7 +661,7 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
} }
if (dimensionChange || firstSpawn) { if (dimensionChange || firstSpawn) {
synchronizePosition(); // So the player doesn't get stuck synchronizePosition(true); // So the player doesn't get stuck
this.inventory.update(); this.inventory.update();
} }
@ -1984,18 +1984,20 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
} }
/** /**
* @see Entity#synchronizePosition() * @see Entity#synchronizePosition(boolean)
*/ */
@Override @Override
@ApiStatus.Internal @ApiStatus.Internal
protected void synchronizePosition() { protected void synchronizePosition(boolean includeSelf) {
final PlayerPositionAndLookPacket positionAndLookPacket = new PlayerPositionAndLookPacket(); if (includeSelf) {
positionAndLookPacket.position = position.clone(); final PlayerPositionAndLookPacket positionAndLookPacket = new PlayerPositionAndLookPacket();
positionAndLookPacket.flags = 0x00; positionAndLookPacket.position = position.clone();
positionAndLookPacket.teleportId = teleportId.incrementAndGet(); positionAndLookPacket.flags = 0x00;
playerConnection.sendPacket(positionAndLookPacket); positionAndLookPacket.teleportId = teleportId.incrementAndGet();
playerConnection.sendPacket(positionAndLookPacket);
}
super.synchronizePosition(); super.synchronizePosition(includeSelf);
} }
/** /**