Struct shape_core::Point
source · #[repr(C)]pub struct Point<T> {
pub x: T,
pub y: T,
}
Expand description
A 2D points.
Fields§
§x: T
The x-coordinate of the point
y: T
The y-coordinate of the point
Implementations§
Trait Implementations§
source§impl<'de, T> Deserialize<'de> for Point<T>where
T: Deserialize<'de>,
impl<'de, T> Deserialize<'de> for Point<T>where T: Deserialize<'de>,
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where __D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
source§impl<T> EuclideanDistance<T> for Point<T>where
T: Real,
impl<T> EuclideanDistance<T> for Point<T>where T: Real,
source§fn euclidean_distance(&self, c: &Point<T>) -> T
fn euclidean_distance(&self, c: &Point<T>) -> T
Minimum distance between two Coord
s
source§fn euclidean_squared(&self, rhs: &Point<T>) -> T
fn euclidean_squared(&self, rhs: &Point<T>) -> T
It is especially suitable when only the length needs to be compared Read more
source§impl<T: Float> EuclideanDistance<T, Circle<T>> for Point<T>
impl<T: Float> EuclideanDistance<T, Circle<T>> for Point<T>
fn euclidean_distance(&self, rhs: &Circle<T>) -> T
source§fn euclidean_squared(&self, rhs: &Circle<T>) -> T
fn euclidean_squared(&self, rhs: &Circle<T>) -> T
It is especially suitable when only the length needs to be compared Read more
source§impl<T: Float> EuclideanDistance<T, Line<T>> for Point<T>
impl<T: Float> EuclideanDistance<T, Line<T>> for Point<T>
fn euclidean_distance(&self, rhs: &Line<T>) -> T
source§fn euclidean_squared(&self, rhs: &Line<T>) -> T
fn euclidean_squared(&self, rhs: &Line<T>) -> T
It is especially suitable when only the length needs to be compared Read more
source§impl<T> EuclideanDistance<T, PointSet<T>> for Point<T>where
T: Float + PartialOrd,
impl<T> EuclideanDistance<T, PointSet<T>> for Point<T>where T: Float + PartialOrd,
source§fn euclidean_squared(&self, rhs: &PointSet<T>) -> T
fn euclidean_squared(&self, rhs: &PointSet<T>) -> T
适合单次查询最近的点
fn euclidean_distance(&self, rhs: &PointSet<T>) -> T
source§impl<T: Float> EuclideanDistance<T, Triangle<T>> for Point<T>
impl<T: Float> EuclideanDistance<T, Triangle<T>> for Point<T>
fn euclidean_distance(&self, rhs: &Triangle<T>) -> T
source§fn euclidean_squared(&self, rhs: &Triangle<T>) -> T
fn euclidean_squared(&self, rhs: &Triangle<T>) -> T
It is especially suitable when only the length needs to be compared Read more
source§impl<T> ManhattanDistance<T> for Point<T>where
T: PartialOrd + Clone + Sub<Output = T> + Add<Output = T>,
impl<T> ManhattanDistance<T> for Point<T>where T: PartialOrd + Clone + Sub<Output = T> + Add<Output = T>,
fn manhattan_distance(&self, rhs: &Point<T>) -> T
source§impl<T: PartialEq> PartialEq for Point<T>
impl<T: PartialEq> PartialEq for Point<T>
source§impl<T> Projective<T> for Point<T>where
T: Real,
impl<T> Projective<T> for Point<T>where T: Real,
impl<T: Copy> Copy for Point<T>
impl<T: Eq> Eq for Point<T>
impl<T> StructuralEq for Point<T>
impl<T> StructuralPartialEq for Point<T>
Auto Trait Implementations§
impl<T> RefUnwindSafe for Point<T>where T: RefUnwindSafe,
impl<T> Send for Point<T>where T: Send,
impl<T> Sync for Point<T>where T: Sync,
impl<T> Unpin for Point<T>where T: Unpin,
impl<T> UnwindSafe for Point<T>where T: UnwindSafe,
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