use crate::aliases::{ Qua, TMat, TMat2, TMat2x3, TMat2x4, TMat3, TMat3x2, TMat3x4, TMat4, TMat4x2, TMat4x3, TVec1, TVec2, TVec3, TVec4, }; use na::{RealField, Scalar}; /// Creates a new 1D vector. /// /// # Examples: /// /// Construct a vector of `bool`s: /// /// ``` /// # use nalgebra_glm as glm; /// let v = glm::vec1(true); /// ``` pub fn vec1(x: T) -> TVec1 { TVec1::new(x) } /// Creates a new 2D vector. pub fn vec2(x: T, y: T) -> TVec2 { TVec2::new(x, y) } /// Creates a new 3D vector. pub fn vec3(x: T, y: T, z: T) -> TVec3 { TVec3::new(x, y, z) } /// Creates a new 4D vector. pub fn vec4(x: T, y: T, z: T, w: T) -> TVec4 { TVec4::new(x, y, z, w) } /// Create a new 2x2 matrix. #[rustfmt::skip] pub fn mat2(m11: T, m12: T, m21: T, m22: T) -> TMat2 { TMat::::new( m11, m12, m21, m22, ) } /// Create a new 2x2 matrix. #[rustfmt::skip] pub fn mat2x2(m11: T, m12: T, m21: T, m22: T) -> TMat2 { TMat::::new( m11, m12, m21, m22, ) } /// Create a new 2x3 matrix. #[rustfmt::skip] pub fn mat2x3(m11: T, m12: T, m13: T, m21: T, m22: T, m23: T) -> TMat2x3 { TMat::::new( m11, m12, m13, m21, m22, m23, ) } /// Create a new 2x4 matrix. #[rustfmt::skip] pub fn mat2x4(m11: T, m12: T, m13: T, m14: T, m21: T, m22: T, m23: T, m24: T) -> TMat2x4 { TMat::::new( m11, m12, m13, m14, m21, m22, m23, m24, ) } /// Create a new 3x3 matrix. #[rustfmt::skip] pub fn mat3(m11: T, m12: T, m13: T, m21: T, m22: T, m23: T, m31: T, m32: T, m33: T) -> TMat3 { TMat::::new( m11, m12, m13, m21, m22, m23, m31, m32, m33, ) } /// Create a new 3x2 matrix. #[rustfmt::skip] pub fn mat3x2(m11: T, m12: T, m21: T, m22: T, m31: T, m32: T) -> TMat3x2 { TMat::::new( m11, m12, m21, m22, m31, m32, ) } /// Create a new 3x3 matrix. #[rustfmt::skip] pub fn mat3x3(m11: T, m12: T, m13: T, m21: T, m22: T, m23: T, m31: T, m32: T, m33: T) -> TMat3 { TMat::::new( m11, m12, m13, m31, m32, m33, m21, m22, m23, ) } /// Create a new 3x4 matrix. #[rustfmt::skip] pub fn mat3x4(m11: T, m12: T, m13: T, m14: T, m21: T, m22: T, m23: T, m24: T, m31: T, m32: T, m33: T, m34: T) -> TMat3x4 { TMat::::new( m11, m12, m13, m14, m21, m22, m23, m24, m31, m32, m33, m34, ) } /// Create a new 4x2 matrix. #[rustfmt::skip] pub fn mat4x2(m11: T, m12: T, m21: T, m22: T, m31: T, m32: T, m41: T, m42: T) -> TMat4x2 { TMat::::new( m11, m12, m21, m22, m31, m32, m41, m42, ) } /// Create a new 4x3 matrix. #[rustfmt::skip] pub fn mat4x3(m11: T, m12: T, m13: T, m21: T, m22: T, m23: T, m31: T, m32: T, m33: T, m41: T, m42: T, m43: T) -> TMat4x3 { TMat::::new( m11, m12, m13, m21, m22, m23, m31, m32, m33, m41, m42, m43, ) } /// Create a new 4x4 matrix. #[rustfmt::skip] pub fn mat4x4(m11: T, m12: T, m13: T, m14: T, m21: T, m22: T, m23: T, m24: T, m31: T, m32: T, m33: T, m34: T, m41: T, m42: T, m43: T, m44: T) -> TMat4 { TMat::::new( m11, m12, m13, m14, m21, m22, m23, m24, m31, m32, m33, m34, m41, m42, m43, m44, ) } /// Create a new 4x4 matrix. #[rustfmt::skip] pub fn mat4(m11: T, m12: T, m13: T, m14: T, m21: T, m22: T, m23: T, m24: T, m31: T, m32: T, m33: T, m34: T, m41: T, m42: T, m43: T, m44: T) -> TMat4 { TMat::::new( m11, m12, m13, m14, m21, m22, m23, m24, m31, m32, m33, m34, m41, m42, m43, m44, ) } /// Creates a new quaternion. pub fn quat(x: T, y: T, z: T, w: T) -> Qua { Qua::new(w, x, y, z) }