#[repr(C)]pub struct Line<const D: usize> { /* private fields */ }Expand description
An n-dimensional line, defined by an origin and a direction
The dimensionality of the line is defined by the const generic D
parameter.
Implementations
sourceimpl<const D: usize> Line<D>
impl<const D: usize> Line<D>
sourcepub fn from_origin_and_direction(origin: Point<D>, direction: Vector<D>) -> Self
pub fn from_origin_and_direction(origin: Point<D>, direction: Vector<D>) -> Self
sourcepub fn origin(&self) -> Point<D>
pub fn origin(&self) -> Point<D>
Access the origin of the line
The origin is a point on the line which, together with the direction
field, defines the line fully. The origin also defines the origin of the
line’s 1-dimensional coordinate system.
sourcepub fn direction(&self) -> Vector<D>
pub fn direction(&self) -> Vector<D>
Access the direction of the line
The length of this vector defines the unit of the line’s curve
coordinate system. The coordinate 1. is always were the direction
vector points, from origin.
sourcepub fn is_coincident_with(&self, other: &Self) -> bool
pub fn is_coincident_with(&self, other: &Self) -> bool
Determine if this line is coincident with another line
Implementation Note
This method only returns true, if the lines are precisely coincident.
This will probably not be enough going forward, but it’ll do for now.
sourcepub fn point_to_line_coords(&self, point: impl Into<Point<D>>) -> Point<1>
pub fn point_to_line_coords(&self, point: impl Into<Point<D>>) -> Point<1>
Convert a D-dimensional point to line coordinates
Projects the point onto the line before the conversion. This is done to make this method robust against floating point accuracy issues.
Callers are advised to be careful about the points they pass, as the point not being on the line, intentional or not, will never result in an error.
sourcepub fn vector_to_line_coords(&self, vector: impl Into<Vector<D>>) -> Vector<1>
pub fn vector_to_line_coords(&self, vector: impl Into<Vector<D>>) -> Vector<1>
Convert a D-dimensional vector to line coordinates
sourcepub fn point_from_line_coords(&self, point: impl Into<Point<1>>) -> Point<D>
pub fn point_from_line_coords(&self, point: impl Into<Point<1>>) -> Point<D>
Convert a point in line coordinates into a D-dimensional point
sourcepub fn vector_from_line_coords(&self, vector: impl Into<Vector<1>>) -> Vector<D>
pub fn vector_from_line_coords(&self, vector: impl Into<Vector<1>>) -> Vector<D>
Convert a vector in line coordinates into a D-dimensional vector
Trait Implementations
sourceimpl<const D: usize> AbsDiffEq<Line<D>> for Line<D>
impl<const D: usize> AbsDiffEq<Line<D>> for Line<D>
sourcefn default_epsilon() -> Self::Epsilon
fn default_epsilon() -> Self::Epsilon
The default tolerance to use when testing values that are close together. Read more
sourcefn abs_diff_eq(&self, other: &Self, epsilon: Self::Epsilon) -> bool
fn abs_diff_eq(&self, other: &Self, epsilon: Self::Epsilon) -> bool
A test for equality that uses the absolute difference to compute the approximate equality of two numbers. Read more
sourcefn abs_diff_ne(&self, other: &Rhs, epsilon: Self::Epsilon) -> bool
fn abs_diff_ne(&self, other: &Rhs, epsilon: Self::Epsilon) -> bool
The inverse of AbsDiffEq::abs_diff_eq.
sourceimpl<const D: usize> Ord for Line<D>
impl<const D: usize> Ord for Line<D>
1.21.0 · sourcefn max(self, other: Self) -> Self
fn max(self, other: Self) -> Self
Compares and returns the maximum of two values. Read more
1.21.0 · sourcefn min(self, other: Self) -> Self
fn min(self, other: Self) -> Self
Compares and returns the minimum of two values. Read more
1.50.0 · sourcefn clamp(self, min: Self, max: Self) -> Self where
Self: PartialOrd<Self>,
fn clamp(self, min: Self, max: Self) -> Self where
Self: PartialOrd<Self>,
Restrict a value to a certain interval. Read more
sourceimpl<const D: usize> PartialEq<Line<D>> for Line<D>
impl<const D: usize> PartialEq<Line<D>> for Line<D>
sourceimpl<const D: usize> PartialOrd<Line<D>> for Line<D>
impl<const D: usize> PartialOrd<Line<D>> for Line<D>
sourcefn partial_cmp(&self, other: &Line<D>) -> Option<Ordering>
fn partial_cmp(&self, other: &Line<D>) -> Option<Ordering>
This method returns an ordering between self and other values if one exists. Read more
1.0.0 · sourcefn lt(&self, other: &Rhs) -> bool
fn lt(&self, other: &Rhs) -> bool
This method tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · sourcefn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
This method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl<const D: usize> Copy for Line<D>
impl<const D: usize> Eq for Line<D>
impl<const D: usize> StructuralEq for Line<D>
impl<const D: usize> StructuralPartialEq for Line<D>
Auto Trait Implementations
impl<const D: usize> RefUnwindSafe for Line<D>
impl<const D: usize> Send for Line<D>
impl<const D: usize> Sync for Line<D>
impl<const D: usize> Unpin for Line<D>
impl<const D: usize> UnwindSafe for Line<D>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
impl<T> Downcast for T where
T: Any,
impl<T> Downcast for T where
T: Any,
fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
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. Read more
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait. Read more
fn as_any(&self) -> &(dyn Any + 'static)
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. Read more
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
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. Read more
impl<SS, SP> SupersetOf<SS> for SP where
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SP where
SS: SubsetOf<SP>,
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 more
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).
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.
fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts self to the equivalent element of its superset.