mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-08 01:17:47 +01:00
fix: update advancement packet to 1.20.4
This commit is contained in:
parent
3bbdb1f0c9
commit
03ef3e2374
@ -4,6 +4,9 @@ import net.kyori.adventure.resource.ResourcePackInfo;
|
|||||||
import net.kyori.adventure.resource.ResourcePackRequest;
|
import net.kyori.adventure.resource.ResourcePackRequest;
|
||||||
import net.kyori.adventure.text.Component;
|
import net.kyori.adventure.text.Component;
|
||||||
import net.minestom.server.MinecraftServer;
|
import net.minestom.server.MinecraftServer;
|
||||||
|
import net.minestom.server.advancements.FrameType;
|
||||||
|
import net.minestom.server.advancements.notifications.Notification;
|
||||||
|
import net.minestom.server.advancements.notifications.NotificationCenter;
|
||||||
import net.minestom.server.adventure.MinestomAdventure;
|
import net.minestom.server.adventure.MinestomAdventure;
|
||||||
import net.minestom.server.adventure.audience.Audiences;
|
import net.minestom.server.adventure.audience.Audiences;
|
||||||
import net.minestom.server.coordinate.Pos;
|
import net.minestom.server.coordinate.Pos;
|
||||||
@ -115,6 +118,15 @@ public class PlayerInit {
|
|||||||
})
|
})
|
||||||
.build();
|
.build();
|
||||||
player.getInventory().addItemStack(bundle);
|
player.getInventory().addItemStack(bundle);
|
||||||
|
|
||||||
|
if (event.isFirstSpawn()) {
|
||||||
|
Notification notification = new Notification(
|
||||||
|
Component.text("Welcome!"),
|
||||||
|
FrameType.TASK,
|
||||||
|
Material.IRON_SWORD
|
||||||
|
);
|
||||||
|
NotificationCenter.send(notification, event.getPlayer());
|
||||||
|
}
|
||||||
})
|
})
|
||||||
.addListener(PlayerPacketOutEvent.class, event -> {
|
.addListener(PlayerPacketOutEvent.class, event -> {
|
||||||
//System.out.println("out " + event.getPacket().getClass().getSimpleName());
|
//System.out.println("out " + event.getPacket().getClass().getSimpleName());
|
||||||
|
@ -308,7 +308,6 @@ public class Advancement {
|
|||||||
final Advancement parent = getParent();
|
final Advancement parent = getParent();
|
||||||
final String parentIdentifier = parent != null ? parent.getIdentifier() : null;
|
final String parentIdentifier = parent != null ? parent.getIdentifier() : null;
|
||||||
AdvancementsPacket.Advancement adv = new AdvancementsPacket.Advancement(parentIdentifier, toDisplayData(),
|
AdvancementsPacket.Advancement adv = new AdvancementsPacket.Advancement(parentIdentifier, toDisplayData(),
|
||||||
List.of(criteria.criterionIdentifier()),
|
|
||||||
List.of(new AdvancementsPacket.Requirement(List.of(criteria.criterionIdentifier()))),
|
List.of(new AdvancementsPacket.Requirement(List.of(criteria.criterionIdentifier()))),
|
||||||
sendTelemetryData);
|
sendTelemetryData);
|
||||||
return new AdvancementsPacket.AdvancementMapping(getIdentifier(), adv);
|
return new AdvancementsPacket.AdvancementMapping(getIdentifier(), adv);
|
||||||
|
@ -65,7 +65,6 @@ public final class NotificationCenter {
|
|||||||
new AdvancementsPacket.CriterionProgress(System.currentTimeMillis()));
|
new AdvancementsPacket.CriterionProgress(System.currentTimeMillis()));
|
||||||
|
|
||||||
final var advancement = new AdvancementsPacket.Advancement(null, displayData,
|
final var advancement = new AdvancementsPacket.Advancement(null, displayData,
|
||||||
List.of(criteria.criterionIdentifier()),
|
|
||||||
List.of(new AdvancementsPacket.Requirement(List.of(criteria.criterionIdentifier()))),
|
List.of(new AdvancementsPacket.Requirement(List.of(criteria.criterionIdentifier()))),
|
||||||
false);
|
false);
|
||||||
|
|
||||||
|
@ -104,27 +104,21 @@ public record AdvancementsPacket(boolean reset, @NotNull List<AdvancementMapping
|
|||||||
}
|
}
|
||||||
|
|
||||||
public record Advancement(@Nullable String parentIdentifier, @Nullable DisplayData displayData,
|
public record Advancement(@Nullable String parentIdentifier, @Nullable DisplayData displayData,
|
||||||
@NotNull List<String> criteria,
|
|
||||||
@NotNull List<Requirement> requirements,
|
@NotNull List<Requirement> requirements,
|
||||||
boolean sendTelemetryData) implements NetworkBuffer.Writer, ComponentHolder<Advancement> {
|
boolean sendTelemetryData) implements NetworkBuffer.Writer, ComponentHolder<Advancement> {
|
||||||
public Advancement {
|
public Advancement {
|
||||||
criteria = List.copyOf(criteria);
|
|
||||||
requirements = List.copyOf(requirements);
|
requirements = List.copyOf(requirements);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Advancement(@NotNull NetworkBuffer reader) {
|
public Advancement(@NotNull NetworkBuffer reader) {
|
||||||
this(reader.read(BOOLEAN) ? reader.read(STRING) : null,
|
this(reader.readOptional(STRING), reader.readOptional(DisplayData::new),
|
||||||
reader.read(BOOLEAN) ? new DisplayData(reader) : null,
|
reader.readCollection(Requirement::new), reader.read(BOOLEAN));
|
||||||
reader.readCollection(STRING),
|
|
||||||
reader.readCollection(Requirement::new),
|
|
||||||
reader.read(BOOLEAN));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void write(@NotNull NetworkBuffer writer) {
|
public void write(@NotNull NetworkBuffer writer) {
|
||||||
writer.writeOptional(STRING, parentIdentifier);
|
writer.writeOptional(STRING, parentIdentifier);
|
||||||
writer.writeOptional(displayData);
|
writer.writeOptional(displayData);
|
||||||
writer.writeCollection(STRING, criteria);
|
|
||||||
writer.writeCollection(requirements);
|
writer.writeCollection(requirements);
|
||||||
writer.write(BOOLEAN, sendTelemetryData);
|
writer.write(BOOLEAN, sendTelemetryData);
|
||||||
}
|
}
|
||||||
@ -136,7 +130,7 @@ public record AdvancementsPacket(boolean reset, @NotNull List<AdvancementMapping
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public @NotNull Advancement copyWithOperator(@NotNull UnaryOperator<Component> operator) {
|
public @NotNull Advancement copyWithOperator(@NotNull UnaryOperator<Component> operator) {
|
||||||
return this.displayData == null ? this : new Advancement(this.parentIdentifier, this.displayData.copyWithOperator(operator), this.criteria, this.requirements, this.sendTelemetryData);
|
return this.displayData == null ? this : new Advancement(this.parentIdentifier, this.displayData.copyWithOperator(operator), this.requirements, this.sendTelemetryData);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -190,7 +184,7 @@ public record AdvancementsPacket(boolean reset, @NotNull List<AdvancementMapping
|
|||||||
writer.write(COMPONENT, title);
|
writer.write(COMPONENT, title);
|
||||||
writer.write(COMPONENT, description);
|
writer.write(COMPONENT, description);
|
||||||
writer.write(ITEM, icon);
|
writer.write(ITEM, icon);
|
||||||
writer.write(VAR_INT, frameType.ordinal());
|
writer.writeEnum(FrameType.class, frameType);
|
||||||
writer.write(INT, flags);
|
writer.write(INT, flags);
|
||||||
if ((flags & 0x1) != 0) {
|
if ((flags & 0x1) != 0) {
|
||||||
assert backgroundTexture != null;
|
assert backgroundTexture != null;
|
||||||
|
Loading…
Reference in New Issue
Block a user