Package net.risingworld.api.utils
Class Vector4f
java.lang.Object
net.risingworld.api.utils.Vector4f
- All Implemented Interfaces:
- Serializable
A Vector which holds four float values: X, Y, Z and W
It can be used to represent a four dimensional value.
It can be used to represent a four dimensional value.
- See Also:
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final Vector4fA vector with values 1, 1, 1, 1static final Vector4fA unit vector along the W axisstatic final Vector4fA unit vector along the X axisstatic final Vector4fA unit vector along the Y axisstatic final Vector4fA unit vector along the Z axisfloatThe W value of this vectorfloatThe X value of this vectorfloatThe Y value of this vectorfloatThe Z value of this vectorstatic final Vector4fA vector with values 0, 0, 0, 0
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionadd(float addX, float addY, float addZ, float addW) Creates a new vector with the same values of this vector and adds the provided values.Creates a new vector with the same values of this vector and adds the values of the provided vector.addLocal(float addX, float addY, float addZ, float addW) Adds the provided values to the values of this vector.Adds the values of the provided vector to the values of this vector.floatangleBetween(Vector4f other) Gets the angle between this vector and another vector.
 Please note: Both vectors need to be unit vectors (normalized).copy()Creates a copy of this Vector.floatdistance(float x, float y, float z, float w) Gets the distance between this vector and the provided coordinates.floatGets the distance between this vector and another vector.floatdistanceSquared(float x, float y, float z, float w) Gets the squared distance between this vector and the provided coordinates.floatdistanceSquared(Vector4f other) Gets the squared distance between this vector and another Vector4f.Creates a new vector with the same values of this vector and divides the values of the provided vector.divideLocal(float scalar) divideLocal(Vector4f other) floatdot(float x, float y, float z, float w) Gets the dot product of this vector with the provided coordinates.floatGets the dot product of this vector with the provided vector.booleanequals(float x, float y, float z, float w) booleanGets whether or not this vector is equal to another object.floatgetW()Returns the w value of this vector.floatgetX()Returns the x value of this vector.floatgetY()Returns the y value of this vector.floatgetZ()Returns the z value of this vector.inthashCode()Gets a unique* hash code for this vector, based on its values.interpolateLocal(Vector4f finalVector, float mu) Interpolates this vector to the provided final vector, e.g if this vector is (0, 5, 10, 0), and the final vector is (-10, 0, 10, 0), the result (by using a mu-value of 0.5f) would be (-5, 2.5f, 10, 0)booleanChecks if this vector is a unit vector.floatlength()Gets the length of this vector.floatGets the squared length of this vector.mult(float scalar) Creates a new vector with the same values of this vector and multiplies them with the provided scalar.mult(float multX, float multY, float multZ, float multW) Creates a new vector with the same values of this vector and multiplies the provided values.Creates a new vector with the same values of this vector and multiplies the values of the provided vector.multLocal(float scalar) Multiplies the values of this vector with the provided scalar.multLocal(float multX, float multY, float multZ, float multW) Multiplies the values of this vector with the provided values.Multiplies the values of this vector with the values of the provided vector.negate()Creates a new vector which contains negated values of this vector.Negates all values of this vector.Normalizes this vector (i.e turn it into a unit vector).set(float x, float y, float z, float w) Sets the x, y, z and w values of this vector to the provided values.Sets the x, y, z and w values of this vector to the values of the provided vector.setW(float w) Sets the w value of this vector.setX(float x) Sets the x value of this vector.setY(float y) Sets the y value of this vector.setZ(float z) Sets the z value of this vector.subtract(float subtractX, float subtractY, float subtractZ, float subtractW) Creates a new vector with the same values of this vector and subtracts the provided values.Creates a new vector with the same values of this vector and subtracts the values of the provided vector.subtractLocal(float subtractX, float subtractY, float subtractZ, float subtractW) Subtracts the provided values from the values of this vector.subtractLocal(Vector4f other) Subtracts the values of the provided vector from the values of this vector.toString()Gets a String representation of this vector, for example(1.0, 4.2, 0.0, -10.0)zero()Sets all values to 0 (same setset(0, 0, 0, 0);).
- 
Field Details- 
ZEROA vector with values 0, 0, 0, 0
- 
ONEA vector with values 1, 1, 1, 1
- 
UNIT_XA unit vector along the X axis
- 
UNIT_YA unit vector along the Y axis
- 
UNIT_ZA unit vector along the Z axis
- 
UNIT_WA unit vector along the W axis
- 
xpublic float xThe X value of this vector
- 
ypublic float yThe Y value of this vector
- 
zpublic float zThe Z value of this vector
- 
wpublic float wThe W value of this vector
 
- 
- 
Constructor Details- 
Vector4fpublic Vector4f()Creates a new Vector4f with default values 0, 0, 0, 0.
- 
Vector4fpublic Vector4f(float x, float y, float z, float w) Creates a new Vector4f with the provided values.- Parameters:
- x- the x value of the vector.
- y- the y value of the vector.
- z- the z value of the vector.
- w- the w value of the vector.
 
- 
Vector4fCreates a new Vector4f and copies the X, Y, Z and W values from the provided vector.- Parameters:
- copy- the Vector4f to copy.
 
 
- 
- 
Method Details- 
copyCreates a copy of this Vector.- Returns:
- a new instance with the same values of this Vector.
 
- 
setSets the x, y, z and w values of this vector to the values of the provided vector.- Parameters:
- vector- the Vector4f to copy.
- Returns:
- this vector.
 
- 
setSets the x, y, z and w values of this vector to the provided values.- Parameters:
- x- the x value.
- y- the y value.
- z- the z value.
- w- the w value.
- Returns:
- this vector.
 
- 
setXSets the x value of this vector.- Parameters:
- x- the new x value.
- Returns:
- this vector.
 
- 
setYSets the y value of this vector.- Parameters:
- y- the new y value.
- Returns:
- this vector.
 
- 
setZSets the z value of this vector.- Parameters:
- z- the new z value.
- Returns:
- this vector.
 
- 
setWSets the w value of this vector.- Parameters:
- w- the new w value.
- Returns:
- this vector.
 
- 
getXpublic float getX()Returns the x value of this vector.- Returns:
- the current x value.
 
- 
getYpublic float getY()Returns the y value of this vector.- Returns:
- the current y value.
 
- 
getZpublic float getZ()Returns the z value of this vector.- Returns:
- the current z value.
 
- 
getWpublic float getW()Returns the w value of this vector.- Returns:
- the current w value.
 
- 
dotGets the dot product of this vector with the provided vector.- Parameters:
- other- the vector to calculate the dot product with.
- Returns:
- the resulting dot product.
 
- 
dotpublic float dot(float x, float y, float z, float w) Gets the dot product of this vector with the provided coordinates.- Parameters:
- x- the x coordinate.
- y- the y coordinate.
- z- the z coordinate.
- w- the w coordinate.
- Returns:
- the resulting dot product.
 
- 
lengthpublic float length()Gets the length of this vector.- Returns:
- the length of this vector.
- See Also:
 
- 
lengthSquaredpublic float lengthSquared()Gets the squared length of this vector. Use this function to avoid calculating the squareroot.- Returns:
- the squared length of this vector.
- See Also:
 
- 
distanceGets the distance between this vector and another vector.- Parameters:
- other- the other vector.
- Returns:
- the distance between this vector and another vector.
- See Also:
 
- 
distancepublic float distance(float x, float y, float z, float w) Gets the distance between this vector and the provided coordinates.- Parameters:
- x- the other x coordinate.
- y- the other y coordinate.
- z- the other z coordinate.
- w- the other w coordinate.
- Returns:
- the distance between this vector and the provided coordinates.
- See Also:
 
- 
distanceSquaredGets the squared distance between this vector and another Vector4f. Use this function to avoid calculating the squareroot.- Parameters:
- other- the other Vector4f.
- Returns:
- the squared distance between this vector and the provided Vector4f.
 
- 
distanceSquaredpublic float distanceSquared(float x, float y, float z, float w) Gets the squared distance between this vector and the provided coordinates. Use this function to avoid calculating the squareroot.- Parameters:
- x- the other x coordinate.
- y- the other y coordinate.
- z- the other z coordinate.
- w- the other w coordinate.
- Returns:
- the squared distance between this vector and the provided coordinates.
 
- 
addCreates a new vector with the same values of this vector and adds the values of the provided vector. Same asnew Vector4f(this).addLocal(other);- Parameters:
- other- the vector to add.
- Returns:
- the newly created vector.
 
- 
addCreates a new vector with the same values of this vector and adds the provided values. Same asnew Vector4f(this).addLocal(x, y, z, w);- Parameters:
- addX- the x value to add.
- addY- the y value to add.
- addZ- the z value to add.
- addW- the w value to add.
- Returns:
- the newly created vector.
 
- 
addLocalAdds the values of the provided vector to the values of this vector.- Parameters:
- other- the vector to add.
- Returns:
- this vector.
 
- 
addLocalAdds the provided values to the values of this vector.- Parameters:
- addX- the x value to add.
- addY- the y value to add.
- addZ- the z value to add.
- addW- the w value to add.
- Returns:
- this vector.
 
- 
subtractCreates a new vector with the same values of this vector and subtracts the values of the provided vector. Same asnew Vector4f(this).subtractLocal(other);- Parameters:
- other- the vector to subtract.
- Returns:
- the newly created vector.
 
- 
subtractCreates a new vector with the same values of this vector and subtracts the provided values. Same asnew Vector4f(this).subtractLocal(x, y, z, w);- Parameters:
- subtractX- the x value to subtract.
- subtractY- the y value to subtract.
- subtractZ- the z value to subtract.
- subtractW- the w value to subtract.
- Returns:
- the newly created vector.
 
- 
subtractLocalSubtracts the values of the provided vector from the values of this vector.- Parameters:
- other- the vector to subtract.
- Returns:
- this vector.
 
- 
subtractLocalSubtracts the provided values from the values of this vector.- Parameters:
- subtractX- the x value to subtract.
- subtractY- the y value to subtract.
- subtractZ- the z value to subtract.
- subtractW- the w value to subtract.
- Returns:
- this vector.
 
- 
multCreates a new vector with the same values of this vector and multiplies them with the provided scalar.- Parameters:
- scalar- the value to multiply the vector by.
- Returns:
- the newly created vector.
 
- 
multCreates a new vector with the same values of this vector and multiplies the values of the provided vector. Same asnew Vector4f(this).multLocal(other);- Parameters:
- other- the vector to multiply.
- Returns:
- the newly created vector.
 
- 
multCreates a new vector with the same values of this vector and multiplies the provided values. Same asnew Vector4f(this).multLocal(x, y, z, w);- Parameters:
- multX- the x value to multiply.
- multY- the y value to multiply.
- multZ- the z value to multiply.
- multW- the w value to multiply.
- Returns:
- the newly created vector.
 
- 
multLocalMultiplies the values of this vector with the provided scalar.- Parameters:
- scalar- the value to multiply this vector by.
- Returns:
- this vector.
 
- 
multLocalMultiplies the values of this vector with the values of the provided vector.- Parameters:
- other- the vector to multiply.
- Returns:
- this vector.
 
- 
multLocalMultiplies the values of this vector with the provided values.- Parameters:
- multX- the x value to multiply the x coordinate of this vector by.
- multY- the y value to multiply the y coordinate of this vector by.
- multZ- the z value to multiply the z coordinate of this vector by.
- multW- the w value to multiply the w coordinate of this vector by.
- Returns:
- this vector.
 
- 
divideCreates a new vector with the same values of this vector and divides the values of the provided vector. Same asnew Vector4f(this).divideLocal(other);- Parameters:
- other- the vector to divide.
- Returns:
- the newly created vector.
 
- 
divideLocal
- 
divideLocal
- 
negateCreates a new vector which contains negated values of this vector.- Returns:
- the newly created vector.
 
- 
negateLocalNegates all values of this vector.- Returns:
- this vector.
 
- 
normalizeLocalNormalizes this vector (i.e turn it into a unit vector).- Returns:
- this vector (normalized).
 
- 
angleBetweenGets the angle between this vector and another vector.
 Please note: Both vectors need to be unit vectors (normalized).- Parameters:
- other- the other vector (unit vector).
- Returns:
- the angle in degrees.
 
- 
zeroSets all values to 0 (same setset(0, 0, 0, 0);).- Returns:
- this vector.
 
- 
isUnitVectorpublic boolean isUnitVector()Checks if this vector is a unit vector.- Returns:
- true if this is a unit vector, false if not.
 
- 
interpolateLocalInterpolates this vector to the provided final vector, e.g if this vector is (0, 5, 10, 0), and the final vector is (-10, 0, 10, 0), the result (by using a mu-value of 0.5f) would be (-5, 2.5f, 10, 0)- Parameters:
- finalVector- the final vector to interpolate towards.
- mu- the mu value between 0.0 and 1.0 (i.e the percentage change from this vector to towards the final vector).
- Returns:
- this vector containing the interpolated values.
 
- 
equalsGets whether or not this vector is equal to another object. This function returns true, if the other object is aVector4fand if it has exactly the same x, y, z and w values.
- 
equalspublic boolean equals(float x, float y, float z, float w) 
- 
hashCodepublic int hashCode()Gets a unique* hash code for this vector, based on its values. If two vectors have the same x, y, z and w values, they will return the same hash code.
 * Please keep in mind that the uniqueness is not fully reliable. There is always a small chance that collisions occur (i.e two completely different vectors return the same hash code). But usually the reliability is sufficient.
- 
toStringGets a String representation of this vector, for example(1.0, 4.2, 0.0, -10.0)
 
-