From 6d134a6d47c9e8fd3ea9f8316def857caa4395fc Mon Sep 17 00:00:00 2001 From: AoElite <20812471+AoElite@users.noreply.github.com> Date: Wed, 24 Jan 2024 21:28:04 -0500 Subject: [PATCH] add initial camel support --- .../data/packetentity/PacketEntityCamel.java | 17 +++++++++++++++++ .../utils/latency/CompensatedEntities.java | 16 +++++++++++++++- 2 files changed, 32 insertions(+), 1 deletion(-) create mode 100644 src/main/java/ac/grim/grimac/utils/data/packetentity/PacketEntityCamel.java diff --git a/src/main/java/ac/grim/grimac/utils/data/packetentity/PacketEntityCamel.java b/src/main/java/ac/grim/grimac/utils/data/packetentity/PacketEntityCamel.java new file mode 100644 index 0000000000..504c11f965 --- /dev/null +++ b/src/main/java/ac/grim/grimac/utils/data/packetentity/PacketEntityCamel.java @@ -0,0 +1,17 @@ +package ac.grim.grimac.utils.data.packetentity; + +import ac.grim.grimac.player.GrimPlayer; +import com.github.retrooper.packetevents.protocol.entity.type.EntityType; + +public class PacketEntityCamel extends PacketEntityHorse { + + public boolean dashing = false; //TODO: handle camel dashing + + public PacketEntityCamel(GrimPlayer player, EntityType type, double x, double y, double z, float xRot) { + super(player, type, x, y, z, xRot); + + jumpStrength = 0.42F; + movementSpeedAttribute = 0.09f; + } + +} diff --git a/src/main/java/ac/grim/grimac/utils/latency/CompensatedEntities.java b/src/main/java/ac/grim/grimac/utils/latency/CompensatedEntities.java index cf82b77eae..0610e692b7 100644 --- a/src/main/java/ac/grim/grimac/utils/latency/CompensatedEntities.java +++ b/src/main/java/ac/grim/grimac/utils/latency/CompensatedEntities.java @@ -185,7 +185,9 @@ public void addEntity(int entityID, EntityType entityType, Vector3d position, fl PacketEntity packetEntity; - if (EntityTypes.isTypeInstanceOf(entityType, EntityTypes.ABSTRACT_HORSE)) { + if (EntityTypes.CAMEL.equals(entityType)) { + packetEntity = new PacketEntityCamel(player, entityType, position.getX(), position.getY(), position.getZ(), xRot); + } else if (EntityTypes.isTypeInstanceOf(entityType, EntityTypes.ABSTRACT_HORSE)) { packetEntity = new PacketEntityHorse(player, entityType, position.getX(), position.getY(), position.getZ(), xRot); } else if (entityType == EntityTypes.SLIME || entityType == EntityTypes.MAGMA_CUBE || entityType == EntityTypes.PHANTOM) { packetEntity = new PacketEntitySizeable(player, entityType, position.getX(), position.getY(), position.getZ()); @@ -388,6 +390,18 @@ public void updateEntityMetadata(int entityID, List watchableObjects ((PacketEntityHorse) entity).hasSaddle = (info & 0x04) != 0; ((PacketEntityHorse) entity).isRearing = (info & 0x20) != 0; } + + // track camel dashing + if (PacketEvents.getAPI().getServerManager().getVersion().isNewerThanOrEquals(ServerVersion.V_1_20)) { + if (entity instanceof PacketEntityCamel) { + PacketEntityCamel camel = (PacketEntityCamel) entity; + EntityData entityData = WatchableIndexUtil.getIndex(watchableObjects, 18); + if (entityData != null) { + camel.dashing = (boolean) entityData.getValue(); + } + } + } + } else { EntityData horseByte = WatchableIndexUtil.getIndex(watchableObjects, 16); if (horseByte != null) {