Merge pull request #365 from Kebab11noel/coordinatetype-cleanup

Cleanup CoordinateType
This commit is contained in:
TheMode 2021-07-11 01:11:04 +02:00 committed by GitHub
commit 6c9cef35c0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -103,9 +103,6 @@ public final class RelativeVec {
public enum CoordinateType { public enum CoordinateType {
RELATIVE((relative, origin, relativeX, relativeY, relativeZ) -> { RELATIVE((relative, origin, relativeX, relativeY, relativeZ) -> {
if (!relativeX && !relativeY && !relativeZ) {
return relative;
}
final var absolute = Objects.requireNonNullElse(origin, Vec.ZERO); final var absolute = Objects.requireNonNullElse(origin, Vec.ZERO);
final double x = relative.x() + (relativeX ? absolute.x() : 0); final double x = relative.x() + (relativeX ? absolute.x() : 0);
final double y = relative.y() + (relativeY ? absolute.y() : 0); final double y = relative.y() + (relativeY ? absolute.y() : 0);
@ -113,19 +110,12 @@ public final class RelativeVec {
return new Vec(x, y, z); return new Vec(x, y, z);
}), }),
LOCAL((local, origin, relativeX, relativeY, relativeZ) -> { LOCAL((local, origin, relativeX, relativeY, relativeZ) -> {
final double double5 = Math.cos(Math.toRadians(origin.yaw() + 90.0f)); final Vec vec1 = new Vec(Math.cos(Math.toRadians(origin.yaw() + 90.0f)), 0, Math.sin(Math.toRadians(origin.yaw() + 90.0f)));
final double double6 = Math.sin(Math.toRadians(origin.yaw() + 90.0f)); final Vec a = vec1.mul(Math.cos(Math.toRadians(-origin.pitch()))).withY(Math.sin(Math.toRadians(-origin.pitch())));
final double double7 = Math.cos(Math.toRadians(-origin.pitch())); final Vec b = vec1.mul(Math.cos(Math.toRadians(-origin.pitch() + 90.0f))).withY(Math.sin(Math.toRadians(-origin.pitch() + 90.0f)));
final double double8 = Math.sin(Math.toRadians(-origin.pitch())); final Vec c = a.cross(b).neg();
final double double9 = Math.cos(Math.toRadians(-origin.pitch() + 90.0f)); final Vec relativePos = a.mul(local.z()).add(b.mul(local.y())).add(c.mul(local.x()));
final double double10 = Math.sin(Math.toRadians(-origin.pitch() + 90.0f)); return origin.add(relativePos).asVec();
final Vec dna11 = new Vec(double5 * double7, double8, double6 * double7);
final Vec dna12 = new Vec(double5 * double9, double10, double6 * double9);
final Vec dna13 = dna11.cross(dna12).neg();
final double double14 = dna11.x() * local.z() + dna12.x() * local.y() + dna13.x() * local.x();
final double double16 = dna11.y() * local.z() + dna12.y() * local.y() + dna13.y() * local.x();
final double double18 = dna11.z() * local.z() + dna12.z() * local.y() + dna13.z() * local.x();
return new Vec(double14 + origin.x(), double16 + origin.y(), double18 + origin.z());
}), }),
ABSOLUTE(((vec, origin, relativeX1, relativeY1, relativeZ1) -> vec)); ABSOLUTE(((vec, origin, relativeX1, relativeY1, relativeZ1) -> vec));