geometry::transform

Struct Transformation

Source
pub struct Transformation { /* private fields */ }
Expand description

A transformation representing a Manhattan translation, rotation, and/or reflection of geometry.

This object does not support scaling of geometry, and as such all transformation matrices should be unitary.

Implementations§

Source§

impl Transformation

Source

pub fn identity() -> Self

Returns the identity transform, leaving any transformed object unmodified.

Source

pub fn translate(x: i64, y: i64) -> Self

Returns a translation by (x,y).

Source

pub fn translate_ref(&self, x: i64, y: i64) -> Self

Translates the current transformation by (x, y), returning a new Transformation.

Source

pub fn rotate(angle: Rotation) -> Self

Returns a rotatation by angle degrees.

Source

pub fn reflect_vert() -> Self

Returns a reflection about the x-axis.

Source

pub fn builder() -> TransformationBuilder

Returns a new TransformationBuilder.

Source

pub fn from_offset(offset: Point) -> Self

Creates a transform from only an offset.

The resulting transformation will apply only a translation (i.e. no rotations/reflections).

Source

pub fn from_offset_and_orientation( offset: Point, orientation: impl Into<Orientation>, ) -> Self

Creates a transform from an offset and Orientation.

Source

pub fn from_opts(offset: Point, reflect_vert: bool, angle: Rotation) -> Self

Creates a transform from an offset, angle, and a bool indicating whether or not to reflect vertically.

Source

pub fn cascade(parent: Transformation, child: Transformation) -> Transformation

Create a new Transformation that is the cascade of parent and child.

“Parents” and “children” refer to typical layout-instance hierarchies, in which each layer of instance has a nested set of transformations relative to its top-level parent.

Note this operation is not commutative. For example the set of transformations:

  • (a) Reflect vertically, then
  • (b) Translate by (1,1)
  • (c) Place a point at (local coordinate) (1,1)

Lands said point at (2,-2) in top-level space, whereas reversing the order of (a) and (b) lands it at (2,0).

Source

pub fn offset_point(&self) -> Point

The point representing the translation of this transformation.

Source

pub fn orientation(&self) -> Orientation

Returns an Orientation corresponding to this transformation.

Source

pub fn inv(&self) -> Transformation

Returns the inverse Transformation of self.

§Examples
use geometry::transform::Transformation;
use geometry::transform::Rotation;

let trans = Transformation::cascade(
    Transformation::rotate(Rotation::R90),
    Transformation::translate(5, 10),
);
let inv = trans.inv();

assert_eq!(Transformation::cascade(inv, trans), Transformation::identity());
assert_eq!(Transformation::cascade(trans, inv), Transformation::identity());

Trait Implementations§

Source§

impl Clone for Transformation

Source§

fn clone(&self) -> Transformation

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 Transformation

Source§

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

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

impl Default for Transformation

Source§

fn default() -> Self

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

impl<'de> Deserialize<'de> for Transformation

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<T> From<T> for Transformation
where T: Into<Orientation>,

Source§

fn from(value: T) -> Self

Converts to this type from the input type.
Source§

impl Hash for Transformation

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl PartialEq for Transformation

Source§

fn eq(&self, other: &Transformation) -> 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 Transformation

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 Copy for Transformation

Source§

impl Eq for Transformation

Source§

impl StructuralPartialEq for Transformation

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> 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> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,