diff --git a/src/main/java/emu/grasscutter/game/entity/gadget/platform/BaseRoute.java b/src/main/java/emu/grasscutter/game/entity/gadget/platform/BaseRoute.java index 74428294b..e6949f979 100644 --- a/src/main/java/emu/grasscutter/game/entity/gadget/platform/BaseRoute.java +++ b/src/main/java/emu/grasscutter/game/entity/gadget/platform/BaseRoute.java @@ -63,7 +63,25 @@ public abstract class BaseRoute { private MathQuaternion.Builder rotAsMathQuaternion() { val result = MathQuaternion.newBuilder(); if (startRot != null) { - result.setX(startRot.getX()).setY(startRot.getY()).setZ(startRot.getZ()); + // https://en.wikipedia.org/wiki/Conversion_between_quaternions_and_Euler_angles + // "MY BRAIN!" - Nazrin + val roll = Math.toRadians(startRot.getX()); + val pitch = Math.toRadians(startRot.getY()); + val yaw = Math.toRadians(startRot.getZ()); + + val cr = (float)Math.cos(roll * 0.5); + val sr = (float)Math.sin(roll * 0.5); + val cp = (float)Math.cos(pitch * 0.5); + val sp = (float)Math.sin(pitch * 0.5); + val cy = (float)Math.cos(yaw * 0.5); + val sy = (float)Math.sin(yaw * 0.5); + + result.setW(cr * cp * cy + sr * sp * sy); + result.setX(sr * cp * cy - cr * sp * sy); + result.setY(cr * sp * cy + sr * cp * sy); + result.setZ(cr * cp * sy - sr * sp * cy); + } else { + result.setW(1f); } return result; }