Struct fj_core::operations::TetrahedronShell
source · pub struct TetrahedronShell<I: IsInserted = IsInsertedNo> {
pub shell: I::T<Shell>,
pub abc: Polygon<3, IsInsertedYes>,
pub bad: Polygon<3, IsInsertedYes>,
pub dac: Polygon<3, IsInsertedYes>,
pub cbd: Polygon<3, IsInsertedYes>,
}Expand description
A tetrahedron
A tetrahedron is constructed from 4 points and has 4 faces. For the purpose
of naming the fields of this struct, the points are named a, b, c, and
d, in the order in which they are passed.
Returned by BuildShell::tetrahedron.
Fields§
§shell: I::T<Shell>The shell that forms the tetrahedron
abc: Polygon<3, IsInsertedYes>The face formed by the points a, b, and c.
bad: Polygon<3, IsInsertedYes>The face formed by the points b, a, and d.
dac: Polygon<3, IsInsertedYes>The face formed by the points d, a, and c.
cbd: Polygon<3, IsInsertedYes>The face formed by the points c, b, and d.
Trait Implementations§
source§impl Insert for TetrahedronShell<IsInsertedNo>
impl Insert for TetrahedronShell<IsInsertedNo>
§type Inserted = TetrahedronShell<IsInsertedYes>
type Inserted = TetrahedronShell<IsInsertedYes>
The type of
Self, once it has been inserted Read moreAuto Trait Implementations§
impl<I = IsInsertedNo> !RefUnwindSafe for TetrahedronShell<I>
impl<I> Send for TetrahedronShell<I>where <I as IsInserted>::T<Shell>: Send,
impl<I> Sync for TetrahedronShell<I>where <I as IsInserted>::T<Shell>: Sync,
impl<I> Unpin for TetrahedronShell<I>where <I as IsInserted>::T<Shell>: Unpin,
impl<I = IsInsertedNo> !UnwindSafe for TetrahedronShell<I>
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
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere T: Any,
§fn into_any(self: Box<T, Global>) -> Box<dyn Any, Global>
fn into_any(self: Box<T, Global>) -> Box<dyn Any, 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.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.§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.§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.§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere 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.