pub struct InfinitePlane3d {
pub normal: Dir3,
}
Expand description
An unbounded plane in 3D space. It forms a separating surface through the origin, stretching infinitely far
Fields§
§normal: Dir3
The normal of the plane. The plane will be placed perpendicular to this direction
Implementations§
source§impl InfinitePlane3d
impl InfinitePlane3d
sourcepub fn new<T: TryInto<Dir3>>(normal: T) -> Self
pub fn new<T: TryInto<Dir3>>(normal: T) -> Self
Create a new InfinitePlane3d
from a normal
§Panics
Panics if the given normal
is zero (or very close to zero), or non-finite.
sourcepub fn from_points(a: Vec3, b: Vec3, c: Vec3) -> (Self, Vec3)
pub fn from_points(a: Vec3, b: Vec3, c: Vec3) -> (Self, Vec3)
Create a new InfinitePlane3d
based on three points and compute the geometric center
of those points.
The direction of the plane normal is determined by the winding order of the triangular shape formed by the points.
§Panics
Panics if a valid normal can not be computed, for example when the points are collinear and lie on the same line.
sourcepub fn signed_distance(
&self,
isometry: impl Into<Isometry3d>,
point: Vec3,
) -> f32
pub fn signed_distance( &self, isometry: impl Into<Isometry3d>, point: Vec3, ) -> f32
Computes the shortest distance between a plane transformed with the given isometry
and a
point
. The result is a signed value; it’s positive if the point lies in the half-space
that the plane’s normal vector points towards.
sourcepub fn project_point(
&self,
isometry: impl Into<Isometry3d>,
point: Vec3,
) -> Vec3
pub fn project_point( &self, isometry: impl Into<Isometry3d>, point: Vec3, ) -> Vec3
Injects the point
into this plane transformed with the given isometry
.
This projects the point orthogonally along the shortest path onto the plane.
sourcepub fn isometry_into_xy(&self, origin: Vec3) -> Isometry3d
pub fn isometry_into_xy(&self, origin: Vec3) -> Isometry3d
Computes an Isometry3d
which transforms points from the plane in 3D space with the given
origin
to the XY-plane.
§Guarantees
- the transformation is a congruence meaning it will preserve all distances and angles of the transformed geometry
- uses the least rotation possible to transform the geometry
- if two geometries are transformed with the same isometry, then the relations between them, like distances, are also preserved
- compared to projections, the transformation is lossless (up to floating point errors) reversible
§Non-Guarantees
- the rotation used is generally not unique
- the orientation of the transformed geometry in the XY plane might be arbitrary, to enforce some kind of alignment the user has to use an extra transformation ontop of this one
See isometries_xy
for example usescases.
sourcepub fn isometry_from_xy(&self, origin: Vec3) -> Isometry3d
pub fn isometry_from_xy(&self, origin: Vec3) -> Isometry3d
Computes an Isometry3d
which transforms points from the XY-plane to this plane with the
given origin
.
§Guarantees
- the transformation is a congruence meaning it will preserve all distances and angles of the transformed geometry
- uses the least rotation possible to transform the geometry
- if two geometries are transformed with the same isometry, then the relations between them, like distances, are also preserved
- compared to projections, the transformation is lossless (up to floating point errors) reversible
§Non-Guarantees
- the rotation used is generally not unique
- the orientation of the transformed geometry in the XY plane might be arbitrary, to enforce some kind of alignment the user has to use an extra transformation ontop of this one
See isometries_xy
for example usescases.
sourcepub fn isometries_xy(&self, origin: Vec3) -> (Isometry3d, Isometry3d)
pub fn isometries_xy(&self, origin: Vec3) -> (Isometry3d, Isometry3d)
Computes both isometries which transforms points from the plane in 3D space with the
given origin
to the XY-plane and back.
§Example
The projection and its inverse can be used to run 2D algorithms on flat shapes in 3D. The workflow would usually look like this:
let triangle_3d @ [a, b, c] = [Vec3::X, Vec3::Y, Vec3::Z];
let center = (a + b + c) / 3.0;
let plane = InfinitePlane3d::new(Vec3::ONE);
let (to_xy, from_xy) = plane.isometries_xy(center);
let triangle_2d = triangle_3d.map(|vec3| to_xy * vec3).map(|vec3| vec3.truncate());
// apply some algorithm to `triangle_2d`
let triangle_3d = triangle_2d.map(|vec2| vec2.extend(0.0)).map(|vec3| from_xy * vec3);
Trait Implementations§
source§impl Bounded3d for InfinitePlane3d
impl Bounded3d for InfinitePlane3d
source§fn aabb_3d(&self, isometry: impl Into<Isometry3d>) -> Aabb3d
fn aabb_3d(&self, isometry: impl Into<Isometry3d>) -> Aabb3d
source§fn bounding_sphere(&self, isometry: impl Into<Isometry3d>) -> BoundingSphere
fn bounding_sphere(&self, isometry: impl Into<Isometry3d>) -> BoundingSphere
source§impl Clone for InfinitePlane3d
impl Clone for InfinitePlane3d
source§fn clone(&self) -> InfinitePlane3d
fn clone(&self) -> InfinitePlane3d
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for InfinitePlane3d
impl Debug for InfinitePlane3d
source§impl Default for InfinitePlane3d
impl Default for InfinitePlane3d
source§fn default() -> Self
fn default() -> Self
Returns the default InfinitePlane3d
with a normal pointing in the +Y
direction.
source§impl<'de> Deserialize<'de> for InfinitePlane3d
impl<'de> Deserialize<'de> for InfinitePlane3d
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>,
source§impl FromReflect for InfinitePlane3dwhere
InfinitePlane3d: Any + Send + Sync,
Dir3: FromReflect + TypePath + MaybeTyped + RegisterForReflection,
impl FromReflect for InfinitePlane3dwhere
InfinitePlane3d: Any + Send + Sync,
Dir3: FromReflect + TypePath + MaybeTyped + RegisterForReflection,
source§fn from_reflect(reflect: &dyn PartialReflect) -> Option<Self>
fn from_reflect(reflect: &dyn PartialReflect) -> Option<Self>
Self
from a reflected value.source§fn take_from_reflect(
reflect: Box<dyn PartialReflect>,
) -> Result<Self, Box<dyn PartialReflect>>
fn take_from_reflect( reflect: Box<dyn PartialReflect>, ) -> Result<Self, Box<dyn PartialReflect>>
Self
using,
constructing the value using from_reflect
if that fails. Read moresource§impl GetTypeRegistration for InfinitePlane3dwhere
InfinitePlane3d: Any + Send + Sync,
Dir3: FromReflect + TypePath + MaybeTyped + RegisterForReflection,
impl GetTypeRegistration for InfinitePlane3dwhere
InfinitePlane3d: Any + Send + Sync,
Dir3: FromReflect + TypePath + MaybeTyped + RegisterForReflection,
source§fn get_type_registration() -> TypeRegistration
fn get_type_registration() -> TypeRegistration
TypeRegistration
for this type.source§fn register_type_dependencies(registry: &mut TypeRegistry)
fn register_type_dependencies(registry: &mut TypeRegistry)
source§impl PartialEq for InfinitePlane3d
impl PartialEq for InfinitePlane3d
source§impl PartialReflect for InfinitePlane3dwhere
InfinitePlane3d: Any + Send + Sync,
Dir3: FromReflect + TypePath + MaybeTyped + RegisterForReflection,
impl PartialReflect for InfinitePlane3dwhere
InfinitePlane3d: Any + Send + Sync,
Dir3: FromReflect + TypePath + MaybeTyped + RegisterForReflection,
source§fn get_represented_type_info(&self) -> Option<&'static TypeInfo>
fn get_represented_type_info(&self) -> Option<&'static TypeInfo>
source§fn clone_value(&self) -> Box<dyn PartialReflect>
fn clone_value(&self) -> Box<dyn PartialReflect>
Reflect
trait object. Read moresource§fn try_apply(&mut self, value: &dyn PartialReflect) -> Result<(), ApplyError>
fn try_apply(&mut self, value: &dyn PartialReflect) -> Result<(), ApplyError>
source§fn reflect_kind(&self) -> ReflectKind
fn reflect_kind(&self) -> ReflectKind
source§fn reflect_ref(&self) -> ReflectRef<'_>
fn reflect_ref(&self) -> ReflectRef<'_>
source§fn reflect_mut(&mut self) -> ReflectMut<'_>
fn reflect_mut(&mut self) -> ReflectMut<'_>
source§fn reflect_owned(self: Box<Self>) -> ReflectOwned
fn reflect_owned(self: Box<Self>) -> ReflectOwned
source§fn try_into_reflect(
self: Box<Self>,
) -> Result<Box<dyn Reflect>, Box<dyn PartialReflect>>
fn try_into_reflect( self: Box<Self>, ) -> Result<Box<dyn Reflect>, Box<dyn PartialReflect>>
source§fn try_as_reflect(&self) -> Option<&dyn Reflect>
fn try_as_reflect(&self) -> Option<&dyn Reflect>
source§fn try_as_reflect_mut(&mut self) -> Option<&mut dyn Reflect>
fn try_as_reflect_mut(&mut self) -> Option<&mut dyn Reflect>
source§fn into_partial_reflect(self: Box<Self>) -> Box<dyn PartialReflect>
fn into_partial_reflect(self: Box<Self>) -> Box<dyn PartialReflect>
source§fn as_partial_reflect(&self) -> &dyn PartialReflect
fn as_partial_reflect(&self) -> &dyn PartialReflect
source§fn as_partial_reflect_mut(&mut self) -> &mut dyn PartialReflect
fn as_partial_reflect_mut(&mut self) -> &mut dyn PartialReflect
source§fn reflect_partial_eq(&self, value: &dyn PartialReflect) -> Option<bool>
fn reflect_partial_eq(&self, value: &dyn PartialReflect) -> Option<bool>
source§fn apply(&mut self, value: &(dyn PartialReflect + 'static))
fn apply(&mut self, value: &(dyn PartialReflect + 'static))
source§fn reflect_hash(&self) -> Option<u64>
fn reflect_hash(&self) -> Option<u64>
source§fn serializable(&self) -> Option<Serializable<'_>>
fn serializable(&self) -> Option<Serializable<'_>>
source§fn is_dynamic(&self) -> bool
fn is_dynamic(&self) -> bool
source§impl Reflect for InfinitePlane3dwhere
InfinitePlane3d: Any + Send + Sync,
Dir3: FromReflect + TypePath + MaybeTyped + RegisterForReflection,
impl Reflect for InfinitePlane3dwhere
InfinitePlane3d: Any + Send + Sync,
Dir3: FromReflect + TypePath + MaybeTyped + RegisterForReflection,
source§fn as_any_mut(&mut self) -> &mut dyn Any
fn as_any_mut(&mut self) -> &mut dyn Any
&mut dyn Any
. Read moresource§fn into_reflect(self: Box<Self>) -> Box<dyn Reflect>
fn into_reflect(self: Box<Self>) -> Box<dyn Reflect>
source§fn as_reflect(&self) -> &dyn Reflect
fn as_reflect(&self) -> &dyn Reflect
source§fn as_reflect_mut(&mut self) -> &mut dyn Reflect
fn as_reflect_mut(&mut self) -> &mut dyn Reflect
source§impl Serialize for InfinitePlane3d
impl Serialize for InfinitePlane3d
source§impl Struct for InfinitePlane3dwhere
InfinitePlane3d: Any + Send + Sync,
Dir3: FromReflect + TypePath + MaybeTyped + RegisterForReflection,
impl Struct for InfinitePlane3dwhere
InfinitePlane3d: Any + Send + Sync,
Dir3: FromReflect + TypePath + MaybeTyped + RegisterForReflection,
source§fn field(&self, name: &str) -> Option<&dyn PartialReflect>
fn field(&self, name: &str) -> Option<&dyn PartialReflect>
name
as a &dyn PartialReflect
.source§fn field_mut(&mut self, name: &str) -> Option<&mut dyn PartialReflect>
fn field_mut(&mut self, name: &str) -> Option<&mut dyn PartialReflect>
name
as a
&mut dyn PartialReflect
.source§fn field_at(&self, index: usize) -> Option<&dyn PartialReflect>
fn field_at(&self, index: usize) -> Option<&dyn PartialReflect>
index
as a
&dyn PartialReflect
.source§fn field_at_mut(&mut self, index: usize) -> Option<&mut dyn PartialReflect>
fn field_at_mut(&mut self, index: usize) -> Option<&mut dyn PartialReflect>
index
as a &mut dyn PartialReflect
.source§fn name_at(&self, index: usize) -> Option<&str>
fn name_at(&self, index: usize) -> Option<&str>
index
.source§fn iter_fields(&self) -> FieldIter<'_>
fn iter_fields(&self) -> FieldIter<'_>
source§fn clone_dynamic(&self) -> DynamicStruct
fn clone_dynamic(&self) -> DynamicStruct
DynamicStruct
.source§fn get_represented_struct_info(&self) -> Option<&'static StructInfo>
fn get_represented_struct_info(&self) -> Option<&'static StructInfo>
None
if TypeInfo
is not available.source§impl TypePath for InfinitePlane3d
impl TypePath for InfinitePlane3d
source§fn type_path() -> &'static str
fn type_path() -> &'static str
source§fn short_type_path() -> &'static str
fn short_type_path() -> &'static str
source§fn type_ident() -> Option<&'static str>
fn type_ident() -> Option<&'static str>
source§fn crate_name() -> Option<&'static str>
fn crate_name() -> Option<&'static str>
source§impl Typed for InfinitePlane3dwhere
InfinitePlane3d: Any + Send + Sync,
Dir3: FromReflect + TypePath + MaybeTyped + RegisterForReflection,
impl Typed for InfinitePlane3dwhere
InfinitePlane3d: Any + Send + Sync,
Dir3: FromReflect + TypePath + MaybeTyped + RegisterForReflection,
impl Copy for InfinitePlane3d
impl Primitive3d for InfinitePlane3d
impl StructuralPartialEq for InfinitePlane3d
Auto Trait Implementations§
impl Freeze for InfinitePlane3d
impl RefUnwindSafe for InfinitePlane3d
impl Send for InfinitePlane3d
impl Sync for InfinitePlane3d
impl Unpin for InfinitePlane3d
impl UnwindSafe for InfinitePlane3d
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
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)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>
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
.source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
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)
&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)
&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> DowncastSync for T
impl<T> DowncastSync for T
source§impl<T> DynamicTypePath for Twhere
T: TypePath,
impl<T> DynamicTypePath for Twhere
T: TypePath,
source§fn reflect_type_path(&self) -> &str
fn reflect_type_path(&self) -> &str
TypePath::type_path
.source§fn reflect_short_type_path(&self) -> &str
fn reflect_short_type_path(&self) -> &str
source§fn reflect_type_ident(&self) -> Option<&str>
fn reflect_type_ident(&self) -> Option<&str>
TypePath::type_ident
.source§fn reflect_crate_name(&self) -> Option<&str>
fn reflect_crate_name(&self) -> Option<&str>
TypePath::crate_name
.source§fn reflect_module_path(&self) -> Option<&str>
fn reflect_module_path(&self) -> Option<&str>
source§impl<T> DynamicTyped for Twhere
T: Typed,
impl<T> DynamicTyped for Twhere
T: Typed,
source§fn reflect_type_info(&self) -> &'static TypeInfo
fn reflect_type_info(&self) -> &'static TypeInfo
Typed::type_info
.source§impl<S> GetField for Swhere
S: Struct,
impl<S> GetField for Swhere
S: Struct,
source§impl<T> GetPath for T
impl<T> GetPath for T
source§fn reflect_path<'p>(
&self,
path: impl ReflectPath<'p>,
) -> Result<&(dyn PartialReflect + 'static), ReflectPathError<'p>>
fn reflect_path<'p>( &self, path: impl ReflectPath<'p>, ) -> Result<&(dyn PartialReflect + 'static), ReflectPathError<'p>>
path
. Read moresource§fn reflect_path_mut<'p>(
&mut self,
path: impl ReflectPath<'p>,
) -> Result<&mut (dyn PartialReflect + 'static), ReflectPathError<'p>>
fn reflect_path_mut<'p>( &mut self, path: impl ReflectPath<'p>, ) -> Result<&mut (dyn PartialReflect + 'static), ReflectPathError<'p>>
path
. Read moresource§fn path<'p, T>(
&self,
path: impl ReflectPath<'p>,
) -> Result<&T, ReflectPathError<'p>>where
T: Reflect,
fn path<'p, T>(
&self,
path: impl ReflectPath<'p>,
) -> Result<&T, ReflectPathError<'p>>where
T: Reflect,
path
. Read moresource§fn path_mut<'p, T>(
&mut self,
path: impl ReflectPath<'p>,
) -> Result<&mut T, ReflectPathError<'p>>where
T: Reflect,
fn path_mut<'p, T>(
&mut self,
path: impl ReflectPath<'p>,
) -> Result<&mut T, ReflectPathError<'p>>where
T: Reflect,
path
. Read moresource§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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>
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>
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 more