mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-08 17:37:42 +01:00
Fix info update
Signed-off-by: TheMode <themode@outlook.fr>
This commit is contained in:
parent
7ba55fdfef
commit
1a606285c0
@ -444,7 +444,7 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
|
|||||||
setOnFire(false);
|
setOnFire(false);
|
||||||
refreshHealth();
|
refreshHealth();
|
||||||
sendPacket(new RespawnPacket(getDimensionType().toString(), getDimensionType().getName().asString(),
|
sendPacket(new RespawnPacket(getDimensionType().toString(), getDimensionType().getName().asString(),
|
||||||
0, gameMode, gameMode, false, levelFlat, true));
|
0, gameMode, gameMode, false, levelFlat, true));
|
||||||
|
|
||||||
PlayerRespawnEvent respawnEvent = new PlayerRespawnEvent(this);
|
PlayerRespawnEvent respawnEvent = new PlayerRespawnEvent(this);
|
||||||
EventDispatcher.call(respawnEvent);
|
EventDispatcher.call(respawnEvent);
|
||||||
@ -932,9 +932,7 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
|
|||||||
*/
|
*/
|
||||||
public void setDisplayName(@Nullable Component displayName) {
|
public void setDisplayName(@Nullable Component displayName) {
|
||||||
this.displayName = displayName;
|
this.displayName = displayName;
|
||||||
// TODO
|
PacketUtils.broadcastPacket(new PlayerInfoUpdatePacket(PlayerInfoUpdatePacket.Action.UPDATE_DISPLAY_NAME, infoEntry()));
|
||||||
//PacketUtils.broadcastPacket(new PlayerInfoPacket(PlayerInfoPacket.Action.UPDATE_DISPLAY_NAME,
|
|
||||||
// new PlayerInfoPacket.UpdateDisplayName(getUuid(), displayName)));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1289,9 +1287,7 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
|
|||||||
// Condition to prevent sending the packets before spawning the player
|
// Condition to prevent sending the packets before spawning the player
|
||||||
if (isActive()) {
|
if (isActive()) {
|
||||||
sendPacket(new ChangeGameStatePacket(ChangeGameStatePacket.Reason.CHANGE_GAMEMODE, gameMode.id()));
|
sendPacket(new ChangeGameStatePacket(ChangeGameStatePacket.Reason.CHANGE_GAMEMODE, gameMode.id()));
|
||||||
// TODO
|
PacketUtils.broadcastPacket(new PlayerInfoUpdatePacket(PlayerInfoUpdatePacket.Action.UPDATE_GAME_MODE, infoEntry()));
|
||||||
//PacketUtils.broadcastPacket(new PlayerInfoPacket(PlayerInfoPacket.Action.UPDATE_GAMEMODE,
|
|
||||||
// new PlayerInfoPacket.UpdateGameMode(getUuid(), gameMode)));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// The client updates their abilities based on the GameMode as follows
|
// The client updates their abilities based on the GameMode as follows
|
||||||
@ -1791,9 +1787,7 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
|
|||||||
*/
|
*/
|
||||||
public void refreshLatency(int latency) {
|
public void refreshLatency(int latency) {
|
||||||
this.latency = latency;
|
this.latency = latency;
|
||||||
// TODO
|
PacketUtils.broadcastPacket(new PlayerInfoUpdatePacket(PlayerInfoUpdatePacket.Action.UPDATE_LATENCY, infoEntry()));
|
||||||
//PacketUtils.broadcastPacket(new PlayerInfoPacket(PlayerInfoPacket.Action.UPDATE_LATENCY,
|
|
||||||
// new PlayerInfoPacket.UpdateLatency(getUuid(), latency)));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void refreshOnGround(boolean onGround) {
|
public void refreshOnGround(boolean onGround) {
|
||||||
@ -1914,13 +1908,8 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
|
|||||||
* @return a {@link PlayerInfoUpdatePacket} to add the player
|
* @return a {@link PlayerInfoUpdatePacket} to add the player
|
||||||
*/
|
*/
|
||||||
protected @NotNull PlayerInfoUpdatePacket getAddPlayerToList() {
|
protected @NotNull PlayerInfoUpdatePacket getAddPlayerToList() {
|
||||||
final PlayerSkin skin = this.skin;
|
|
||||||
List<PlayerInfoUpdatePacket.Property> prop = skin != null ?
|
|
||||||
List.of(new PlayerInfoUpdatePacket.Property("textures", skin.textures(), skin.signature())) :
|
|
||||||
List.of();
|
|
||||||
return new PlayerInfoUpdatePacket(EnumSet.of(PlayerInfoUpdatePacket.Action.ADD_PLAYER, PlayerInfoUpdatePacket.Action.UPDATE_LISTED),
|
return new PlayerInfoUpdatePacket(EnumSet.of(PlayerInfoUpdatePacket.Action.ADD_PLAYER, PlayerInfoUpdatePacket.Action.UPDATE_LISTED),
|
||||||
List.of(new PlayerInfoUpdatePacket.Entry(getUuid(), getUsername(), prop,
|
List.of(infoEntry()));
|
||||||
true, getLatency(), getGameMode(), displayName)));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1932,6 +1921,15 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
|
|||||||
return new PlayerInfoRemovePacket(List.of(getUuid()));
|
return new PlayerInfoRemovePacket(List.of(getUuid()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private PlayerInfoUpdatePacket.Entry infoEntry() {
|
||||||
|
final PlayerSkin skin = this.skin;
|
||||||
|
List<PlayerInfoUpdatePacket.Property> prop = skin != null ?
|
||||||
|
List.of(new PlayerInfoUpdatePacket.Property("textures", skin.textures(), skin.signature())) :
|
||||||
|
List.of();
|
||||||
|
return new PlayerInfoUpdatePacket.Entry(getUuid(), getUsername(), prop,
|
||||||
|
true, getLatency(), getGameMode(), displayName);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sends all the related packet to have the player sent to another with related data
|
* Sends all the related packet to have the player sent to another with related data
|
||||||
* (create player, spawn position, velocity, metadata, equipments, passengers, team).
|
* (create player, spawn position, velocity, metadata, equipments, passengers, team).
|
||||||
|
@ -16,6 +16,10 @@ import static net.minestom.server.network.NetworkBuffer.*;
|
|||||||
|
|
||||||
public record PlayerInfoUpdatePacket(@NotNull EnumSet<@NotNull Action> actions,
|
public record PlayerInfoUpdatePacket(@NotNull EnumSet<@NotNull Action> actions,
|
||||||
@NotNull List<@NotNull Entry> entries) implements ServerPacket {
|
@NotNull List<@NotNull Entry> entries) implements ServerPacket {
|
||||||
|
public PlayerInfoUpdatePacket(@NotNull Action action, @NotNull Entry entry) {
|
||||||
|
this(EnumSet.of(action), List.of(entry));
|
||||||
|
}
|
||||||
|
|
||||||
public PlayerInfoUpdatePacket {
|
public PlayerInfoUpdatePacket {
|
||||||
actions = EnumSet.copyOf(actions);
|
actions = EnumSet.copyOf(actions);
|
||||||
entries = List.copyOf(entries);
|
entries = List.copyOf(entries);
|
||||||
@ -47,7 +51,7 @@ public record PlayerInfoUpdatePacket(@NotNull EnumSet<@NotNull Action> actions,
|
|||||||
|
|
||||||
public record Property(@NotNull String name, @NotNull String value,
|
public record Property(@NotNull String name, @NotNull String value,
|
||||||
@Nullable String signature) implements NetworkBuffer.Writer {
|
@Nullable String signature) implements NetworkBuffer.Writer {
|
||||||
public Property(String name, String value) {
|
public Property(@NotNull String name, @NotNull String value) {
|
||||||
this(name, value, null);
|
this(name, value, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user