A four-dimensional matrix.
Adapted from gl-matrix by toji
and vecmath by mattdesl
Constructor
new Matrix4([m])
Parameters
name | type | optional | description |
---|---|---|---|
m | Yes | Optional Matrix4 to copy values from. |
Scope: static
Source: src/math/Matrix4.js#L15
Since: 3.0.0
Public Members
val
val: Float32Array
Description:
The matrix values.
Source: src/math/Matrix4.js#L35
Since: 3.0.0
Public Methods
adjoint
<instance> adjoint()
Description:
Calculate the adjoint, or adjugate, of this Matrix.
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L418
Since: 3.0.0
clone
<instance> clone()
Description:
Make a clone of this Matrix4.
Returns: Phaser.Math.Matrix4 - A clone of this Matrix4.
Source: src/math/Matrix4.js#L56
Since: 3.0.0
copy
<instance> copy(src)
Description:
Copy the values of a given Matrix into this Matrix.
Parameters:
name | type | optional | description |
---|---|---|---|
src | No | The Matrix to copy the values from. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L133
Since: 3.0.0
determinant
<instance> determinant()
Description:
Calculate the determinant of this Matrix.
Returns: number - The determinant of this Matrix.
Source: src/math/Matrix4.js#L470
Since: 3.0.0
fromArray
<instance> fromArray(a)
Description:
Set the values of this Matrix from the given array.
Parameters:
name | type | optional | description |
---|---|---|---|
a | Array.<number> | No | The array to copy the values from. Must have at least 16 elements. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L150
Since: 3.0.0
fromQuat
<instance> fromQuat(q)
Description:
Set the values of this Matrix from the given Quaternion.
Parameters:
name | type | optional | description |
---|---|---|---|
q | No | The Quaternion to set the values of this Matrix from. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L1105
Since: 3.0.0
fromRotationTranslation
<instance> fromRotationTranslation(q, v)
Description:
Set the values of this Matrix from the given rotation Quaternion and translation Vector.
Parameters:
name | type | optional | description |
---|---|---|---|
q | No | The Quaternion to set rotation from. | |
v | No | The Vector to set translation from. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L1047
Since: 3.0.0
fromRotationXYTranslation
<instance> fromRotationXYTranslation(rotation, position, translateFirst)
Description:
Takes the rotation and position vectors and builds this Matrix4 from them.
Parameters:
name | type | optional | description |
---|---|---|---|
rotation | No | The rotation vector. | |
position | No | The position vector. | |
translateFirst | boolean | No | Should the operation translate then rotate ( |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L1670
Since: 3.50.0
frustum
<instance> frustum(left, right, bottom, top, near, far)
Description:
Generate a frustum matrix with the given bounds.
Parameters:
name | type | optional | description |
---|---|---|---|
left | number | No | The left bound of the frustum. |
right | number | No | The right bound of the frustum. |
bottom | number | No | The bottom bound of the frustum. |
top | number | No | The top bound of the frustum. |
near | number | No | The near bound of the frustum. |
far | number | No | The far bound of the frustum. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L1161
Since: 3.0.0
getInverse
<instance> getInverse(m)
Description:
Copies the given Matrix4 into this Matrix and then inverses it.
Parameters:
name | type | optional | description |
---|---|---|---|
m | No | The Matrix4 to invert into this Matrix4. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L324
Since: 3.50.0
getMaxScaleOnAxis
<instance> getMaxScaleOnAxis()
Description:
Returns the maximum axis scale from this Matrix4.
Returns: number - The maximum axis scale.
Source: src/math/Matrix4.js#L1741
Since: 3.50.0
identity
<instance> identity()
Description:
Reset this Matrix to an identity (default) matrix.
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L276
Since: 3.0.0
invert
<instance> invert()
Description:
Invert this Matrix.
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L341
Since: 3.0.0
lookAt
<instance> lookAt(eye, center, up)
Description:
Generate a look-at matrix with the given eye position, focal point, and up axis.
Parameters:
name | type | optional | description |
---|---|---|---|
eye | No | Position of the viewer | |
center | No | Point the viewer is looking at | |
up | No | vec3 pointing up. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L1393
Since: 3.0.0
lookAtRH
<instance> lookAtRH(eye, target, up)
Description:
Generate a right-handed look-at matrix with the given eye position, target and up axis.
Parameters:
name | type | optional | description |
---|---|---|---|
eye | No | Position of the viewer. | |
target | No | Point the viewer is looking at. | |
up | No | vec3 pointing up. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L1333
Since: 3.50.0
makeRotationAxis
<instance> makeRotationAxis(axis, angle)
Description:
Derive a rotation matrix around the given axis.
Parameters:
name | type | optional | description |
---|---|---|---|
axis | No | The rotation axis. | |
angle | number | No | The rotation angle in radians. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L814
Since: 3.0.0
multiply
<instance> multiply(src)
Description:
Multiply this Matrix by the given Matrix.
Parameters:
name | type | optional | description |
---|---|---|---|
src | No | The Matrix to multiply this Matrix by. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L519
Since: 3.0.0
multiplyLocal
<instance> multiplyLocal(src)
Description:
Multiply the values of this Matrix4 by those given in the src
argument.
Parameters:
name | type | optional | description |
---|---|---|---|
src | No | The source Matrix4 that this Matrix4 is multiplied by. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L599
Since: 3.0.0
multiplyMatrices
<instance> multiplyMatrices(a, b)
Description:
Multiplies the two given Matrix4 objects and stores the results in this Matrix.
Parameters:
name | type | optional | description |
---|---|---|---|
a | No | The first Matrix4 to multiply. | |
b | No | The second Matrix4 to multiply. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L654
Since: 3.50.0
multiplyToMat4
<instance> multiplyToMat4(src, out)
Description:
Multiplies this Matrix4 by the given src
Matrix4 and stores the results in the out
Matrix4.
Parameters:
name | type | optional | description |
---|---|---|---|
src | No | The Matrix4 to multiply with this one. | |
out | No | The receiving Matrix. |
Returns: Phaser.Math.Matrix4 - This out
Matrix4.
Source: src/math/Matrix4.js#L1597
Since: 3.50.0
ortho
<instance> ortho(left, right, bottom, top, near, far)
Description:
Generate an orthogonal projection matrix with the given bounds.
Parameters:
name | type | optional | description |
---|---|---|---|
left | number | No | The left bound of the frustum. |
right | number | No | The right bound of the frustum. |
bottom | number | No | The bottom bound of the frustum. |
top | number | No | The top bound of the frustum. |
near | number | No | The near bound of the frustum. |
far | number | No | The far bound of the frustum. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L1284
Since: 3.0.0
perspective
<instance> perspective(fovy, aspect, near, far)
Description:
Generate a perspective projection matrix with the given bounds.
Parameters:
name | type | optional | description |
---|---|---|---|
fovy | number | No | Vertical field of view in radians |
aspect | number | No | Aspect ratio. Typically viewport width /height. |
near | number | No | Near bound of the frustum. |
far | number | No | Far bound of the frustum. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L1205
Since: 3.0.0
perspectiveLH
<instance> perspectiveLH(width, height, near, far)
Description:
Generate a perspective projection matrix with the given bounds.
Parameters:
name | type | optional | description |
---|---|---|---|
width | number | No | The width of the frustum. |
height | number | No | The height of the frustum. |
near | number | No | Near bound of the frustum. |
far | number | No | Far bound of the frustum. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L1246
Since: 3.0.0
premultiply
<instance> premultiply(m)
Description:
Multiplies the given Matrix4 object with this Matrix.
This is the same as calling multiplyMatrices(m, this)
.
Parameters:
name | type | optional | description |
---|---|---|---|
m | No | The Matrix4 to multiply with this one. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L637
Since: 3.50.0
rotate
<instance> rotate(rad, axis)
Description:
Apply a rotation transformation to this Matrix.
Parameters:
name | type | optional | description |
---|---|---|---|
rad | number | No | The angle in radians to rotate by. |
axis | No | The axis to rotate upon. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L846
Since: 3.0.0
rotateX
<instance> rotateX(rad)
Description:
Rotate this matrix on its X axis.
Parameters:
name | type | optional | description |
---|---|---|---|
rad | number | No | The angle in radians to rotate by. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L930
Since: 3.0.0
rotateY
<instance> rotateY(rad)
Description:
Rotate this matrix on its Y axis.
Parameters:
name | type | optional | description |
---|---|---|---|
rad | number | No | The angle to rotate by, in radians. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L969
Since: 3.0.0
rotateZ
<instance> rotateZ(rad)
Description:
Rotate this matrix on its Z axis.
Parameters:
name | type | optional | description |
---|---|---|---|
rad | number | No | The angle to rotate by, in radians. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L1008
Since: 3.0.0
scale
<instance> scale(v)
Description:
Apply a scale transformation to this Matrix.
Uses the x
, y
and z
components of the given Vector to scale the Matrix.
Parameters:
name | type | optional | description |
---|---|---|---|
v | No | The Vector to scale this Matrix with. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L763
Since: 3.0.0
scaleXYZ
<instance> scaleXYZ(x, y, z)
Description:
Apply a scale transformation to this Matrix.
Parameters:
name | type | optional | description |
---|---|---|---|
x | number | No | The x component. |
y | number | No | The y component. |
z | number | No | The z component. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L780
Since: 3.16.0
scaling
<instance> scaling(x, y, z)
Description:
Set the scaling values of this Matrix.
Parameters:
name | type | optional | description |
---|---|---|---|
x | number | No | The x scaling value. |
y | number | No | The y scaling value. |
z | number | No | The z scaling value. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L250
Since: 3.0.0
set
<instance> set(src)
Description:
This method is an alias for Matrix4.copy
.
Parameters:
name | type | optional | description |
---|---|---|---|
src | No | The Matrix to set the values of this Matrix's from. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L69
Since: 3.0.0
setValues
<instance> setValues(m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33)
Description:
Sets all values of this Matrix4.
Parameters:
name | type | optional | description |
---|---|---|---|
m00 | number | No | The m00 value. |
m01 | number | No | The m01 value. |
m02 | number | No | The m02 value. |
m03 | number | No | The m03 value. |
m10 | number | No | The m10 value. |
m11 | number | No | The m11 value. |
m12 | number | No | The m12 value. |
m13 | number | No | The m13 value. |
m20 | number | No | The m20 value. |
m21 | number | No | The m21 value. |
m22 | number | No | The m22 value. |
m23 | number | No | The m23 value. |
m30 | number | No | The m30 value. |
m31 | number | No | The m31 value. |
m32 | number | No | The m32 value. |
m33 | number | No | The m33 value. |
Returns: Phaser.Math.Matrix4 - This Matrix4 instance.
Source: src/math/Matrix4.js#L84
Since: 3.50.0
setWorldMatrix
<instance> setWorldMatrix(rotation, position, scale, [viewMatrix], [projectionMatrix])
Description:
Generate a world matrix from the given rotation, position, scale, view matrix and projection matrix.
Parameters:
name | type | optional | description |
---|---|---|---|
rotation | No | The rotation of the world matrix. | |
position | No | The position of the world matrix. | |
scale | No | The scale of the world matrix. | |
viewMatrix | Yes | The view matrix. | |
projectionMatrix | Yes | The projection matrix. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L1560
Since: 3.0.0
transform
<instance> transform(position, scale, rotation)
Description:
Generates a transform matrix based on the given position, scale and rotation.
Parameters:
name | type | optional | description |
---|---|---|---|
position | No | The position vector. | |
scale | No | The scale vector. | |
rotation | No | The rotation quaternion. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L180
Since: 3.50.0
translate
<instance> translate(v)
Description:
Translate this Matrix using the given Vector.
Parameters:
name | type | optional | description |
---|---|---|---|
v | No | The Vector to translate this Matrix with. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L724
Since: 3.0.0
translateXYZ
<instance> translateXYZ(x, y, z)
Description:
Translate this Matrix using the given values.
Parameters:
name | type | optional | description |
---|---|---|---|
x | number | No | The x component. |
y | number | No | The y component. |
z | number | No | The z component. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L739
Since: 3.16.0
transpose
<instance> transpose()
Description:
Transpose this Matrix.
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L289
Since: 3.0.0
xyz
<instance> xyz(x, y, z)
Description:
Set the x
, y
and z
values of this Matrix.
Parameters:
name | type | optional | description |
---|---|---|---|
x | number | No | The x value. |
y | number | No | The y value. |
z | number | No | The z value. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L225
Since: 3.0.0
yawPitchRoll
<instance> yawPitchRoll(yaw, pitch, roll)
Description:
Set the values of this matrix from the given yaw
, pitch
and roll
values.
Parameters:
name | type | optional | description |
---|---|---|---|
yaw | number | No | The yaw value. |
pitch | number | No | The pitch value. |
roll | number | No | The roll value. |
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L1499
Since: 3.0.0
zero
<instance> zero()
Description:
Reset this Matrix.
Sets all values to 0
.
Returns: Phaser.Math.Matrix4 - This Matrix4.
Source: src/math/Matrix4.js#L165
Since: 3.0.0