Struct ssbh_lib::Matrix4x4

source ·
pub struct Matrix4x4 {
    pub col1: Vector4,
    pub col2: Vector4,
    pub col3: Vector4,
    pub col4: Vector4,
}
Expand description

A column-major 4x4 matrix of contiguous floats.

Fields§

§col1: Vector4§col2: Vector4§col3: Vector4§col4: Vector4

Implementations§

source§

impl Matrix4x4

source

pub fn identity() -> Matrix4x4

The identity transformation matrix.

use ssbh_lib::{Vector4, Matrix4x4};

let m = Matrix4x4::identity();
assert_eq!(Vector4::new(1f32, 0f32, 0f32, 0f32), m.col1);
assert_eq!(Vector4::new(0f32, 1f32, 0f32, 0f32), m.col2);
assert_eq!(Vector4::new(0f32, 0f32, 1f32, 0f32), m.col3);
assert_eq!(Vector4::new(0f32, 0f32, 0f32, 1f32), m.col4);
source

pub fn to_cols_array(&self) -> [[f32; 4]; 4]

Converts the elements to a 2d array in column-major order.

use ssbh_lib::{Vector4, Matrix4x4};

let m = Matrix4x4 {
    col1: Vector4::new(1f32, 2f32, 3f32, 4f32),
    col2: Vector4::new(5f32, 6f32, 7f32, 8f32),
    col3: Vector4::new(9f32, 10f32, 11f32, 12f32),
    col4: Vector4::new(13f32, 14f32, 15f32, 16f32),
};

assert_eq!(
    [
        [1f32, 2f32, 3f32, 4f32],
        [5f32, 6f32, 7f32, 8f32],
        [9f32, 10f32, 11f32, 12f32],
        [13f32, 14f32, 15f32, 16f32],
    ],
    m.to_cols_array(),
);
source

pub fn from_cols_array(cols: &[[f32; 4]; 4]) -> Matrix4x4

Creates the matrix from a 2d array in column-major order.

let elements = [
    [1f32, 2f32, 3f32, 4f32],
    [5f32, 6f32, 7f32, 8f32],
    [9f32, 10f32, 11f32, 12f32],
    [13f32, 14f32, 15f32, 16f32],
];
let m = Matrix4x4::from_cols_array(&elements);
assert_eq!(elements, m.to_cols_array());

Trait Implementations§

source§

impl BinRead for Matrix4x4

§

type Args<'__binrw_generated_args_lifetime> = ()

The type used for the args parameter of read_args() and read_options(). Read more
source§

fn read_options<R: Read + Seek>( __binrw_generated_var_reader: &mut R, __binrw_generated_var_endian: Endian, __binrw_generated_var_arguments: Self::Args<'_> ) -> BinResult<Self>

Read Self from the reader using the given Endian and arguments. Read more
source§

fn read_be<R>(reader: &mut R) -> Result<Self, Error>
where R: Read + Seek, Self::Args<'a>: for<'a> Required,

Read Self from the reader using default arguments and assuming big-endian byte order. Read more
source§

fn read_le<R>(reader: &mut R) -> Result<Self, Error>
where R: Read + Seek, Self::Args<'a>: for<'a> Required,

Read Self from the reader using default arguments and assuming little-endian byte order. Read more
source§

fn read_ne<R>(reader: &mut R) -> Result<Self, Error>
where R: Read + Seek, Self::Args<'a>: for<'a> Required,

Read T from the reader assuming native-endian byte order. Read more
source§

fn read_be_args<R>(reader: &mut R, args: Self::Args<'_>) -> Result<Self, Error>
where R: Read + Seek,

Read Self from the reader, assuming big-endian byte order, using the given arguments. Read more
source§

fn read_le_args<R>(reader: &mut R, args: Self::Args<'_>) -> Result<Self, Error>
where R: Read + Seek,

Read Self from the reader, assuming little-endian byte order, using the given arguments. Read more
source§

fn read_ne_args<R>(reader: &mut R, args: Self::Args<'_>) -> Result<Self, Error>
where R: Read + Seek,

Read T from the reader, assuming native-endian byte order, using the given arguments. Read more
source§

impl Clone for Matrix4x4

source§

fn clone(&self) -> Matrix4x4

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Matrix4x4

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl PartialEq for Matrix4x4

source§

fn eq(&self, other: &Matrix4x4) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl SsbhWrite for Matrix4x4

source§

fn ssbh_write<W: Write + Seek>( &self, writer: &mut W, data_ptr: &mut u64 ) -> Result<()>

Writes the byte representation of self to writer. data_ptr is assumed to be the absolute offset where the next data stored behind an offset will be written. Struct that contains no offsets as fields can skip updating data_ptr. Read more
source§

fn size_in_bytes(&self) -> u64

The offset in bytes between successive elements in an array of this type. This should include any alignment or padding.
source§

fn alignment_in_bytes() -> u64

The alignment for pointers of this type, which is useful for offset calculations.
source§

fn write<W>(&self, writer: &mut W) -> Result<(), Error>
where W: Write + Seek,

Writes the byte representation of self to writer. This is a convenience method for ssbh_write that handles initializing the data pointer.
source§

impl Copy for Matrix4x4

source§

impl StructuralPartialEq for Matrix4x4

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.