java.lang.Object
com.github.stephengold.joltjni.Quat
- All Implemented Interfaces:
- QuatArg
A math object used to represent rotations and orientations in 3-dimensional
 space, without risk of gimbal lock. Each quaternion has 4 single-precision
 components: 3 imaginary ones (X, Y, and Z) and a real one (W).
 
Mathematically speaking, quaternions are an extension of complex numbers.
- 
Constructor SummaryConstructorsConstructorDescriptionQuat()Instantiate an identity quaternion (0,0,0,1).Quat(float[] array) Instantiate a quaternion from the specified array.Quat(float x, float y, float z, float w) Instantiate a quaternion with specified components.Instantiate a copy of the argument.Instantiate a quaternion based on aVec3Arg.Quat(FloatBuffer buffer) Instantiate from a buffer.
- 
Method SummaryModifier and TypeMethodDescriptionReturn the conjugate.voidcopyTo(FloatBuffer storeFloats) Write all 4 components to the start of the specified buffer.floatgetW()Return the real (W) component in single precision.floatgetX()Return the first imaginary (X) component in single precision.floatgetY()Return the 2nd imaginary (Y) component in single precision.floatgetZ()Return the 3rd imaginary (Z) component in single precision.booleanisFinite()Test whether the quaternion contains infinities or NaNs.booleanTest whether the quaternion is normalized to within a tolerance of 10^-5.booleanisNormalized(float tolerance) Test whether the quaternion is normalized to within the specified tolerance.booleanTest whether the quaternion represents an identity rotation.booleanisZero()Test whether the quaternion is zero.floatlength()Return the length.floatlengthSq()Return the squared length.voidSet the current quaternion to identity.Generate a normalized quaternion that represents the same rotation.voidput(FloatBuffer storeBuffer) Write all 4 components to the specified buffer in XYZW order and advance the buffer's position by 4.Apply the rotation to (1,0,0).Apply the rotation to (0,1,0).Apply the rotation to (0,0,1).voidset(float[] array) Set all 4 components from the specified array.voidset(float x, float y, float z, float w) Set all 4 components to specified values.voidCopy all 4 components from the argument.voidset(FloatBuffer buffer) Set all 4 components from the specified buffer.static QuatsEulerAngles(float x, float y, float z) Create a rotation quaternion from the specified Tait-Bryan angles, applying the rotations in x-y-z extrinsic order or z-y'-x" intrinsic order.static QuatsEulerAngles(Vec3Arg angles) Create a rotation quaternion from the specified Tait-Bryan angles, applying the rotations in x-y-z extrinsic order or z-y'-x" intrinsic order.static QuatCreate a rotation quaternion that rotatesfromtoto.static QuatCreate an identity quaternion (0,0,0,1).static QuatsRandom(RandomNumberEngine engine) Generate a pseudo-random unit quaternion.static QuatCreate a rotation quaternion from a normalized rotation axis.toString()Return a string representation of the quaternion, which is unaffected.
- 
Constructor Details- 
Quatpublic Quat()Instantiate an identity quaternion (0,0,0,1).
- 
Quatpublic Quat(float x, float y, float z, float w) Instantiate a quaternion with specified components.- Parameters:
- x- the desired X component
- y- the desired Y component
- z- the desired Z component
- w- the desired W component
 
- 
Quatpublic Quat(float[] array) Instantiate a quaternion from the specified array.- Parameters:
- array- the desired component values (in XYZW order, not null, length≥4, unaffected)
 
- 
QuatInstantiate from a buffer.- Parameters:
- buffer- the desired component values (not null, unaffected, capacity≥4)
 
- 
QuatInstantiate a copy of the argument.- Parameters:
- original- the quaternion to copy (not null, unaffected)
 
- 
QuatInstantiate a quaternion based on aVec3Arg.- Parameters:
- v- the desired XYZ components
- w- the desired W component
 
 
- 
- 
Method Details- 
loadIdentitypublic void loadIdentity()Set the current quaternion to identity.
- 
setpublic void set(float x, float y, float z, float w) Set all 4 components to specified values.- Parameters:
- x- the desired X component
- y- the desired Y component
- z- the desired Z component
- w- the desired W component
 
- 
setpublic void set(float[] array) Set all 4 components from the specified array.- Parameters:
- array- the desired component values (in XYZW order, not null, length≥4, unaffected)
 
- 
setSet all 4 components from the specified buffer.- Parameters:
- buffer- the desired component values (not null, length≥4, unaffected)
 
- 
setCopy all 4 components from the argument.- Parameters:
- source- the quaternion to copy (not null, unaffected)
 
- 
sEulerAnglesCreate a rotation quaternion from the specified Tait-Bryan angles, applying the rotations in x-y-z extrinsic order or z-y'-x" intrinsic order.- Parameters:
- x- the desired rotation around the X axis (in radians)
- y- the desired rotation around the Y axis (in radians)
- z- the desired rotation around the Z axis (in radians)
- Returns:
- a new quaternion
 
- 
sEulerAnglesCreate a rotation quaternion from the specified Tait-Bryan angles, applying the rotations in x-y-z extrinsic order or z-y'-x" intrinsic order.- Parameters:
- angles- the desired rotation around each axis (in radians, not null, unaffected)
- Returns:
- a new quaternion
 
- 
sFromToCreate a rotation quaternion that rotatesfromtoto.- Parameters:
- from- the first direction vector (not null, unaffected)
- to- the 2nd direction vector (not null, unaffected)
- Returns:
- a new quaternion
 
- 
sIdentityCreate an identity quaternion (0,0,0,1).- Returns:
- a new quaternion
 
- 
sRandomGenerate a pseudo-random unit quaternion.- Parameters:
- engine- the generator to use (not null)
- Returns:
- a new unit quaternion
 
- 
sRotationCreate a rotation quaternion from a normalized rotation axis.- Parameters:
- axis- the desired rotation axis (not null, normalized)
- angle- the desired rotation angle (in radians)
- Returns:
- a new quaternion
 
- 
copyToWrite all 4 components to the start of the specified buffer. The current object is unaffected.
- 
conjugatedReturn the conjugate. The current object is unaffected.- Specified by:
- conjugatedin interface- QuatArg
- Returns:
- a new object
 
- 
getWpublic float getW()Return the real (W) component in single precision. The quaternion is unaffected.
- 
getXpublic float getX()Return the first imaginary (X) component in single precision. The quaternion is unaffected.
- 
getYpublic float getY()Return the 2nd imaginary (Y) component in single precision. The quaternion is unaffected.
- 
getZpublic float getZ()Return the 3rd imaginary (Z) component in single precision. The quaternion is unaffected.
- 
isFinitepublic boolean isFinite()Test whether the quaternion contains infinities or NaNs. The quaternion is unaffected.
- 
isNormalizedpublic boolean isNormalized()Test whether the quaternion is normalized to within a tolerance of 10^-5. The quaternion is unaffected.- Specified by:
- isNormalizedin interface- QuatArg
- Returns:
- trueif normalized, otherwise- false
 
- 
isNormalizedpublic boolean isNormalized(float tolerance) Test whether the quaternion is normalized to within the specified tolerance. The quaternion is unaffected.- Specified by:
- isNormalizedin interface- QuatArg
- Parameters:
- tolerance- the desired tolerance (default=1e-5)
- Returns:
- trueif normalized, otherwise- false
 
- 
isRotationIdentitypublic boolean isRotationIdentity()Test whether the quaternion represents an identity rotation. The quaternion is unaffected.- Specified by:
- isRotationIdentityin interface- QuatArg
- Returns:
- trueif the real component is a non-zero number and the imaginary components are all zero, otherwise- false
 
- 
isZeropublic boolean isZero()Test whether the quaternion is zero. The quaternion is unaffected.
- 
lengthpublic float length()Return the length. The quaternion is unaffected.
- 
lengthSqpublic float lengthSq()Return the squared length. The quaternion is unaffected.
- 
normalizedGenerate a normalized quaternion that represents the same rotation. The current object is unaffected.- Specified by:
- normalizedin interface- QuatArg
- Returns:
- a new quaternion
 
- 
putWrite all 4 components to the specified buffer in XYZW order and advance the buffer's position by 4. The quaternion is unaffected.
- 
rotateAxisXApply the rotation to (1,0,0). The quaternion is assumed to be normalized and is unaffected.- Specified by:
- rotateAxisXin interface- QuatArg
- Returns:
- a new vector
 
- 
rotateAxisYApply the rotation to (0,1,0). The quaternion is assumed to be normalized and is unaffected.- Specified by:
- rotateAxisYin interface- QuatArg
- Returns:
- a new vector
 
- 
rotateAxisZApply the rotation to (0,0,1). The quaternion is assumed to be normalized and is unaffected.- Specified by:
- rotateAxisZin interface- QuatArg
- Returns:
- a new vector
 
- 
toStringReturn a string representation of the quaternion, which is unaffected. For example, an identity quaternion is represented by:Quat(0.0 0.0 0.0 1.0) 
 
-