pub enum PolylinePointLocation {
OnVertex(usize),
OnEdge(usize, usize, [f32; 2]),
}Expand description
Location of a point on a polyline.
This enum represents where a point lies on a polygon’s boundary. It’s used by the intersection algorithms to precisely describe intersection points.
§Variants
OnVertex(i)- The point is exactly on vertexiof the polygonOnEdge(i, j, bcoords)- The point lies on the edge between verticesiandj, with barycentric coordinatesbcoordswherebcoords[0] + bcoords[1] = 1.0
§Examples
let polygon = vec![
Point2::origin(),
Point2::new(2.0, 0.0),
Point2::new(2.0, 2.0),
Point2::new(0.0, 2.0),
];
// A point on vertex 0
let loc1 = PolylinePointLocation::OnVertex(0);
let pt1 = loc1.to_point(&polygon);
assert_eq!(pt1, Point2::origin());
// A point halfway along the edge from vertex 0 to vertex 1
let loc2 = PolylinePointLocation::OnEdge(0, 1, [0.5, 0.5]);
let pt2 = loc2.to_point(&polygon);
assert_eq!(pt2, Point2::new(1.0, 0.0));Variants§
Implementations§
Source§impl PolylinePointLocation
impl PolylinePointLocation
Sourcepub fn to_point(self, pts: &[Point2<f32>]) -> Point2<f32>
pub fn to_point(self, pts: &[Point2<f32>]) -> Point2<f32>
Computes the point corresponding to this location.
Given a polygon (as a slice of points), this method converts the location into an actual 2D point coordinate.
§Arguments
pts- The vertices of the polygon
§Examples
let polygon = vec![
Point2::origin(),
Point2::new(4.0, 0.0),
Point2::new(4.0, 4.0),
];
let loc = PolylinePointLocation::OnEdge(0, 1, [0.75, 0.25]);
let point = loc.to_point(&polygon);
assert_eq!(point, Point2::new(1.0, 0.0)); // 75% of vertex 0 + 25% of vertex 1Trait Implementations§
Source§impl Clone for PolylinePointLocation
impl Clone for PolylinePointLocation
Source§fn clone(&self) -> PolylinePointLocation
fn clone(&self) -> PolylinePointLocation
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for PolylinePointLocation
impl Debug for PolylinePointLocation
Source§impl PartialEq for PolylinePointLocation
impl PartialEq for PolylinePointLocation
impl Copy for PolylinePointLocation
impl StructuralPartialEq for PolylinePointLocation
Auto Trait Implementations§
impl Freeze for PolylinePointLocation
impl RefUnwindSafe for PolylinePointLocation
impl Send for PolylinePointLocation
impl Sync for PolylinePointLocation
impl Unpin for PolylinePointLocation
impl UnwindSafe for PolylinePointLocation
Blanket Implementations§
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
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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>
Converts
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn 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>
Converts
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which 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)
Converts
&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)
Converts
&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> DowncastSend for T
impl<T> DowncastSend for T
Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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 moreSource§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.