emath

Struct TSTransform

Source
#[repr(C)]
pub struct TSTransform { pub scaling: f32, pub translation: Vec2, }
Expand description

Linearly transforms positions via a translation, then a scaling.

TSTransform first scales points with the scaling origin at 0, 0 (the top left corner), then translates them.

Fields§

§scaling: f32

Scaling applied first, scaled around (0, 0).

§translation: Vec2

Translation amount, applied after scaling.

Implementations§

Source§

impl TSTransform

Source

pub const IDENTITY: Self = _

Source

pub fn new(translation: Vec2, scaling: f32) -> Self

Creates a new translation that first scales points around (0, 0), then translates them.

Source

pub fn from_translation(translation: Vec2) -> Self

Source

pub fn from_scaling(scaling: f32) -> Self

Source

pub fn inverse(&self) -> Self

Inverts the transform.

let p1 = pos2(2.0, 3.0);
let p2 = pos2(12.0, 5.0);
let ts = TSTransform::new(vec2(2.0, 3.0), 2.0);
let inv = ts.inverse();
assert_eq!(inv.mul_pos(p1), pos2(0.0, 0.0));
assert_eq!(inv.mul_pos(p2), pos2(5.0, 1.0));

assert_eq!(ts.inverse().inverse(), ts);
Source

pub fn mul_pos(&self, pos: Pos2) -> Pos2

Transforms the given coordinate.

let p1 = pos2(0.0, 0.0);
let p2 = pos2(5.0, 1.0);
let ts = TSTransform::new(vec2(2.0, 3.0), 2.0);
assert_eq!(ts.mul_pos(p1), pos2(2.0, 3.0));
assert_eq!(ts.mul_pos(p2), pos2(12.0, 5.0));
Source

pub fn mul_rect(&self, rect: Rect) -> Rect

Transforms the given rectangle.

let rect = Rect::from_min_max(pos2(5.0, 5.0), pos2(15.0, 10.0));
let ts = TSTransform::new(vec2(1.0, 0.0), 3.0);
let transformed = ts.mul_rect(rect);
assert_eq!(transformed.min, pos2(16.0, 15.0));
assert_eq!(transformed.max, pos2(46.0, 30.0));

Trait Implementations§

Source§

impl Clone for TSTransform

Source§

fn clone(&self) -> TSTransform

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 TSTransform

Source§

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

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

impl Default for TSTransform

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for TSTransform

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Mul<Pos2> for TSTransform

Transforms the position.

Source§

type Output = Pos2

The resulting type after applying the * operator.
Source§

fn mul(self, pos: Pos2) -> Pos2

Performs the * operation. Read more
Source§

impl Mul<Rect> for TSTransform

Transforms the rectangle.

Source§

type Output = Rect

The resulting type after applying the * operator.
Source§

fn mul(self, rect: Rect) -> Rect

Performs the * operation. Read more
Source§

impl Mul for TSTransform

Source§

fn mul(self, rhs: Self) -> Self::Output

Applies the right hand side transform, then the left hand side.

let ts1 = TSTransform::new(vec2(1.0, 0.0), 2.0);
let ts2 = TSTransform::new(vec2(-1.0, -1.0), 3.0);
let ts_combined = TSTransform::new(vec2(2.0, -1.0), 6.0);
assert_eq!(ts_combined, ts2 * ts1);
Source§

type Output = TSTransform

The resulting type after applying the * operator.
Source§

impl PartialEq for TSTransform

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for TSTransform

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl Zeroable for TSTransform

Source§

fn zeroed() -> Self

Source§

impl Copy for TSTransform

Source§

impl Eq for TSTransform

Source§

impl Pod for TSTransform

Source§

impl StructuralPartialEq for TSTransform

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> CheckedBitPattern for T
where T: AnyBitPattern,

Source§

type Bits = T

Self must have the same layout as the specified Bits except for the possible invalid bit patterns being checked during is_valid_bit_pattern.
Source§

fn is_valid_bit_pattern(_bits: &T) -> bool

If this function returns true, then it must be valid to reinterpret bits as &Self.
Source§

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

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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,

Source§

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>,

Source§

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>,

Source§

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.
Source§

impl<T> AnyBitPattern for T
where T: Pod,

Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

Source§

impl<T> NoUninit for T
where T: Pod,