Struct plane_split::Plane [−][src]
pub struct Plane<T, U> {
pub normal: TypedVector3D<T, U>,
pub offset: T,
}An infinite plane in 3D space, defined by equation: dot(v, normal) + offset = 0 When used for plane splitting, it's defining a hemisphere with equation "dot(v, normal) + offset > 0".
Fields
normal: TypedVector3D<T, U>
Normalized vector perpendicular to the plane.
offset: T
Constant offset from the normal plane, specified in the direction opposite to the normal.
Methods
impl<T: Copy + Zero + One + Float + ApproxEq<T> + Sub<T, Output = T> + Add<T, Output = T> + Mul<T, Output = T> + Div<T, Output = T>, U> Plane<T, U>[src]
impl<T: Copy + Zero + One + Float + ApproxEq<T> + Sub<T, Output = T> + Add<T, Output = T> + Mul<T, Output = T> + Div<T, Output = T>, U> Plane<T, U>pub fn from_unnormalized(normal: TypedVector3D<T, U>, offset: T) -> Option<Self>[src]
pub fn from_unnormalized(normal: TypedVector3D<T, U>, offset: T) -> Option<Self>Construct a new plane from unnormalized equation.
pub fn contains(&self, other: &Self) -> bool[src]
pub fn contains(&self, other: &Self) -> boolCheck if this plane contains another one.
pub fn signed_distance_to(&self, point: &TypedPoint3D<T, U>) -> T[src]
pub fn signed_distance_to(&self, point: &TypedPoint3D<T, U>) -> TReturn the signed distance from this plane to a point. The distance is negative if the point is on the other side of the plane from the direction of the normal.
pub fn distance_to_line(&self, line: &Line<T, U>) -> T where
T: Neg<Output = T>, [src]
pub fn distance_to_line(&self, line: &Line<T, U>) -> T where
T: Neg<Output = T>, Compute the distance across the line to the plane plane, starting from the line origin.
pub fn signed_distance_sum_to(&self, poly: &Polygon<T, U>) -> T[src]
pub fn signed_distance_sum_to(&self, poly: &Polygon<T, U>) -> TCompute the sum of signed distances to each of the points
of another plane. Useful to know the relation of a plane that
is a product of a split, and we know it doesn't intersect self.
pub fn are_outside(&self, points: &[TypedPoint3D<T, U>]) -> bool[src]
pub fn are_outside(&self, points: &[TypedPoint3D<T, U>]) -> boolCheck if a convex shape defined by a set of points is completely outside of this plane. Merely touching the surface is not considered an intersection.
pub fn intersect(&self, other: &Self) -> Option<Line<T, U>>[src]
pub fn intersect(&self, other: &Self) -> Option<Line<T, U>>Compute the line of intersection with another plane.
Trait Implementations
impl<T: Debug, U: Debug> Debug for Plane<T, U>[src]
impl<T: Debug, U: Debug> Debug for Plane<T, U>fn fmt(&self, f: &mut Formatter) -> Result[src]
fn fmt(&self, f: &mut Formatter) -> ResultFormats the value using the given formatter. Read more
impl<T: PartialEq, U: PartialEq> PartialEq for Plane<T, U>[src]
impl<T: PartialEq, U: PartialEq> PartialEq for Plane<T, U>fn eq(&self, other: &Plane<T, U>) -> bool[src]
fn eq(&self, other: &Plane<T, U>) -> boolThis method tests for self and other values to be equal, and is used by ==. Read more
fn ne(&self, other: &Plane<T, U>) -> bool[src]
fn ne(&self, other: &Plane<T, U>) -> boolThis method tests for !=.
impl<T: Clone, U> Clone for Plane<T, U>[src]
impl<T: Clone, U> Clone for Plane<T, U>