mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-08 01:17:47 +01:00
Fixes cat color (variant) metadata, adds frog meta (#1833)
* Add frog & cat meta types * Rename Color -> Variant in CatMeta, use DyeColor
This commit is contained in:
parent
01ffec6614
commit
e160cbdecd
@ -107,7 +107,7 @@ record EntityTypeImpl(Registry.EntityEntry registry) implements EntityType {
|
||||
entry("minecraft:falling_block", FallingBlockMeta::new),
|
||||
entry("minecraft:firework_rocket", FireworkRocketMeta::new),
|
||||
entry("minecraft:fox", FoxMeta::new),
|
||||
entry("minecraft:frog", EntityMeta::new), // TODO dedicated metadata
|
||||
entry("minecraft:frog", FrogMeta::new),
|
||||
entry("minecraft:ghast", GhastMeta::new),
|
||||
entry("minecraft:giant", GiantMeta::new),
|
||||
entry("minecraft:glow_item_frame", GlowItemFrameMeta::new),
|
||||
|
@ -2,6 +2,8 @@ package net.minestom.server.entity;
|
||||
|
||||
import net.kyori.adventure.text.Component;
|
||||
import net.minestom.server.coordinate.Point;
|
||||
import net.minestom.server.entity.metadata.animal.FrogMeta;
|
||||
import net.minestom.server.entity.metadata.animal.tameable.CatMeta;
|
||||
import net.minestom.server.item.ItemStack;
|
||||
import net.minestom.server.network.NetworkBuffer;
|
||||
import net.minestom.server.network.packet.server.play.EntityMetaDataPacket;
|
||||
@ -95,6 +97,14 @@ public final class Metadata {
|
||||
return new MetadataImpl.EntryImpl<>(TYPE_POSE, value, NetworkBuffer.POSE);
|
||||
}
|
||||
|
||||
public static Entry<CatMeta.Variant> CatVariant(@NotNull CatMeta.Variant value) {
|
||||
return new MetadataImpl.EntryImpl<>(TYPE_CAT_VARIANT, value, NetworkBuffer.CAT_VARIANT);
|
||||
}
|
||||
|
||||
public static Entry<FrogMeta.Variant> FrogVariant(@NotNull FrogMeta.Variant value) {
|
||||
return new MetadataImpl.EntryImpl<>(TYPE_FROG_VARIANT, value, NetworkBuffer.FROG_VARIANT);
|
||||
}
|
||||
|
||||
public static final byte TYPE_BYTE = 0;
|
||||
public static final byte TYPE_VARINT = 1;
|
||||
public static final byte TYPE_FLOAT = 2;
|
||||
@ -114,6 +124,8 @@ public final class Metadata {
|
||||
public static final byte TYPE_VILLAGERDATA = 16;
|
||||
public static final byte TYPE_OPTVARINT = 17;
|
||||
public static final byte TYPE_POSE = 18;
|
||||
public static final byte TYPE_CAT_VARIANT = 19;
|
||||
public static final byte TYPE_FROG_VARIANT = 20;
|
||||
|
||||
private static final VarHandle NOTIFIED_CHANGES;
|
||||
|
||||
|
@ -0,0 +1,38 @@
|
||||
package net.minestom.server.entity.metadata.animal;
|
||||
|
||||
import net.minestom.server.entity.Entity;
|
||||
import net.minestom.server.entity.Metadata;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
|
||||
public class FrogMeta extends AnimalMeta {
|
||||
public static final byte OFFSET = AnimalMeta.MAX_OFFSET;
|
||||
public static final byte MAX_OFFSET = OFFSET + 2;
|
||||
|
||||
public FrogMeta(@NotNull Entity entity, @NotNull Metadata metadata) {
|
||||
super(entity, metadata);
|
||||
}
|
||||
|
||||
public Variant getVariant() {
|
||||
return super.metadata.getIndex(OFFSET, Variant.TEMPERATE);
|
||||
}
|
||||
|
||||
public void setVariant(@NotNull Variant value) {
|
||||
super.metadata.setIndex(OFFSET, Metadata.FrogVariant(value));
|
||||
}
|
||||
|
||||
public int getTongueTarget() {
|
||||
return super.metadata.getIndex(OFFSET + 1, 0);
|
||||
}
|
||||
|
||||
public void setTongueTarget(int value) {
|
||||
super.metadata.setIndex(OFFSET + 1, Metadata.OptVarInt(value));
|
||||
}
|
||||
|
||||
public enum Variant {
|
||||
TEMPERATE,
|
||||
WARM,
|
||||
COLD;
|
||||
|
||||
private final static FrogMeta.Variant[] VALUES = values();
|
||||
}
|
||||
}
|
@ -1,5 +1,6 @@
|
||||
package net.minestom.server.entity.metadata.animal.tameable;
|
||||
|
||||
import net.minestom.server.color.DyeColor;
|
||||
import net.minestom.server.entity.Entity;
|
||||
import net.minestom.server.entity.Metadata;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
@ -8,17 +9,19 @@ public class CatMeta extends TameableAnimalMeta {
|
||||
public static final byte OFFSET = TameableAnimalMeta.MAX_OFFSET;
|
||||
public static final byte MAX_OFFSET = OFFSET + 4;
|
||||
|
||||
private static final DyeColor[] DYE_VALUES = DyeColor.values();
|
||||
|
||||
public CatMeta(@NotNull Entity entity, @NotNull Metadata metadata) {
|
||||
super(entity, metadata);
|
||||
}
|
||||
|
||||
@NotNull
|
||||
public Color getColor() {
|
||||
return Color.VALUES[super.metadata.getIndex(OFFSET, 1)];
|
||||
public CatMeta.Variant getVariant() {
|
||||
return super.metadata.getIndex(OFFSET, Variant.BLACK);
|
||||
}
|
||||
|
||||
public void setColor(@NotNull Color value) {
|
||||
super.metadata.setIndex(OFFSET, Metadata.VarInt(value.ordinal()));
|
||||
public void setVariant(@NotNull CatMeta.Variant value) {
|
||||
super.metadata.setIndex(OFFSET, Metadata.CatVariant(value));
|
||||
}
|
||||
|
||||
public boolean isLying() {
|
||||
@ -37,15 +40,15 @@ public class CatMeta extends TameableAnimalMeta {
|
||||
super.metadata.setIndex(OFFSET + 2, Metadata.Boolean(value));
|
||||
}
|
||||
|
||||
public int getCollarColor() {
|
||||
return super.metadata.getIndex(OFFSET + 3, 14);
|
||||
public @NotNull DyeColor getCollarColor() {
|
||||
return DYE_VALUES[super.metadata.getIndex(OFFSET + 3, DyeColor.RED.ordinal())];
|
||||
}
|
||||
|
||||
public void setCollarColor(int value) {
|
||||
super.metadata.setIndex(OFFSET + 3, Metadata.VarInt(value));
|
||||
public void setCollarColor(@NotNull DyeColor value) {
|
||||
super.metadata.setIndex(OFFSET + 3, Metadata.VarInt(value.ordinal()));
|
||||
}
|
||||
|
||||
public enum Color {
|
||||
public enum Variant {
|
||||
TABBY,
|
||||
BLACK,
|
||||
RED,
|
||||
@ -58,7 +61,7 @@ public class CatMeta extends TameableAnimalMeta {
|
||||
JELLIE,
|
||||
ALL_BLACK;
|
||||
|
||||
private final static Color[] VALUES = values();
|
||||
private static final Variant[] VALUES = values();
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -3,6 +3,8 @@ package net.minestom.server.network;
|
||||
import net.kyori.adventure.text.Component;
|
||||
import net.minestom.server.coordinate.Point;
|
||||
import net.minestom.server.entity.Entity;
|
||||
import net.minestom.server.entity.metadata.animal.FrogMeta;
|
||||
import net.minestom.server.entity.metadata.animal.tameable.CatMeta;
|
||||
import net.minestom.server.item.ItemStack;
|
||||
import net.minestom.server.network.packet.server.play.data.DeathLocation;
|
||||
import net.minestom.server.utils.Direction;
|
||||
@ -59,6 +61,8 @@ public final class NetworkBuffer {
|
||||
public static final Type<Integer> OPT_VAR_INT = NetworkBufferTypes.OPT_VAR_INT;
|
||||
public static final Type<Entity.Pose> POSE = NetworkBufferTypes.POSE;
|
||||
public static final Type<DeathLocation> DEATH_LOCATION = NetworkBufferTypes.DEATH_LOCATION;
|
||||
public static final Type<CatMeta.Variant> CAT_VARIANT = NetworkBufferTypes.CAT_VARIANT;
|
||||
public static final Type<FrogMeta.Variant> FROG_VARIANT = NetworkBufferTypes.FROG_VARIANT;
|
||||
|
||||
ByteBuffer nioBuffer;
|
||||
final boolean resizable;
|
||||
|
@ -5,6 +5,8 @@ import net.kyori.adventure.text.serializer.gson.GsonComponentSerializer;
|
||||
import net.minestom.server.coordinate.Point;
|
||||
import net.minestom.server.coordinate.Vec;
|
||||
import net.minestom.server.entity.Entity;
|
||||
import net.minestom.server.entity.metadata.animal.FrogMeta;
|
||||
import net.minestom.server.entity.metadata.animal.tameable.CatMeta;
|
||||
import net.minestom.server.item.ItemStack;
|
||||
import net.minestom.server.item.Material;
|
||||
import net.minestom.server.network.packet.server.play.data.DeathLocation;
|
||||
@ -523,6 +525,24 @@ final class NetworkBufferTypes {
|
||||
}
|
||||
return null;
|
||||
});
|
||||
static final TypeImpl<CatMeta.Variant> CAT_VARIANT = new TypeImpl<>(CatMeta.Variant.class,
|
||||
(buffer, value) -> {
|
||||
buffer.write(VAR_INT, value.ordinal());
|
||||
return -1;
|
||||
},
|
||||
buffer -> {
|
||||
final int ordinal = buffer.read(VAR_INT);
|
||||
return CatMeta.Variant.values()[ordinal];
|
||||
});
|
||||
static final TypeImpl<FrogMeta.Variant> FROG_VARIANT = new TypeImpl<>(FrogMeta.Variant.class,
|
||||
(buffer, value) -> {
|
||||
buffer.write(VAR_INT, value.ordinal());
|
||||
return -1;
|
||||
},
|
||||
buffer -> {
|
||||
final int ordinal = buffer.read(VAR_INT);
|
||||
return FrogMeta.Variant.values()[ordinal];
|
||||
});
|
||||
|
||||
record TypeImpl<T>(@NotNull Class<T> type,
|
||||
@NotNull TypeWriter<T> writer,
|
||||
|
Loading…
Reference in New Issue
Block a user