pub enum Face {
Face {
surface: Handle<Surface>,
exteriors: Vec<Handle<Cycle>>,
interiors: Vec<Handle<Cycle>>,
color: [u8; 4],
},
Triangles(Vec<(Triangle<3>, Color)>),
}Expand description
A face of a shape
Equality
Please refer to [crate::kernel::topology] for documentation on the
equality of topological objects.
Validation
A face that is part of a Shape must be structurally sound. That means
the surface and any cycles it refers to, must be part of the same shape.
Variants
Face
Fields
exteriors: Vec<Handle<Cycle>>The cycles that bound the face on the outside
Implementation Note
Since these cycles bound the face, the edges they consist of must lie in the surface. The data we’re using here is 3-dimensional though, so no such limitation is enforced.
It might be less error-prone to specify the edges in surface coordinates.
interiors: Vec<Handle<Cycle>>The cycles that bound the face on the inside
Each of these cycles defines a hole in the face.
Implementation note
See note on exterior field.
A face of a shape
A face is defined by a surface, and is bounded by edges that lie in that surface.
Triangles(Vec<(Triangle<3>, Color)>)
The triangles of the face
Representing faces as a collection of triangles is a temporary state. The plan is to eventually represent faces as a geometric surface, bounded by edges. While the transition is being made, this variant is still required.
Implementations
sourceimpl Face
impl Face
sourcepub fn builder(surface: Surface, shape: &mut Shape) -> FaceBuilder<'_>
pub fn builder(surface: Surface, shape: &mut Shape) -> FaceBuilder<'_>
Build a face using the [FaceBuilder] API
sourcepub fn surface(&self) -> Surface
pub fn surface(&self) -> Surface
Access the surface that the face refers to
This is a convenience method that saves the caller from dealing with the
Handle.
sourcepub fn exteriors(&self) -> impl Iterator<Item = Cycle> + '_
pub fn exteriors(&self) -> impl Iterator<Item = Cycle> + '_
Access the exterior cycles that the face refers to
This is a convenience method that saves the caller from dealing with the
Handles.
sourcepub fn interiors(&self) -> impl Iterator<Item = Cycle> + '_
pub fn interiors(&self) -> impl Iterator<Item = Cycle> + '_
Access the interior cycles that the face refers to
This is a convenience method that saves the caller from dealing with the
Handles.
sourcepub fn all_cycles(&self) -> impl Iterator<Item = Cycle> + '_
pub fn all_cycles(&self) -> impl Iterator<Item = Cycle> + '_
Access all cycles that the face refers to
This is equivalent to chaining the iterators returned by
Face::exteriors and Face::interiors.
Trait Implementations
sourceimpl Ord for Face
impl Ord for Face
sourceimpl PartialOrd<Face> for Face
impl PartialOrd<Face> for Face
sourcefn partial_cmp(&self, other: &Face) -> Option<Ordering>
fn partial_cmp(&self, other: &Face) -> 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 Eq for Face
impl Object for Face
impl StructuralEq for Face
Auto Trait Implementations
impl !RefUnwindSafe for Face
impl Send for Face
impl Sync for Face
impl Unpin for Face
impl !UnwindSafe for Face
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.
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into)Uses borrowed data to replace owned data, usually by cloning. Read more