Enum druid::piet::kurbo::PathSeg

pub enum PathSeg {
    Line(Line),
    Quad(QuadBez),
    Cubic(CubicBez),
}
Expand description

A segment of a Bézier path.

Variants§

§

Line(Line)

A line segment.

§

Quad(QuadBez)

A quadratic bezier segment.

§

Cubic(CubicBez)

A cubic bezier segment.

Implementations§

§

impl PathSeg

pub fn reverse(&self) -> PathSeg

Returns a new PathSeg describing the same path as self, but with the points reversed.

pub fn to_cubic(&self) -> CubicBez

Convert this segment to a cubic bezier.

pub fn intersect_line(&self, line: Line) -> ArrayVec<LineIntersection, 3>

Compute intersections against a line.

Returns a vector of the intersections. For each intersection, the t value of the segment and line are given.

Note: This test is designed to be inclusive of points near the endpoints of the segment. This is so that testing a line against multiple contiguous segments of a path will be guaranteed to catch at least one of them. In such cases, use higher level logic to coalesce the hits (the t value may be slightly outside the range of 0..1).

Examples
let seg = PathSeg::Line(Line::new((0.0, 0.0), (2.0, 0.0)));
let line = Line::new((1.0, 2.0), (1.0, -2.0));
let intersection = seg.intersect_line(line);
assert_eq!(intersection.len(), 1);
let intersection = intersection[0];
assert_eq!(intersection.segment_t, 0.5);
assert_eq!(intersection.line_t, 0.5);

let point = seg.eval(intersection.segment_t);
assert_eq!(point, Point::new(1.0, 0.0));

pub fn is_finite(&self) -> bool

Is this Bezier path finite?

pub fn is_nan(&self) -> bool

Is this Bezier path NaN?

pub fn min_dist(&self, other: PathSeg, accuracy: f64) -> MinDistance

Minimum distance between two PathSegs

Returns a tuple of the distance, the path time t1 of the closest point on the first PathSeg, and the path time t2 of the closest point on the second PathSeg.

Trait Implementations§

§

impl Clone for PathSeg

§

fn clone(&self) -> PathSeg

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 Data for PathSeg

source§

fn same(&self, other: &Self) -> bool

Determine whether two values are the same. Read more
§

impl Debug for PathSeg

§

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

Formats the value using the given formatter. Read more
§

impl From<CubicBez> for PathSeg

§

fn from(cubic_bez: CubicBez) -> PathSeg

Converts to this type from the input type.
§

impl From<Line> for PathSeg

§

fn from(line: Line) -> PathSeg

Converts to this type from the input type.
§

impl From<QuadBez> for PathSeg

§

fn from(quad_bez: QuadBez) -> PathSeg

Converts to this type from the input type.
§

impl Mul<PathSeg> for Affine

§

type Output = PathSeg

The resulting type after applying the * operator.
§

fn mul(self, other: PathSeg) -> PathSeg

Performs the * operation. Read more
§

impl Mul<PathSeg> for TranslateScale

§

type Output = PathSeg

The resulting type after applying the * operator.
§

fn mul(self, other: PathSeg) -> PathSeg

Performs the * operation. Read more
§

impl ParamCurve for PathSeg

§

fn eval(&self, t: f64) -> Point

Evaluate the curve at parameter t. Read more
§

fn subsegment(&self, range: Range<f64>) -> PathSeg

Get a subsegment of the curve for the given parameter range.
§

fn subdivide(&self) -> (Self, Self)

Subdivide into (roughly) halves.
§

fn start(&self) -> Point

The start point.
§

fn end(&self) -> Point

The end point.
§

impl ParamCurveArclen for PathSeg

§

fn arclen(&self, accuracy: f64) -> f64

The arc length of the curve. Read more
§

fn inv_arclen(&self, arclen: f64, accuracy: f64) -> f64

Solve for the parameter that has the given arc length from the start. Read more
§

impl ParamCurveArea for PathSeg

§

fn signed_area(&self) -> f64

Compute the signed area under the curve. Read more
§

impl ParamCurveExtrema for PathSeg

§

fn extrema( &self ) -> ArrayVec<f64, kurbo::::bezpath::{impl#19}::extrema::{constant#0}>

Compute the extrema of the curve. Read more
§

fn extrema_ranges( &self ) -> ArrayVec<Range<f64>, kurbo::::param_curve::ParamCurveExtrema::extrema_ranges::{constant#0}>

Return parameter ranges, each of which is monotonic within the range.
§

fn bounding_box(&self) -> Rect

The smallest rectangle that encloses the curve in the range (0..1).
§

impl ParamCurveNearest for PathSeg

§

fn nearest(&self, p: Point, accuracy: f64) -> Nearest

Find the position on the curve that is nearest to the given point. Read more
§

impl PartialEq<PathSeg> for PathSeg

§

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

§

fn area(&self) -> f64

The area under the curve.

We could just return 0, but this seems more useful.

§

type PathElementsIter = PathSegIter

The iterator returned by the path_elements method.
§

fn path_elements(&self, _tolerance: f64) -> PathSegIter

Returns an iterator over this shape expressed as PathEls; that is, as Bézier path elements. Read more
§

fn perimeter(&self, accuracy: f64) -> f64

Total length of perimeter.
§

fn winding(&self, _pt: Point) -> i32

The winding number of a point. Read more
§

fn bounding_box(&self) -> Rect

The smallest rectangle that encloses the shape.
§

fn as_line(&self) -> Option<Line>

If the shape is a line, make it available.
§

fn to_path(&self, tolerance: f64) -> BezPath

Convert to a Bézier path. Read more
§

fn into_path(self, tolerance: f64) -> BezPath

Convert into a Bézier path. Read more
§

fn path_segments(&self, tolerance: f64) -> Segments<Self::PathElementsIter<'_>>

Returns an iterator over this shape expressed as Bézier path segments (PathSegs). Read more
§

fn contains(&self, pt: Point) -> bool

Returns true if the Point is inside this shape. Read more
§

fn as_rect(&self) -> Option<Rect>

If the shape is a rectangle, make it available.
§

fn as_rounded_rect(&self) -> Option<RoundedRect>

If the shape is a rounded rectangle, make it available.
§

fn as_circle(&self) -> Option<Circle>

If the shape is a circle, make it available.
§

fn as_path_slice(&self) -> Option<&[PathEl]>

If the shape is stored as a slice of path elements, make that available. Read more
§

impl Copy for PathSeg

§

impl StructuralPartialEq for PathSeg

Auto Trait Implementations§

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> AnyEq for Twhere T: Any + PartialEq<T>,

source§

fn equals(&self, other: &(dyn Any + 'static)) -> bool

source§

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

source§

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

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

const: unstable · source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

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

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

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 Twhere U: From<T>,

const: unstable · 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.

§

impl<T> RoundFrom<T> for T

§

fn round_from(x: T) -> T

Performs the conversion.
§

impl<T, U> RoundInto<U> for Twhere U: RoundFrom<T>,

§

fn round_into(self) -> U

Performs the conversion.
source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for Twhere 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 Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

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

§

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

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

impl<T> WithSubscriber for T

source§

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
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

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