use super::*;
#[derive(Clone, Copy, Default, PartialEq)]
#[repr(align(16), C)]
pub struct Mat3 {
pub(crate) x_axis: Vec3,
pub(crate) y_axis: Vec3,
pub(crate) z_axis: Vec3,
}
unsafe impl Zeroable for Mat3 {}
unsafe impl Pod for Mat3 {}
impl core::fmt::Debug for Mat3 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.write_str("Mat3 { x_axis: (")?;
let [x, y, z, _]: [f32; 4] = cast(self.x_axis);
core::fmt::Debug::fmt(&x, f)?;
f.write_str(", ")?;
core::fmt::Debug::fmt(&y, f)?;
f.write_str(", ")?;
core::fmt::Debug::fmt(&z, f)?;
f.write_str("), y_axis: (")?;
let [x, y, z, _]: [f32; 4] = cast(self.y_axis);
core::fmt::Debug::fmt(&x, f)?;
f.write_str(", ")?;
core::fmt::Debug::fmt(&y, f)?;
f.write_str(", ")?;
core::fmt::Debug::fmt(&z, f)?;
f.write_str("), z_axis: (")?;
let [x, y, z, _]: [f32; 4] = cast(self.z_axis);
core::fmt::Debug::fmt(&x, f)?;
f.write_str(", ")?;
core::fmt::Debug::fmt(&y, f)?;
f.write_str(", ")?;
core::fmt::Debug::fmt(&z, f)?;
f.write_str(") }")
}
}
impl core::fmt::Display for Mat3 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
let [x0, x1, x2, _]: [f32; 4] = cast(self.x_axis);
let [y0, y1, y2, _]: [f32; 4] = cast(self.y_axis);
let [z0, z1, z2, _]: [f32; 4] = cast(self.z_axis);
f.write_str("| ")?;
core::fmt::Display::fmt(&x0, f)?;
f.write_str(", ")?;
core::fmt::Display::fmt(&y0, f)?;
f.write_str(", ")?;
core::fmt::Display::fmt(&z0, f)?;
f.write_str(" |\n| ")?;
core::fmt::Display::fmt(&x1, f)?;
f.write_str(", ")?;
core::fmt::Display::fmt(&y1, f)?;
f.write_str(", ")?;
core::fmt::Display::fmt(&z1, f)?;
f.write_str(" |\n| ")?;
core::fmt::Display::fmt(&x2, f)?;
f.write_str(", ")?;
core::fmt::Display::fmt(&y2, f)?;
f.write_str(", ")?;
core::fmt::Display::fmt(&z2, f)?;
f.write_str(" |")
}
}
impl core::fmt::LowerExp for Mat3 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
let [x0, x1, x2, _]: [f32; 4] = cast(self.x_axis);
let [y0, y1, y2, _]: [f32; 4] = cast(self.y_axis);
let [z0, z1, z2, _]: [f32; 4] = cast(self.z_axis);
f.write_str("| ")?;
core::fmt::LowerExp::fmt(&x0, f)?;
f.write_str(", ")?;
core::fmt::LowerExp::fmt(&y0, f)?;
f.write_str(", ")?;
core::fmt::LowerExp::fmt(&z0, f)?;
f.write_str(" |\n| ")?;
core::fmt::LowerExp::fmt(&x1, f)?;
f.write_str(", ")?;
core::fmt::LowerExp::fmt(&y1, f)?;
f.write_str(", ")?;
core::fmt::LowerExp::fmt(&z1, f)?;
f.write_str(" |\n| ")?;
core::fmt::LowerExp::fmt(&x2, f)?;
f.write_str(", ")?;
core::fmt::LowerExp::fmt(&y2, f)?;
f.write_str(", ")?;
core::fmt::LowerExp::fmt(&z2, f)?;
f.write_str(" |")
}
}
impl core::fmt::UpperExp for Mat3 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
let [x0, x1, x2, _]: [f32; 4] = cast(self.x_axis);
let [y0, y1, y2, _]: [f32; 4] = cast(self.y_axis);
let [z0, z1, z2, _]: [f32; 4] = cast(self.z_axis);
f.write_str("| ")?;
core::fmt::UpperExp::fmt(&x0, f)?;
f.write_str(", ")?;
core::fmt::UpperExp::fmt(&y0, f)?;
f.write_str(", ")?;
core::fmt::UpperExp::fmt(&z0, f)?;
f.write_str(" |\n| ")?;
core::fmt::UpperExp::fmt(&x1, f)?;
f.write_str(", ")?;
core::fmt::UpperExp::fmt(&y1, f)?;
f.write_str(", ")?;
core::fmt::UpperExp::fmt(&z1, f)?;
f.write_str(" |\n| ")?;
core::fmt::UpperExp::fmt(&x2, f)?;
f.write_str(", ")?;
core::fmt::UpperExp::fmt(&y2, f)?;
f.write_str(", ")?;
core::fmt::UpperExp::fmt(&z2, f)?;
f.write_str(" |")
}
}
impl From<[f32; 9]> for Mat3 {
fn from([xx, xy, xz, yx, yy, yz, zx, zy, zz]: [f32; 9]) -> Self {
Self {
x_axis: Vec3::from([xx, xy, xz]),
y_axis: Vec3::from([yx, yy, yz]),
z_axis: Vec3::from([zx, zy, zz]),
}
}
}
impl From<Mat3> for [f32; 9] {
fn from(
Mat3 {
x_axis,
y_axis,
z_axis,
}: Mat3,
) -> Self {
let [e0, e1, e2]: [f32; 3] = x_axis.into();
let [e3, e4, e5]: [f32; 3] = y_axis.into();
let [e6, e7, e8]: [f32; 3] = z_axis.into();
[e0, e1, e2, e3, e4, e5, e6, e7, e8]
}
}
#[cfg(feature = "mint")]
impl From<mint::ColumnMatrix3<f32>> for Mat3 {
fn from(mint::ColumnMatrix3 { x, y, z }: mint::ColumnMatrix3<f32>) -> Self {
let x_axis: Vec3 = x.into();
let y_axis: Vec3 = y.into();
let z_axis: Vec3 = z.into();
Self {
x_axis,
y_axis,
z_axis,
}
}
}
#[cfg(feature = "mint")]
impl From<Mat3> for mint::ColumnMatrix3<f32> {
fn from(
Mat3 {
x_axis,
y_axis,
z_axis,
}: Mat3,
) -> Self {
let x: mint::Vector3<f32> = x_axis.into();
let y: mint::Vector3<f32> = y_axis.into();
let z: mint::Vector3<f32> = z_axis.into();
Self { x, y, z }
}
}
#[cfg(feature = "serde")]
impl serde::Serialize for Mat3 {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: serde::Serializer,
{
<[f32; 9]>::from(*self).serialize(serializer)
}
}
#[cfg(feature = "serde")]
impl<'de> serde::Deserialize<'de> for Mat3 {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where
D: serde::Deserializer<'de>,
{
Ok(Self::from(<[f32; 9]>::deserialize(deserializer)?))
}
}
impl Mat3 {
pub fn x_axis(self) -> Vec3 {
self.x_axis
}
pub fn y_axis(self) -> Vec3 {
self.y_axis
}
pub fn z_axis(self) -> Vec3 {
self.z_axis
}
pub fn x_axis_mut(&mut self) -> &mut Vec3 {
&mut self.x_axis
}
pub fn y_axis_mut(&mut self) -> &mut Vec3 {
&mut self.y_axis
}
pub fn z_axis_mut(&mut self) -> &mut Vec3 {
&mut self.z_axis
}
}
impl Mat3 {
pub fn new(x_axis: Vec3, y_axis: Vec3, z_axis: Vec3) -> Self {
Self {
x_axis,
y_axis,
z_axis,
}
}
pub fn splat(v: f32) -> Self {
Self {
x_axis: Vec3::splat(v),
y_axis: Vec3::splat(v),
z_axis: Vec3::splat(v),
}
}
pub fn diagonal(x: f32, y: f32, z: f32) -> Self {
let x_axis = Vec3::new(x, 0.0, 0.0);
let y_axis = Vec3::new(0.0, y, 0.0);
let z_axis = Vec3::new(0.0, 0.0, z);
Self {
x_axis,
y_axis,
z_axis,
}
}
pub fn to_mat2(self) -> Mat2 {
let x_axis = self.x_axis.to_vec2();
let y_axis = self.y_axis.to_vec2();
Mat2 { x_axis, y_axis }
}
pub fn to_mat4(self, w: f32) -> Mat4 {
let x_axis = self.x_axis.to_vec4(0.0);
let y_axis = self.y_axis.to_vec4(0.0);
let z_axis = self.z_axis.to_vec4(0.0);
let w_axis = Vec4::new(0.0, 0.0, 0.0, w);
Mat4 {
x_axis,
y_axis,
z_axis,
w_axis,
}
}
}