Struct glam::f64::DMat3 [−][src]
#[repr(C)]pub struct DMat3(_);
Expand description
A 3x3 column major matrix.
This 3x3 matrix type features convenience methods for creating and using linear and
affine transformations. If you are primarily dealing with 2D affine transformations the
[Affine2
] type is much faster and more space efficient than using a 3x3 matrix.
Linear transformations including 3D rotation and scale can be created using methods
such as Self::from_diagonal()
, Self::from_quat()
, Self::from_axis_angle()
,
Self::from_rotation_x()
, Self::from_rotation_y()
, or
Self::from_rotation_z()
.
The resulting matrices can be use to transform 3D vectors using regular vector multiplication.
Affine transformations including 2D translation, rotation and scale can be created
using methods such as Self::from_translation()
, Self::from_angle()
,
Self::from_scale()
and Self::from_scale_angle_translation()
.
The Self::transform_point2()
and Self::transform_vector2()
convenience methods
are provided for performing affine transforms on 2D vectors and points. These multiply
2D inputs as 3D vectors with an implicit z
value of 1
for points and 0
for
vectors respectively. These methods assume that Self
contains a valid affine
transform.
Implementations
impl DMat3
[src]
impl DMat3
[src]pub const IDENTITY: Self
[src]
pub const IDENTITY: Self
[src]A 3x3 identity matrix, where all diagonal elements are 1
, and all off-diagonal
elements are 0
.
pub fn from_cols(x_axis: DVec3, y_axis: DVec3, z_axis: DVec3) -> Self
[src]
pub fn from_cols(x_axis: DVec3, y_axis: DVec3, z_axis: DVec3) -> Self
[src]Creates a 3x3 matrix from three column vectors.
pub fn from_cols_array(m: &[f64; 9]) -> Self
[src]
pub fn from_cols_array(m: &[f64; 9]) -> Self
[src]Creates a 3x3 matrix from a [S; 9]
array stored in column major order.
If your data is stored in row major you will need to transpose
the returned
matrix.
pub fn to_cols_array(&self) -> [f64; 9]
[src]
pub fn to_cols_array(&self) -> [f64; 9]
[src]Creates a [S; 9]
array storing data in column major order.
If you require data in row major order transpose
the matrix first.
pub fn from_cols_array_2d(m: &[[f64; 3]; 3]) -> Self
[src]
pub fn from_cols_array_2d(m: &[[f64; 3]; 3]) -> Self
[src]Creates a 3x3 matrix from a [[S; 3]; 3]
2D array stored in column major order.
If your data is in row major order you will need to transpose
the returned
matrix.
pub fn to_cols_array_2d(&self) -> [[f64; 3]; 3]
[src]
pub fn to_cols_array_2d(&self) -> [[f64; 3]; 3]
[src]Creates a [[S; 3]; 3]
2D array storing data in column major order.
If you require data in row major order transpose
the matrix first.
pub fn from_diagonal(diagonal: DVec3) -> Self
[src]
pub fn from_diagonal(diagonal: DVec3) -> Self
[src]Creates a 3x3 matrix with its diagonal set to diagonal
and all other entries set to 0.
The resulting matrix is a 3D scale transfom.
pub fn from_quat(rotation: DQuat) -> Self
[src]
pub fn from_quat(rotation: DQuat) -> Self
[src]Creates a 3D rotation matrix from the given quaternion.
pub fn from_axis_angle(axis: DVec3, angle: f64) -> Self
[src]
pub fn from_axis_angle(axis: DVec3, angle: f64) -> Self
[src]Creates a 3D rotation matrix from a normalized rotation axis
and angle
(in
radians).
pub fn from_rotation_ypr(yaw: f64, pitch: f64, roll: f64) -> Self
[src]
Please use from_euler(EulerRot::YXZ, yaw, pitch, roll)
instead
pub fn from_euler(order: EulerRot, a: f64, b: f64, c: f64) -> Self
[src]
pub fn from_euler(order: EulerRot, a: f64, b: f64, c: f64) -> Self
[src]Creates a 3D rotation matrix from the given euler rotation sequence and the angles (in radians).
pub fn from_rotation_x(angle: f64) -> Self
[src]
pub fn from_rotation_x(angle: f64) -> Self
[src]Creates a 3D rotation matrix from angle
(in radians) around the x axis.
pub fn from_rotation_y(angle: f64) -> Self
[src]
pub fn from_rotation_y(angle: f64) -> Self
[src]Creates a 3D rotation matrix from angle
(in radians) around the y axis.
pub fn from_rotation_z(angle: f64) -> Self
[src]
pub fn from_rotation_z(angle: f64) -> Self
[src]Creates a 3D rotation matrix from angle
(in radians) around the z axis.
pub fn from_translation(translation: DVec2) -> Self
[src]
pub fn from_translation(translation: DVec2) -> Self
[src]Creates an affine transformation matrix from the given 2D translation
.
The resulting matrix can be used to transform 2D points and vectors. See
Self::transform_point2()
and Self::transform_vector2()
.
pub fn from_angle(angle: f64) -> Self
[src]
pub fn from_angle(angle: f64) -> Self
[src]Creates an affine transformation matrix from the given 2D rotation angle
(in
radians).
The resulting matrix can be used to transform 2D points and vectors. See
Self::transform_point2()
and Self::transform_vector2()
.
pub fn from_scale_angle_translation(
scale: DVec2,
angle: f64,
translation: DVec2
) -> Self
[src]
pub fn from_scale_angle_translation(
scale: DVec2,
angle: f64,
translation: DVec2
) -> Self
[src]Creates an affine transformation matrix from the given 2D scale
, rotation angle
(in
radians) and translation
.
The resulting matrix can be used to transform 2D points and vectors. See
Self::transform_point2()
and Self::transform_vector2()
.
pub fn from_scale(scale: DVec2) -> Self
[src]
pub fn from_scale(scale: DVec2) -> Self
[src]Creates an affine transformation matrix from the given non-uniform 2D scale
.
The resulting matrix can be used to transform 2D points and vectors. See
Self::transform_point2()
and Self::transform_vector2()
.
pub fn from_cols_slice(slice: &[f64]) -> Self
[src]
pub fn from_cols_slice(slice: &[f64]) -> Self
[src]Creates a 3x3 matrix from the first 9 values in slice
.
Panics
Panics if slice
is less than 9 elements long.
pub fn write_cols_to_slice(self, slice: &mut [f64])
[src]
pub fn write_cols_to_slice(self, slice: &mut [f64])
[src]Writes the columns of self
to the first 9 elements in slice
.
Panics
Panics if slice
is less than 9 elements long.
pub fn is_finite(&self) -> bool
[src]
pub fn is_finite(&self) -> bool
[src]Returns true
if, and only if, all elements are finite.
If any element is either NaN
, positive or negative infinity, this will return false
.
pub fn determinant(&self) -> f64
[src]
pub fn determinant(&self) -> f64
[src]Returns the determinant of self
.
pub fn inverse(&self) -> Self
[src]
pub fn inverse(&self) -> Self
[src]Returns the inverse of self
.
If the matrix is not invertible the returned matrix will be invalid.
pub fn mul_scalar(&self, other: f64) -> Self
[src]
pub fn mul_scalar(&self, other: f64) -> Self
[src]Multiplies a 3x3 matrix by a scalar.
pub fn transform_point2(&self, other: DVec2) -> DVec2
[src]
pub fn transform_point2(&self, other: DVec2) -> DVec2
[src]Transforms the given 2D vector as a point.
This is the equivalent of multiplying other
as a 3D vector where z
is 1
.
This method assumes that self
contains a valid affine transform.
pub fn transform_vector2(&self, other: DVec2) -> DVec2
[src]
pub fn transform_vector2(&self, other: DVec2) -> DVec2
[src]Rotates the given 2D vector.
This is the equivalent of multiplying other
as a 3D vector where z
is 0
.
This method assumes that self
contains a valid affine transform.
pub fn abs_diff_eq(&self, other: Self, max_abs_diff: f64) -> bool
[src]
pub fn abs_diff_eq(&self, other: Self, max_abs_diff: f64) -> bool
[src]Returns true if the absolute difference of all elements between self
and other
is less than or equal to max_abs_diff
.
This can be used to compare if two matrices contain similar elements. It works best
when comparing with a known value. The max_abs_diff
that should be used used
depends on the values being compared against.
For more see comparing floating point numbers.
pub fn as_f32(&self) -> Mat3
[src]
Trait Implementations
impl Copy for DMat3
[src]
Auto Trait Implementations
impl RefUnwindSafe for DMat3
impl Send for DMat3
impl Sync for DMat3
impl Unpin for DMat3
impl UnwindSafe for DMat3
Blanket Implementations
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]pub fn borrow_mut(&mut self) -> &mut T
[src]
pub fn borrow_mut(&mut self) -> &mut T
[src]Mutably borrows from an owned value. Read more
impl<T> ToOwned for T where
T: Clone,
[src]
impl<T> ToOwned for T where
T: Clone,
[src]type Owned = T
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
pub fn to_owned(&self) -> T
[src]Creates owned data from borrowed data, usually by cloning. Read more
pub fn clone_into(&self, target: &mut T)
[src]
pub fn clone_into(&self, target: &mut T)
[src]🔬 This is a nightly-only experimental API. (toowned_clone_into
)
recently added
Uses borrowed data to replace owned data, usually by cloning. Read more