From 9cd39c5f9a2da83f87458c5c58fbfe62116ae7d0 Mon Sep 17 00:00:00 2001 From: doctor4t Date: Thu, 21 Nov 2024 13:30:55 +0100 Subject: [PATCH] Fix confetti rotations being fucked --- .../client/particle/ConfettiParticle.java | 23 +++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/src/main/java/ladysnake/blast/client/particle/ConfettiParticle.java b/src/main/java/ladysnake/blast/client/particle/ConfettiParticle.java index 40af7fa..0977245 100644 --- a/src/main/java/ladysnake/blast/client/particle/ConfettiParticle.java +++ b/src/main/java/ladysnake/blast/client/particle/ConfettiParticle.java @@ -77,7 +77,7 @@ public void buildGeometry(VertexConsumer vertexConsumer, Camera camera, float ti for (int k = 0; k < 4; ++k) { Vector3f Vec3f2 = Vec3fs[k]; - Vec3f2.rotate(new Quaternionf(rotationX, rotationY, rotationZ, 1)); + Vec3f2.rotate(eulerToQuaternion(rotationX, rotationY, rotationZ)); Vec3f2.normalize(siZe); Vec3f2.add(x, y, z); } @@ -87,7 +87,7 @@ public void buildGeometry(VertexConsumer vertexConsumer, Camera camera, float ti for (int k = 0; k < 4; ++k) { Vector3f Vec3f2 = Vec3fs[k]; - Vec3f2.rotate(new Quaternionf(rotationX, rotationY, rotationZ, 1)); + Vec3f2.rotate(eulerToQuaternion(rotationX, rotationY, rotationZ)); Vec3f2.normalize(siZe); Vec3f2.add(x, y + this.groundOffset, z); } @@ -109,6 +109,25 @@ public void buildGeometry(VertexConsumer vertexConsumer, Camera camera, float ti vertexConsumer.vertex(Vec3fs[1].x(), Vec3fs[1].y(), Vec3fs[1].z()).texture(minU, maxV).color(red, green, blue, alpha).light(light); } + public Quaternionf eulerToQuaternion(float x, float y, float z) { + x *= ((float) Math.PI / 180F); + y *= ((float) Math.PI / 180F); + z *= ((float) Math.PI / 180F); + + float f = MathHelper.sin(0.5F * x); + float g = MathHelper.cos(0.5F * x); + float h = MathHelper.sin(0.5F * y); + float i = MathHelper.cos(0.5F * y); + float j = MathHelper.sin(0.5F * z); + float k = MathHelper.cos(0.5F * z); + x = f * i * k + g * h * j; + y = g * h * k - f * i * j; + z = f * h * k + g * i * j; + float w = g * i * k - f * h * j; + + return new Quaternionf(x, y, z, w); + } + @Override public void tick() { this.prevPosX = this.x;