#[repr(C)]pub struct Translation2D<T, Src, Dst> {
pub x: T,
pub y: T,
/* private fields */
}Expand description
A 2d transformation from a space to another that can only express translations.
The main benefit of this type over a Vector2D is the ability to cast
between source and destination spaces.
Example:
use euclid::{Translation2D, Point2D, point2};
struct ParentSpace;
struct ChildSpace;
type ScrollOffset = Translation2D<i32, ParentSpace, ChildSpace>;
type ParentPoint = Point2D<i32, ParentSpace>;
type ChildPoint = Point2D<i32, ChildSpace>;
let scrolling = ScrollOffset::new(0, 100);
let p1: ParentPoint = point2(0, 0);
let p2: ChildPoint = scrolling.transform_point(p1);Fields§
§x: T§y: TImplementations§
Source§impl<T, Src, Dst> Translation2D<T, Src, Dst>
impl<T, Src, Dst> Translation2D<T, Src, Dst>
pub const fn new(x: T, y: T) -> Translation2D<T, Src, Dst>
pub fn splat(v: T) -> Translation2D<T, Src, Dst>where
T: Clone,
Sourcepub fn identity() -> Translation2D<T, Src, Dst>where
T: Zero,
pub fn identity() -> Translation2D<T, Src, Dst>where
T: Zero,
Creates no-op translation (both x and y is zero()).
Sourcepub fn is_identity(&self) -> bool
pub fn is_identity(&self) -> bool
Check if translation does nothing (both x and y is zero()).
use euclid::default::Translation2D;
assert_eq!(Translation2D::<f32>::identity().is_identity(), true);
assert_eq!(Translation2D::new(0, 0).is_identity(), true);
assert_eq!(Translation2D::new(1, 0).is_identity(), false);
assert_eq!(Translation2D::new(0, 1).is_identity(), false);Sourcepub fn transform_size(&self, s: Size2D<T, Src>) -> Size2D<T, Dst>
pub fn transform_size(&self, s: Size2D<T, Src>) -> Size2D<T, Dst>
No-op, just cast the unit.
Source§impl<T, Src, Dst> Translation2D<T, Src, Dst>where
T: Copy,
impl<T, Src, Dst> Translation2D<T, Src, Dst>where
T: Copy,
Sourcepub fn to_untyped(&self) -> Translation2D<T, UnknownUnit, UnknownUnit>
pub fn to_untyped(&self) -> Translation2D<T, UnknownUnit, UnknownUnit>
Drop the units, preserving only the numeric value.
Sourcepub fn from_untyped(
t: &Translation2D<T, UnknownUnit, UnknownUnit>,
) -> Translation2D<T, Src, Dst>
pub fn from_untyped( t: &Translation2D<T, UnknownUnit, UnknownUnit>, ) -> Translation2D<T, Src, Dst>
Tag a unitless value with units.
Sourcepub fn to_transform(&self) -> Transform2D<T, Src, Dst>
pub fn to_transform(&self) -> Transform2D<T, Src, Dst>
Returns the matrix representation of this translation.
Sourcepub fn transform_point(
&self,
p: Point2D<T, Src>,
) -> Point2D<<T as Add>::Output, Dst>where
T: Add,
pub fn transform_point(
&self,
p: Point2D<T, Src>,
) -> Point2D<<T as Add>::Output, Dst>where
T: Add,
Translate a point and cast its unit.
Sourcepub fn transform_rect(&self, r: &Rect<T, Src>) -> Rect<<T as Add>::Output, Dst>where
T: Add<Output = T>,
pub fn transform_rect(&self, r: &Rect<T, Src>) -> Rect<<T as Add>::Output, Dst>where
T: Add<Output = T>,
Translate a rectangle and cast its unit.
Source§impl<T, Src, Dst> Translation2D<T, Src, Dst>
impl<T, Src, Dst> Translation2D<T, Src, Dst>
Sourcepub fn cast<NewT>(self) -> Translation2D<NewT, Src, Dst>where
NewT: NumCast,
pub fn cast<NewT>(self) -> Translation2D<NewT, Src, Dst>where
NewT: NumCast,
Cast from one numeric representation to another, preserving the units.
When casting from floating vector to integer coordinates, the decimals are truncated
as one would expect from a simple cast, but this behavior does not always make sense
geometrically. Consider using round(), ceil() or floor() before casting.
Sourcepub fn try_cast<NewT>(self) -> Option<Translation2D<NewT, Src, Dst>>where
NewT: NumCast,
pub fn try_cast<NewT>(self) -> Option<Translation2D<NewT, Src, Dst>>where
NewT: NumCast,
Fallible cast from one numeric representation to another, preserving the units.
When casting from floating vector to integer coordinates, the decimals are truncated
as one would expect from a simple cast, but this behavior does not always make sense
geometrically. Consider using round(), ceil() or floor() before casting.
Sourcepub fn to_f32(self) -> Translation2D<f32, Src, Dst>
pub fn to_f32(self) -> Translation2D<f32, Src, Dst>
Cast into an f32 vector.
Sourcepub fn to_f64(self) -> Translation2D<f64, Src, Dst>
pub fn to_f64(self) -> Translation2D<f64, Src, Dst>
Cast into an f64 vector.
Sourcepub fn to_usize(self) -> Translation2D<usize, Src, Dst>
pub fn to_usize(self) -> Translation2D<usize, Src, Dst>
Cast into an usize vector, truncating decimals if any.
When casting from floating vector vectors, it is worth considering whether
to round(), ceil() or floor() before the cast in order to obtain
the desired conversion behavior.
Sourcepub fn to_u32(self) -> Translation2D<u32, Src, Dst>
pub fn to_u32(self) -> Translation2D<u32, Src, Dst>
Cast into an u32 vector, truncating decimals if any.
When casting from floating vector vectors, it is worth considering whether
to round(), ceil() or floor() before the cast in order to obtain
the desired conversion behavior.
Sourcepub fn to_i32(self) -> Translation2D<i32, Src, Dst>
pub fn to_i32(self) -> Translation2D<i32, Src, Dst>
Cast into an i32 vector, truncating decimals if any.
When casting from floating vector vectors, it is worth considering whether
to round(), ceil() or floor() before the cast in order to obtain
the desired conversion behavior.
Sourcepub fn to_i64(self) -> Translation2D<i64, Src, Dst>
pub fn to_i64(self) -> Translation2D<i64, Src, Dst>
Cast into an i64 vector, truncating decimals if any.
When casting from floating vector vectors, it is worth considering whether
to round(), ceil() or floor() before the cast in order to obtain
the desired conversion behavior.
Trait Implementations§
Source§impl<T, Src, Dst1, Dst2> Add<Translation2D<T, Dst1, Dst2>> for Translation2D<T, Src, Dst1>where
T: Add,
impl<T, Src, Dst1, Dst2> Add<Translation2D<T, Dst1, Dst2>> for Translation2D<T, Src, Dst1>where
T: Add,
Source§type Output = Translation2D<<T as Add>::Output, Src, Dst2>
type Output = Translation2D<<T as Add>::Output, Src, Dst2>
+ operator.Source§fn add(
self,
other: Translation2D<T, Dst1, Dst2>,
) -> <Translation2D<T, Src, Dst1> as Add<Translation2D<T, Dst1, Dst2>>>::Output
fn add( self, other: Translation2D<T, Dst1, Dst2>, ) -> <Translation2D<T, Src, Dst1> as Add<Translation2D<T, Dst1, Dst2>>>::Output
+ operation. Read moreSource§impl<T, Src, Dst> AddAssign<Translation2D<T, Dst, Dst>> for Translation2D<T, Src, Dst>where
T: AddAssign,
impl<T, Src, Dst> AddAssign<Translation2D<T, Dst, Dst>> for Translation2D<T, Src, Dst>where
T: AddAssign,
Source§fn add_assign(&mut self, other: Translation2D<T, Dst, Dst>)
fn add_assign(&mut self, other: Translation2D<T, Dst, Dst>)
+= operation. Read moreSource§impl<T, Src, Dst> Clone for Translation2D<T, Src, Dst>where
T: Clone,
impl<T, Src, Dst> Clone for Translation2D<T, Src, Dst>where
T: Clone,
Source§fn clone(&self) -> Translation2D<T, Src, Dst>
fn clone(&self) -> Translation2D<T, Src, Dst>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl<T, Src, Dst> Debug for Translation2D<T, Src, Dst>where
T: Debug,
impl<T, Src, Dst> Debug for Translation2D<T, Src, Dst>where
T: Debug,
Source§impl<T, Src, Dst> Default for Translation2D<T, Src, Dst>where
T: Zero,
impl<T, Src, Dst> Default for Translation2D<T, Src, Dst>where
T: Zero,
Source§fn default() -> Translation2D<T, Src, Dst>
fn default() -> Translation2D<T, Src, Dst>
Source§impl<T, Src, Dst> From<Translation2D<T, Src, Dst>> for Transform2D<T, Src, Dst>
impl<T, Src, Dst> From<Translation2D<T, Src, Dst>> for Transform2D<T, Src, Dst>
Source§fn from(t: Translation2D<T, Src, Dst>) -> Transform2D<T, Src, Dst>
fn from(t: Translation2D<T, Src, Dst>) -> Transform2D<T, Src, Dst>
Source§impl<T, Src, Dst> From<Translation2D<T, Src, Dst>> for Vector2D<T, Src>
impl<T, Src, Dst> From<Translation2D<T, Src, Dst>> for Vector2D<T, Src>
Source§fn from(t: Translation2D<T, Src, Dst>) -> Vector2D<T, Src>
fn from(t: Translation2D<T, Src, Dst>) -> Vector2D<T, Src>
Source§impl<T, Src, Dst> From<Vector2D<T, Src>> for Translation2D<T, Src, Dst>
impl<T, Src, Dst> From<Vector2D<T, Src>> for Translation2D<T, Src, Dst>
Source§fn from(v: Vector2D<T, Src>) -> Translation2D<T, Src, Dst>
fn from(v: Vector2D<T, Src>) -> Translation2D<T, Src, Dst>
Source§impl<T, Src, Dst> Hash for Translation2D<T, Src, Dst>where
T: Hash,
impl<T, Src, Dst> Hash for Translation2D<T, Src, Dst>where
T: Hash,
Source§impl<T, Src, Dst> PartialEq for Translation2D<T, Src, Dst>where
T: PartialEq,
impl<T, Src, Dst> PartialEq for Translation2D<T, Src, Dst>where
T: PartialEq,
Source§impl<T, Src, Dst1, Dst2> Sub<Translation2D<T, Dst1, Dst2>> for Translation2D<T, Src, Dst2>where
T: Sub,
impl<T, Src, Dst1, Dst2> Sub<Translation2D<T, Dst1, Dst2>> for Translation2D<T, Src, Dst2>where
T: Sub,
Source§type Output = Translation2D<<T as Sub>::Output, Src, Dst1>
type Output = Translation2D<<T as Sub>::Output, Src, Dst1>
- operator.Source§fn sub(
self,
other: Translation2D<T, Dst1, Dst2>,
) -> <Translation2D<T, Src, Dst2> as Sub<Translation2D<T, Dst1, Dst2>>>::Output
fn sub( self, other: Translation2D<T, Dst1, Dst2>, ) -> <Translation2D<T, Src, Dst2> as Sub<Translation2D<T, Dst1, Dst2>>>::Output
- operation. Read moreSource§impl<T, Src, Dst> SubAssign<Translation2D<T, Dst, Dst>> for Translation2D<T, Src, Dst>where
T: SubAssign,
impl<T, Src, Dst> SubAssign<Translation2D<T, Dst, Dst>> for Translation2D<T, Src, Dst>where
T: SubAssign,
Source§fn sub_assign(&mut self, other: Translation2D<T, Dst, Dst>)
fn sub_assign(&mut self, other: Translation2D<T, Dst, Dst>)
-= operation. Read moreSource§impl<S> Transformation<S> for Translation2D<S, UnknownUnit, UnknownUnit>where
S: Scalar,
impl<S> Transformation<S> for Translation2D<S, UnknownUnit, UnknownUnit>where
S: Scalar,
fn transform_point(&self, p: Point2D<S, UnknownUnit>) -> Point2D<S, UnknownUnit>
fn transform_vector( &self, v: Vector2D<S, UnknownUnit>, ) -> Vector2D<S, UnknownUnit>
impl<T, Src, Dst> Copy for Translation2D<T, Src, Dst>where
T: Copy,
impl<T, Src, Dst> Eq for Translation2D<T, Src, Dst>where
T: Eq,
Auto Trait Implementations§
impl<T, Src, Dst> Freeze for Translation2D<T, Src, Dst>where
T: Freeze,
impl<T, Src, Dst> RefUnwindSafe for Translation2D<T, Src, Dst>
impl<T, Src, Dst> Send for Translation2D<T, Src, Dst>
impl<T, Src, Dst> Sync for Translation2D<T, Src, Dst>
impl<T, Src, Dst> Unpin for Translation2D<T, Src, Dst>
impl<T, Src, Dst> UnwindSafe for Translation2D<T, Src, Dst>
Blanket Implementations§
Source§impl<S, D, Swp, Dwp, T> AdaptInto<D, Swp, Dwp, T> for Swhere
T: Real + Zero + Arithmetics + Clone,
Swp: WhitePoint<T>,
Dwp: WhitePoint<T>,
D: AdaptFrom<S, Swp, Dwp, T>,
impl<S, D, Swp, Dwp, T> AdaptInto<D, Swp, Dwp, T> for Swhere
T: Real + Zero + Arithmetics + Clone,
Swp: WhitePoint<T>,
Dwp: WhitePoint<T>,
D: AdaptFrom<S, Swp, Dwp, T>,
Source§fn adapt_into_using<M>(self, method: M) -> Dwhere
M: TransformMatrix<T>,
fn adapt_into_using<M>(self, method: M) -> Dwhere
M: TransformMatrix<T>,
Source§fn adapt_into(self) -> D
fn adapt_into(self) -> D
Source§impl<T, Res> Apply<Res> for Twhere
T: ?Sized,
impl<T, Res> Apply<Res> for Twhere
T: ?Sized,
Source§impl<T, C> ArraysFrom<C> for Twhere
C: IntoArrays<T>,
impl<T, C> ArraysFrom<C> for Twhere
C: IntoArrays<T>,
Source§fn arrays_from(colors: C) -> T
fn arrays_from(colors: C) -> T
Source§impl<T, C> ArraysInto<C> for Twhere
C: FromArrays<T>,
impl<T, C> ArraysInto<C> for Twhere
C: FromArrays<T>,
Source§fn arrays_into(self) -> C
fn arrays_into(self) -> C
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<WpParam, T, U> Cam16IntoUnclamped<WpParam, T> for Uwhere
T: FromCam16Unclamped<WpParam, U>,
impl<WpParam, T, U> Cam16IntoUnclamped<WpParam, T> for Uwhere
T: FromCam16Unclamped<WpParam, U>,
Source§type Scalar = <T as FromCam16Unclamped<WpParam, U>>::Scalar
type Scalar = <T as FromCam16Unclamped<WpParam, U>>::Scalar
parameters when converting.Source§fn cam16_into_unclamped(
self,
parameters: BakedParameters<WpParam, <U as Cam16IntoUnclamped<WpParam, T>>::Scalar>,
) -> T
fn cam16_into_unclamped( self, parameters: BakedParameters<WpParam, <U as Cam16IntoUnclamped<WpParam, T>>::Scalar>, ) -> T
self into C, using the provided parameters.Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T, C> ComponentsFrom<C> for Twhere
C: IntoComponents<T>,
impl<T, C> ComponentsFrom<C> for Twhere
C: IntoComponents<T>,
Source§fn components_from(colors: C) -> T
fn components_from(colors: C) -> T
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.Source§impl<T> FromAngle<T> for T
impl<T> FromAngle<T> for T
Source§fn from_angle(angle: T) -> T
fn from_angle(angle: T) -> T
angle.Source§impl<T, U> FromStimulus<U> for Twhere
U: IntoStimulus<T>,
impl<T, U> FromStimulus<U> for Twhere
U: IntoStimulus<T>,
Source§fn from_stimulus(other: U) -> T
fn from_stimulus(other: U) -> T
other into Self, while performing the appropriate scaling,
rounding and clamping.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T, U> IntoAngle<U> for Twhere
U: FromAngle<T>,
impl<T, U> IntoAngle<U> for Twhere
U: FromAngle<T>,
Source§fn into_angle(self) -> U
fn into_angle(self) -> U
T.Source§impl<WpParam, T, U> IntoCam16Unclamped<WpParam, T> for Uwhere
T: Cam16FromUnclamped<WpParam, U>,
impl<WpParam, T, U> IntoCam16Unclamped<WpParam, T> for Uwhere
T: Cam16FromUnclamped<WpParam, U>,
Source§type Scalar = <T as Cam16FromUnclamped<WpParam, U>>::Scalar
type Scalar = <T as Cam16FromUnclamped<WpParam, U>>::Scalar
parameters when converting.Source§fn into_cam16_unclamped(
self,
parameters: BakedParameters<WpParam, <U as IntoCam16Unclamped<WpParam, T>>::Scalar>,
) -> T
fn into_cam16_unclamped( self, parameters: BakedParameters<WpParam, <U as IntoCam16Unclamped<WpParam, T>>::Scalar>, ) -> T
self into C, using the provided parameters.Source§impl<T, U> IntoColor<U> for Twhere
U: FromColor<T>,
impl<T, U> IntoColor<U> for Twhere
U: FromColor<T>,
Source§fn into_color(self) -> U
fn into_color(self) -> U
Source§impl<T, U> IntoColorUnclamped<U> for Twhere
U: FromColorUnclamped<T>,
impl<T, U> IntoColorUnclamped<U> for Twhere
U: FromColorUnclamped<T>,
Source§fn into_color_unclamped(self) -> U
fn into_color_unclamped(self) -> U
Source§impl<T> IntoStimulus<T> for T
impl<T> IntoStimulus<T> for T
Source§fn into_stimulus(self) -> T
fn into_stimulus(self) -> T
self into T, while performing the appropriate scaling,
rounding and clamping.Source§impl<T, C> TryComponentsInto<C> for Twhere
C: TryFromComponents<T>,
impl<T, C> TryComponentsInto<C> for Twhere
C: TryFromComponents<T>,
Source§type Error = <C as TryFromComponents<T>>::Error
type Error = <C as TryFromComponents<T>>::Error
try_into_colors fails to cast.Source§fn try_components_into(self) -> Result<C, <T as TryComponentsInto<C>>::Error>
fn try_components_into(self) -> Result<C, <T as TryComponentsInto<C>>::Error>
Source§impl<T, U> TryIntoColor<U> for Twhere
U: TryFromColor<T>,
impl<T, U> TryIntoColor<U> for Twhere
U: TryFromColor<T>,
Source§fn try_into_color(self) -> Result<U, OutOfBounds<U>>
fn try_into_color(self) -> Result<U, OutOfBounds<U>>
OutOfBounds error is returned which contains
the unclamped color. Read more