pub struct VoxelSet {
pub origin: Point<f32>,
pub scale: f32,
/* private fields */
}
Expand description
A sparse set of voxels.
It only contains voxels that are considered as “full” after a voxelization.
Fields§
§origin: Point<f32>
The 3D origin of this voxel-set.
scale: f32
The scale factor between the voxel integer coordinates and their actual float world-space coordinates.
Implementations§
source§impl VoxelSet
impl VoxelSet
sourcepub fn voxel_volume(&self) -> f32
pub fn voxel_volume(&self) -> f32
The volume of a single voxel of this voxel set.
sourcepub fn voxelize(
points: &[Point<f32>],
indices: &[[u32; 3]],
resolution: u32,
fill_mode: FillMode,
keep_voxel_to_primitives_map: bool,
) -> Self
pub fn voxelize( points: &[Point<f32>], indices: &[[u32; 3]], resolution: u32, fill_mode: FillMode, keep_voxel_to_primitives_map: bool, ) -> Self
Voxelizes the given shape described by its boundary: a triangle mesh (in 3D) or polyline (in 2D).
§Parameters
points
- The vertex buffer of the boundary of the shape to voxelize.indices
- The index buffer of the boundary of the shape to voxelize.resolution
- Controls the number of subdivision done along each axis. This number is the number of subdivisions along the axis where the input shape has the largest extent. The other dimensions will have a different automatically-determined resolution (in order to keep the voxels cubic).fill_mode
- Controls what is being voxelized.keep_voxel_to_primitives_map
- If set totrue
a map between the voxels and the primitives (3D triangles or 2D segments) it intersects will be computed.
sourcepub fn min_bb_voxels(&self) -> Point<u32>
pub fn min_bb_voxels(&self) -> Point<u32>
The minimal coordinates of the integer bounding-box of the voxels in this set.
sourcepub fn max_bb_voxels(&self) -> Point<u32>
pub fn max_bb_voxels(&self) -> Point<u32>
The maximal coordinates of the integer bounding-box of the voxels in this set.
sourcepub fn compute_volume(&self) -> f32
pub fn compute_volume(&self) -> f32
Computes the total volume of the voxels contained by this set.
sourcepub fn compute_bb(&mut self)
pub fn compute_bb(&mut self)
Update the bounding box of this voxel set.
sourcepub fn compute_exact_convex_hull(
&self,
points: &[Point<f32>],
indices: &[[u32; 3]],
) -> (Vec<Point<f32>>, Vec<[u32; 3]>)
pub fn compute_exact_convex_hull( &self, points: &[Point<f32>], indices: &[[u32; 3]], ) -> (Vec<Point<f32>>, Vec<[u32; 3]>)
Compute the convex-hull of this voxel set after cutting each voxel by the primitives (3D triangle or 2D segments) it intersects.
This will panic if this VoxelSet
was created with keep_voxel_to_primitives_map = false
.
sourcepub fn compute_primitive_intersections(
&self,
points: &[Point<f32>],
indices: &[[u32; 3]],
) -> Vec<Point<f32>>
pub fn compute_primitive_intersections( &self, points: &[Point<f32>], indices: &[[u32; 3]], ) -> Vec<Point<f32>>
Computes the intersections between all the voxels of this voxel set, and all the primitives (triangle or segments) it intersected (as per the voxel-to-primitives-map computed during voxelization).
Panics if the voxelization was performed without setting the parameter
voxel_to_primitives_map = true
.
sourcepub fn compute_convex_hull(
&self,
sampling: u32,
) -> (Vec<Point<f32>>, Vec<[u32; 3]>)
pub fn compute_convex_hull( &self, sampling: u32, ) -> (Vec<Point<f32>>, Vec<[u32; 3]>)
Compute the convex-hull of the voxels in this set.
§Parameters
sampling
- The convex-hull computation will ignoresampling
voxels at regular intervals. Useful to save some computation times if an exact result isn’t need. Use0
to make sure no voxel is being ignored.
Trait Implementations§
source§impl From<VoxelizedVolume> for VoxelSet
impl From<VoxelizedVolume> for VoxelSet
source§fn from(shape: VoxelizedVolume) -> Self
fn from(shape: VoxelizedVolume) -> Self
Auto Trait Implementations§
impl Freeze for VoxelSet
impl RefUnwindSafe for VoxelSet
impl Send for VoxelSet
impl Sync for VoxelSet
impl Unpin for VoxelSet
impl UnwindSafe for VoxelSet
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> 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> 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 moresource§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self
from the equivalent element of its
superset. Read moresource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self
is actually part of its subset T
(and can be converted to it).source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset
but without any property checks. Always succeeds.source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self
to the equivalent element of its superset.