2018-10-22 04:11:27 +08:00
|
|
|
|
use na::{DefaultAllocator, Point3, Real, Rotation3, Unit};
|
2018-09-22 19:18:59 +08:00
|
|
|
|
|
2018-10-22 04:11:27 +08:00
|
|
|
|
use aliases::{TMat, TMat4, TVec, TVec3};
|
|
|
|
|
use traits::{Alloc, Dimension, Number};
|
2018-09-22 19:18:59 +08:00
|
|
|
|
|
|
|
|
|
/// The identity matrix.
|
2018-09-23 20:48:45 +08:00
|
|
|
|
pub fn identity<N: Number, D: Dimension>() -> TMat<N, D, D>
|
2018-10-22 13:00:10 +08:00
|
|
|
|
where DefaultAllocator: Alloc<N, D, D> {
|
2018-09-23 20:48:45 +08:00
|
|
|
|
TMat::<N, D, D>::identity()
|
2018-09-22 19:18:59 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// Build a look at view matrix based on the right handedness.
|
|
|
|
|
///
|
2018-10-08 10:42:02 +08:00
|
|
|
|
/// # Parameters:
|
|
|
|
|
///
|
|
|
|
|
/// * `eye` − Position of the camera.
|
|
|
|
|
/// * `center` − Position where the camera is looking at.
|
|
|
|
|
/// * `u` − Normalized up vector, how the camera is oriented. Typically `(0, 1, 0)`.
|
2018-10-08 10:30:16 +08:00
|
|
|
|
///
|
|
|
|
|
/// # See also:
|
|
|
|
|
///
|
|
|
|
|
/// * [`look_at_lh`](fn.look_at_lh.html)
|
|
|
|
|
/// * [`look_at_rh`](fn.look_at_rh.html)
|
2018-09-23 20:41:56 +08:00
|
|
|
|
pub fn look_at<N: Real>(eye: &TVec3<N>, center: &TVec3<N>, up: &TVec3<N>) -> TMat4<N> {
|
2018-09-22 19:18:59 +08:00
|
|
|
|
look_at_rh(eye, center, up)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// Build a left handed look at view matrix.
|
|
|
|
|
///
|
2018-10-08 10:42:02 +08:00
|
|
|
|
/// # Parameters:
|
|
|
|
|
///
|
|
|
|
|
/// * `eye` − Position of the camera.
|
|
|
|
|
/// * `center` − Position where the camera is looking at.
|
|
|
|
|
/// * `u` − Normalized up vector, how the camera is oriented. Typically `(0, 1, 0)`.
|
2018-10-08 10:30:16 +08:00
|
|
|
|
///
|
|
|
|
|
/// # See also:
|
|
|
|
|
///
|
|
|
|
|
/// * [`look_at`](fn.look_at.html)
|
|
|
|
|
/// * [`look_at_rh`](fn.look_at_rh.html)
|
2018-09-23 20:41:56 +08:00
|
|
|
|
pub fn look_at_lh<N: Real>(eye: &TVec3<N>, center: &TVec3<N>, up: &TVec3<N>) -> TMat4<N> {
|
2018-10-22 04:11:27 +08:00
|
|
|
|
TMat::look_at_lh(
|
2018-10-24 02:47:42 +08:00
|
|
|
|
&Point3::from(*eye),
|
|
|
|
|
&Point3::from(*center),
|
2018-10-22 04:11:27 +08:00
|
|
|
|
up,
|
|
|
|
|
)
|
2018-09-22 19:18:59 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// Build a right handed look at view matrix.
|
|
|
|
|
///
|
2018-10-08 10:42:02 +08:00
|
|
|
|
/// # Parameters:
|
|
|
|
|
///
|
|
|
|
|
/// * `eye` − Position of the camera.
|
|
|
|
|
/// * `center` − Position where the camera is looking at.
|
|
|
|
|
/// * `u` − Normalized up vector, how the camera is oriented. Typically `(0, 1, 0)`.
|
2018-10-08 10:30:16 +08:00
|
|
|
|
///
|
|
|
|
|
/// # See also:
|
|
|
|
|
///
|
|
|
|
|
/// * [`look_at`](fn.look_at.html)
|
|
|
|
|
/// * [`look_at_lh`](fn.look_at_lh.html)
|
2018-09-23 20:41:56 +08:00
|
|
|
|
pub fn look_at_rh<N: Real>(eye: &TVec3<N>, center: &TVec3<N>, up: &TVec3<N>) -> TMat4<N> {
|
2018-10-22 04:11:27 +08:00
|
|
|
|
TMat::look_at_rh(
|
2018-10-24 02:47:42 +08:00
|
|
|
|
&Point3::from(*eye),
|
|
|
|
|
&Point3::from(*center),
|
2018-10-22 04:11:27 +08:00
|
|
|
|
up,
|
|
|
|
|
)
|
2018-09-22 19:18:59 +08:00
|
|
|
|
}
|
|
|
|
|
|
2018-09-22 23:36:08 +08:00
|
|
|
|
/// Builds a rotation 4 * 4 matrix created from an axis vector and an angle and right-multiply it to `m`.
|
2018-09-22 19:18:59 +08:00
|
|
|
|
///
|
2018-10-08 10:42:02 +08:00
|
|
|
|
/// # Parameters:
|
|
|
|
|
///
|
|
|
|
|
/// * `m` − Input matrix multiplied by this rotation matrix.
|
|
|
|
|
/// * `angle` − Rotation angle expressed in radians.
|
|
|
|
|
/// * `axis` − Rotation axis, recommended to be normalized.
|
2018-10-08 10:30:16 +08:00
|
|
|
|
///
|
|
|
|
|
/// # See also:
|
|
|
|
|
///
|
|
|
|
|
/// * [`rotate_x`](fn.rotate_x.html)
|
|
|
|
|
/// * [`rotate_y`](fn.rotate_y.html)
|
|
|
|
|
/// * [`rotate_z`](fn.rotate_z.html)
|
|
|
|
|
/// * [`scale`](fn.scale.html)
|
|
|
|
|
/// * [`translate`](fn.translate.html)
|
2018-09-23 20:41:56 +08:00
|
|
|
|
pub fn rotate<N: Real>(m: &TMat4<N>, angle: N, axis: &TVec3<N>) -> TMat4<N> {
|
2018-09-22 19:18:59 +08:00
|
|
|
|
m * Rotation3::from_axis_angle(&Unit::new_normalize(*axis), angle).to_homogeneous()
|
|
|
|
|
}
|
|
|
|
|
|
2018-09-23 01:05:37 +08:00
|
|
|
|
/// Builds a rotation 4 * 4 matrix around the X axis and right-multiply it to `m`.
|
|
|
|
|
///
|
2018-10-08 10:42:02 +08:00
|
|
|
|
/// # Parameters:
|
|
|
|
|
///
|
|
|
|
|
/// * `m` − Input matrix multiplied by this rotation matrix.
|
|
|
|
|
/// * `angle` − Rotation angle expressed in radians.
|
2018-10-08 10:30:16 +08:00
|
|
|
|
///
|
|
|
|
|
/// # See also:
|
|
|
|
|
///
|
|
|
|
|
/// * [`rotate`](fn.rotate.html)
|
|
|
|
|
/// * [`rotate_y`](fn.rotate_y.html)
|
|
|
|
|
/// * [`rotate_z`](fn.rotate_z.html)
|
|
|
|
|
/// * [`scale`](fn.scale.html)
|
|
|
|
|
/// * [`translate`](fn.translate.html)
|
2018-09-23 20:41:56 +08:00
|
|
|
|
pub fn rotate_x<N: Real>(m: &TMat4<N>, angle: N) -> TMat4<N> {
|
2018-09-23 20:48:45 +08:00
|
|
|
|
rotate(m, angle, &TVec::x())
|
2018-09-23 01:05:37 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// Builds a rotation 4 * 4 matrix around the Y axis and right-multiply it to `m`.
|
|
|
|
|
///
|
2018-10-08 10:42:02 +08:00
|
|
|
|
/// # Parameters:
|
|
|
|
|
///
|
|
|
|
|
/// * `m` − Input matrix multiplied by this rotation matrix.
|
|
|
|
|
/// * `angle` − Rotation angle expressed in radians.
|
2018-10-08 10:30:16 +08:00
|
|
|
|
///
|
|
|
|
|
/// # See also:
|
|
|
|
|
///
|
|
|
|
|
/// * [`rotate`](fn.rotate.html)
|
|
|
|
|
/// * [`rotate_x`](fn.rotate_x.html)
|
|
|
|
|
/// * [`rotate_z`](fn.rotate_z.html)
|
|
|
|
|
/// * [`scale`](fn.scale.html)
|
|
|
|
|
/// * [`translate`](fn.translate.html)
|
2018-09-23 20:41:56 +08:00
|
|
|
|
pub fn rotate_y<N: Real>(m: &TMat4<N>, angle: N) -> TMat4<N> {
|
2018-09-23 20:48:45 +08:00
|
|
|
|
rotate(m, angle, &TVec::y())
|
2018-09-23 01:05:37 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// Builds a rotation 4 * 4 matrix around the Z axis and right-multiply it to `m`.
|
|
|
|
|
///
|
2018-10-08 10:42:02 +08:00
|
|
|
|
/// # Parameters:
|
|
|
|
|
///
|
|
|
|
|
/// * `m` − Input matrix multiplied by this rotation matrix.
|
|
|
|
|
/// * `angle` − Rotation angle expressed in radians.
|
2018-10-08 10:30:16 +08:00
|
|
|
|
///
|
|
|
|
|
/// # See also:
|
|
|
|
|
///
|
|
|
|
|
/// * [`rotate`](fn.rotate.html)
|
|
|
|
|
/// * [`rotate_x`](fn.rotate_x.html)
|
|
|
|
|
/// * [`rotate_y`](fn.rotate_y.html)
|
|
|
|
|
/// * [`scale`](fn.scale.html)
|
|
|
|
|
/// * [`translate`](fn.translate.html)
|
2018-09-23 20:41:56 +08:00
|
|
|
|
pub fn rotate_z<N: Real>(m: &TMat4<N>, angle: N) -> TMat4<N> {
|
2018-09-23 20:48:45 +08:00
|
|
|
|
rotate(m, angle, &TVec::z())
|
2018-09-23 01:05:37 +08:00
|
|
|
|
}
|
|
|
|
|
|
2018-09-22 23:36:08 +08:00
|
|
|
|
/// Builds a scale 4 * 4 matrix created from 3 scalars and right-multiply it to `m`.
|
2018-09-22 19:18:59 +08:00
|
|
|
|
///
|
2018-10-08 10:42:02 +08:00
|
|
|
|
/// # Parameters:
|
|
|
|
|
///
|
|
|
|
|
/// * `m` − Input matrix multiplied by this scale matrix.
|
|
|
|
|
/// * `v` − Ratio of scaling for each axis.
|
2018-10-08 10:30:16 +08:00
|
|
|
|
///
|
|
|
|
|
/// # See also:
|
|
|
|
|
///
|
|
|
|
|
/// * [`rotate`](fn.rotate.html)
|
|
|
|
|
/// * [`rotate_x`](fn.rotate_x.html)
|
|
|
|
|
/// * [`rotate_y`](fn.rotate_y.html)
|
|
|
|
|
/// * [`rotate_z`](fn.rotate_z.html)
|
|
|
|
|
/// * [`translate`](fn.translate.html)
|
2018-09-23 20:41:56 +08:00
|
|
|
|
pub fn scale<N: Number>(m: &TMat4<N>, v: &TVec3<N>) -> TMat4<N> {
|
2018-09-22 19:18:59 +08:00
|
|
|
|
m.prepend_nonuniform_scaling(v)
|
|
|
|
|
}
|
|
|
|
|
|
2018-09-22 23:36:08 +08:00
|
|
|
|
/// Builds a translation 4 * 4 matrix created from a vector of 3 components and right-multiply it to `m`.
|
2018-09-22 19:18:59 +08:00
|
|
|
|
///
|
2018-10-08 10:42:02 +08:00
|
|
|
|
/// # Parameters:
|
|
|
|
|
///
|
|
|
|
|
/// * `m` − Input matrix multiplied by this translation matrix.
|
|
|
|
|
/// * `v` − Coordinates of a translation vector.
|
2018-10-08 10:30:16 +08:00
|
|
|
|
///
|
|
|
|
|
/// # See also:
|
|
|
|
|
///
|
|
|
|
|
/// * [`rotate`](fn.rotate.html)
|
|
|
|
|
/// * [`rotate_x`](fn.rotate_x.html)
|
|
|
|
|
/// * [`rotate_y`](fn.rotate_y.html)
|
|
|
|
|
/// * [`rotate_z`](fn.rotate_z.html)
|
|
|
|
|
/// * [`scale`](fn.scale.html)
|
2018-09-23 20:41:56 +08:00
|
|
|
|
pub fn translate<N: Number>(m: &TMat4<N>, v: &TVec3<N>) -> TMat4<N> {
|
2018-09-22 19:18:59 +08:00
|
|
|
|
m.prepend_translation(v)
|
|
|
|
|
}
|