use of org.lanternpowered.server.network.vanilla.message.type.play.MessagePlayOutEntityRelativeMove in project LanternServer by LanternPowered.
the class EntityProtocol method update.
@Override
protected void update(EntityProtocolUpdateContext context) {
final Vector3d rot = this.entity.getRotation();
final Vector3d headRot = this.entity instanceof Living ? ((Living) this.entity).getHeadRotation() : null;
final Vector3d pos = this.entity.getPosition();
final double x = pos.getX();
final double y = pos.getY();
final double z = pos.getZ();
final long xu = (long) (x * 4096);
final long yu = (long) (y * 4096);
final long zu = (long) (z * 4096);
final byte yaw = wrapAngle(rot.getY());
// All living entities have a head rotation and changing the pitch
// would only affect the head pitch.
final byte pitch = wrapAngle((headRot != null ? headRot : rot).getX());
boolean dirtyPos = xu != this.lastX || yu != this.lastY || zu != this.lastZ;
boolean dirtyRot = yaw != this.lastYaw || pitch != this.lastPitch;
// TODO: On ground state
final int entityId = getRootEntityId();
final boolean passenger = this.entity.getVehicle().isPresent();
if (dirtyRot) {
this.lastYaw = yaw;
this.lastPitch = pitch;
}
if (dirtyPos) {
final long dxu = xu - this.lastX;
final long dyu = yu - this.lastY;
final long dzu = zu - this.lastZ;
this.lastX = xu;
this.lastY = yu;
this.lastZ = zu;
// rule the world.
if (!passenger) {
if (Math.abs(dxu) <= Short.MAX_VALUE && Math.abs(dyu) <= Short.MAX_VALUE && Math.abs(dzu) <= Short.MAX_VALUE) {
if (dirtyRot) {
context.sendToAllExceptSelf(new MessagePlayOutEntityLookAndRelativeMove(entityId, (int) dxu, (int) dyu, (int) dzu, yaw, pitch, this.entity.isOnGround()));
// The rotation is already send
dirtyRot = false;
} else {
context.sendToAllExceptSelf(new MessagePlayOutEntityRelativeMove(entityId, (int) dxu, (int) dyu, (int) dzu, this.entity.isOnGround()));
}
} else {
context.sendToAllExceptSelf(new MessagePlayOutEntityTeleport(entityId, x, y, z, yaw, pitch, this.entity.isOnGround()));
// The rotation is already send
dirtyRot = false;
}
}
}
if (dirtyRot) {
context.sendToAllExceptSelf(() -> new MessagePlayOutEntityLook(entityId, yaw, pitch, this.entity.isOnGround()));
} else if (!passenger) {
if (headRot != null) {
final byte headYaw = wrapAngle(headRot.getY());
if (headYaw != this.lastHeadYaw) {
context.sendToAllExceptSelf(() -> new MessagePlayOutEntityHeadLook(entityId, headYaw));
this.lastHeadYaw = headYaw;
}
}
}
final Vector3d velocity = this.entity.getVelocity();
final double vx = velocity.getX();
final double vy = velocity.getY();
final double vz = velocity.getZ();
if (vx != this.lastVelX || vy != this.lastVelY || vz != this.lastVelZ) {
context.sendToAll(() -> new MessagePlayOutEntityVelocity(entityId, vx, vy, vz));
this.lastVelX = vx;
this.lastVelY = vy;
this.lastVelZ = vz;
}
final ParameterList parameterList = context == EntityProtocolUpdateContext.empty() ? fillParameters(false, EmptyParameterList.INSTANCE) : fillParameters(false);
// There were parameters applied
if (!parameterList.isEmpty()) {
context.sendToAll(() -> new MessagePlayOutEntityMetadata(entityId, parameterList));
}
if (hasEquipment() && this.entity instanceof Carrier) {
final Inventory inventory = ((Carrier) this.entity).getInventory();
for (int i = 0; i < Holder.EQUIPMENT_TYPES.length; i++) {
final ItemStack itemStack = inventory.query(Holder.EQUIPMENT_QUERIES[i]).first().peek().orElse(null);
final ItemStack oldItemStack = this.lastEquipment.get(i);
if (!LanternItemStack.areSimilar(itemStack, oldItemStack)) {
this.lastEquipment.put(i, itemStack);
final int slotIndex = i;
context.sendToAllExceptSelf(() -> new MessagePlayOutEntityEquipment(getRootEntityId(), slotIndex, itemStack));
}
}
}
// TODO: Update attributes
}
Aggregations