pub struct LineSegment<S> {
    pub from: Point2D<S, UnknownUnit>,
    pub to: Point2D<S, UnknownUnit>,
}
Available on crate feature canvas only.
Expand description

A linear segment.

Fields§

§from: Point2D<S, UnknownUnit>§to: Point2D<S, UnknownUnit>

Implementations§

§

impl<S> LineSegment<S>
where S: Scalar,

pub fn sample(&self, t: S) -> Point2D<S, UnknownUnit>

Sample the segment at t (expecting t between 0 and 1).

pub fn x(&self, t: S) -> S

Sample the x coordinate of the segment at t (expecting t between 0 and 1).

pub fn y(&self, t: S) -> S

Sample the y coordinate of the segment at t (expecting t between 0 and 1).

pub fn from(&self) -> Point2D<S, UnknownUnit>

pub fn to(&self) -> Point2D<S, UnknownUnit>

pub fn solve_t_for_x(&self, x: S) -> S

pub fn solve_t_for_y(&self, y: S) -> S

pub fn solve_y_for_x(&self, x: S) -> S

pub fn solve_x_for_y(&self, y: S) -> S

pub fn flip(&self) -> LineSegment<S>

Returns an inverted version of this segment where the beginning and the end points are swapped.

pub fn split_range(&self, t_range: Range<S>) -> LineSegment<S>

Return the sub-segment inside a given range of t.

This is equivalent splitting at the range’s end points.

pub fn split(&self, t: S) -> (LineSegment<S>, LineSegment<S>)

Split this curve into two sub-segments.

pub fn before_split(&self, t: S) -> LineSegment<S>

Return the segment before the split point.

pub fn after_split(&self, t: S) -> LineSegment<S>

Return the segment after the split point.

pub fn split_at_x(&self, x: S) -> (LineSegment<S>, LineSegment<S>)

pub fn bounding_box(&self) -> Box2D<S, UnknownUnit>

Return the smallest rectangle containing this segment.

pub fn to_vector(&self) -> Vector2D<S, UnknownUnit>

Returns the vector between this segment’s from and to points.

pub fn to_line(&self) -> Line<S>

Returns the line containing this segment.

pub fn length(&self) -> S

Computes the length of this segment.

pub fn square_length(&self) -> S

Computes the squared length of this segment.

pub fn set_length(&mut self, new_length: S)

Changes the segment’s length, moving destination point.

pub fn mid_point(&mut self) -> Point2D<S, UnknownUnit>

Computes third mid-point of this segment.

pub fn translate(&mut self, by: Vector2D<S, UnknownUnit>) -> LineSegment<S>

pub fn transformed<T>(&self, transform: &T) -> LineSegment<S>
where T: Transformation<S>,

Applies the transform to this segment and returns the results.

pub fn intersection_t(&self, other: &LineSegment<S>) -> Option<(S, S)>

Computes the intersection (if any) between this segment and another one.

The result is provided in the form of the t parameter of each segment. To get the intersection point, sample one of the segments at the corresponding value.

pub fn intersection( &self, other: &LineSegment<S> ) -> Option<Point2D<S, UnknownUnit>>

pub fn line_intersection_t(&self, line: &Line<S>) -> Option<S>

pub fn line_intersection( &self, line: &Line<S> ) -> Option<Point2D<S, UnknownUnit>>

pub fn horizontal_line_intersection_t(&self, y: S) -> Option<S>

pub fn vertical_line_intersection_t(&self, x: S) -> Option<S>

pub fn horizontal_line_intersection( &self, y: S ) -> Option<Point2D<S, UnknownUnit>>

pub fn vertical_line_intersection( &self, x: S ) -> Option<Point2D<S, UnknownUnit>>

pub fn intersects(&self, other: &LineSegment<S>) -> bool

pub fn intersects_line(&self, line: &Line<S>) -> bool

pub fn overlaps_line(&self, line: &Line<S>) -> bool

pub fn overlaps_segment(&self, other: &LineSegment<S>) -> bool

pub fn contains_segment(&self, other: &LineSegment<S>) -> bool

pub fn clipped_x(&self, clip: Range<S>) -> Option<LineSegment<S>>

Horizontally clip this segment against a range of the x axis.

pub fn clipped_y(&self, clip: Range<S>) -> Option<LineSegment<S>>

Vertically clip this segment against a range of the y axis.

pub fn clipped(&self, clip: &Box2D<S, UnknownUnit>) -> Option<LineSegment<S>>

Clip this segment against a rectangle.

pub fn distance_to_point(&self, p: Point2D<S, UnknownUnit>) -> S

Computes the distance between this segment and a point.

pub fn square_distance_to_point(&self, p: Point2D<S, UnknownUnit>) -> S

Computes the squared distance between this segment and a point.

Can be useful to save a square root and a division when comparing against a distance that can be squared.

pub fn closest_point( &self, p: Point2D<S, UnknownUnit> ) -> Point2D<S, UnknownUnit>

Computes the closest point on this segment to p.

pub fn to_f32(&self) -> LineSegment<f32>

pub fn to_f64(&self) -> LineSegment<f64>

Trait Implementations§

§

impl<S> Clone for LineSegment<S>
where S: Clone,

§

fn clone(&self) -> LineSegment<S>

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
§

impl<S> Debug for LineSegment<S>
where S: Debug,

§

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

Formats the value using the given formatter. Read more
§

impl<S> PartialEq for LineSegment<S>
where S: PartialEq,

§

fn eq(&self, other: &LineSegment<S>) -> 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.
§

impl<S> Segment for LineSegment<S>
where S: Scalar,

§

type Scalar = S

§

fn from(&self) -> Point2D<S, UnknownUnit>

Start of the curve.
§

fn to(&self) -> Point2D<S, UnknownUnit>

End of the curve.
§

fn sample(&self, t: S) -> Point2D<S, UnknownUnit>

Sample the curve at t (expecting t between 0 and 1).
§

fn x(&self, t: S) -> S

Sample x at t (expecting t between 0 and 1).
§

fn y(&self, t: S) -> S

Sample y at t (expecting t between 0 and 1).
§

fn derivative(&self, _t: S) -> Vector2D<S, UnknownUnit>

Sample the derivative at t (expecting t between 0 and 1).
§

fn dx(&self, _t: S) -> S

Sample x derivative at t (expecting t between 0 and 1).
§

fn dy(&self, _t: S) -> S

Sample y derivative at t (expecting t between 0 and 1).
§

fn split(&self, t: S) -> (LineSegment<S>, LineSegment<S>)

Split this curve into two sub-curves.
§

fn before_split(&self, t: S) -> LineSegment<S>

Return the curve before the split point.
§

fn after_split(&self, t: S) -> LineSegment<S>

Return the curve after the split point.
§

fn split_range(&self, t_range: Range<S>) -> LineSegment<S>

Return the curve inside a given range of t. Read more
§

fn flip(&self) -> LineSegment<S>

Swap the direction of the segment.
§

fn approximate_length(&self, _tolerance: S) -> S

Compute the length of the segment using a flattened approximation.
§

fn for_each_flattened_with_t( &self, _tolerance: <LineSegment<S> as Segment>::Scalar, callback: &mut dyn FnMut(&LineSegment<S>, Range<S>) )

Approximates the curve with sequence of line segments. Read more
§

impl<S> Copy for LineSegment<S>
where S: Copy,

§

impl<S> StructuralPartialEq for LineSegment<S>

Auto Trait Implementations§

§

impl<S> RefUnwindSafe for LineSegment<S>
where S: RefUnwindSafe,

§

impl<S> Send for LineSegment<S>
where S: Send,

§

impl<S> Sync for LineSegment<S>
where S: Sync,

§

impl<S> Unpin for LineSegment<S>
where S: Unpin,

§

impl<S> UnwindSafe for LineSegment<S>
where S: UnwindSafe,

Blanket Implementations§

source§

impl<S, D, Swp, Dwp, T> AdaptInto<D, Swp, Dwp, T> for S
where 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) -> D
where M: TransformMatrix<T>,

Convert the source color to the destination color using the specified method.
source§

fn adapt_into(self) -> D

Convert the source color to the destination color using the bradford method by default.
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, C> ArraysFrom<C> for T
where C: IntoArrays<T>,

source§

fn arrays_from(colors: C) -> T

Cast a collection of colors into a collection of arrays.
source§

impl<T, C> ArraysInto<C> for T
where C: FromArrays<T>,

source§

fn arrays_into(self) -> C

Cast this collection of arrays into a collection of colors.
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, C> ComponentsFrom<C> for T
where C: IntoComponents<T>,

source§

fn components_from(colors: C) -> T

Cast a collection of colors into a collection of color components.
§

impl<T> Downcast<T> for T

§

fn downcast(&self) -> &T

§

impl<T> Downcast for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

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

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> FromAngle<T> for T

source§

fn from_angle(angle: T) -> T

Performs a conversion from angle.
source§

impl<T, U> FromStimulus<U> for T
where U: IntoStimulus<T>,

source§

fn from_stimulus(other: U) -> T

Converts other into Self, while performing the appropriate scaling, rounding and clamping.
§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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, U> IntoAngle<U> for T
where U: FromAngle<T>,

source§

fn into_angle(self) -> U

Performs a conversion into T.
source§

impl<T, U> IntoColor<U> for T
where U: FromColor<T>,

source§

fn into_color(self) -> U

Convert into T with values clamped to the color defined bounds Read more
source§

impl<T, U> IntoColorUnclamped<U> for T
where U: FromColorUnclamped<T>,

source§

fn into_color_unclamped(self) -> U

Convert into T. The resulting color might be invalid in its color space Read more
source§

impl<T> IntoEither for T

source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
source§

impl<T> IntoStimulus<T> for T

source§

fn into_stimulus(self) -> T

Converts self into T, while performing the appropriate scaling, rounding and clamping.
§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same for T

§

type Output = T

Should always be Self
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, C> TryComponentsInto<C> for T
where C: TryFromComponents<T>,

§

type Error = <C as TryFromComponents<T>>::Error

The error for when try_into_colors fails to cast.
source§

fn try_components_into(self) -> Result<C, <T as TryComponentsInto<C>>::Error>

Try to cast this collection of color components into a collection of colors. 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.
source§

impl<T, U> TryIntoColor<U> for T
where U: TryFromColor<T>,

source§

fn try_into_color(self) -> Result<U, OutOfBounds<U>>

Convert into T, returning ok if the color is inside of its defined range, otherwise an OutOfBounds error is returned which contains the unclamped color. Read more
source§

impl<C, U> UintsFrom<C> for U
where C: IntoUints<U>,

source§

fn uints_from(colors: C) -> U

Cast a collection of colors into a collection of unsigned integers.
source§

impl<C, U> UintsInto<C> for U
where C: FromUints<U>,

source§

fn uints_into(self) -> C

Cast this collection of unsigned integers into a collection of colors.
§

impl<T> Upcast<T> for T

§

fn upcast(&self) -> Option<&T>

§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
source§

impl<T> MaybeSend for T
where T: Send,

source§

impl<T> MaybeSync for T
where T: Sync,

§

impl<T> WasmNotSend for T
where T: Send,

§

impl<T> WasmNotSendSync for T

§

impl<T> WasmNotSync for T
where T: Sync,