#[repr(C)]
pub struct GenericHeightField<Storage: HeightFieldStorage> { /* private fields */ }
Expand description

A 2D heightfield with a generic storage buffer for its heights.

Implementations§

source§

impl<Storage: HeightFieldStorage> GenericHeightField<Storage>

source

pub fn aabb(&self, pos: &Isometry<Real>) -> Aabb

Computes the world-space Aabb of this heightfield, transformed by pos.

source

pub fn local_aabb(&self) -> Aabb

Computes the local-space Aabb of this heightfield.

source§

impl<Storage: HeightFieldStorage> GenericHeightField<Storage>

source

pub fn bounding_sphere(&self, pos: &Isometry<Real>) -> BoundingSphere

Computes the world-space bounding sphere of this height-field, transformed by pos.

source

pub fn local_bounding_sphere(&self) -> BoundingSphere

Computes the local-space bounding sphere of this height-field.

source§

impl GenericHeightField<DefaultStorage>

source

pub fn new(heights: DVector<Real>, scale: Vector<Real>) -> Self

Creates a new 2D heightfield with the given heights and scale factor.

source§

impl<Storage: HeightFieldStorage> GenericHeightField<Storage>

source

pub fn num_cells(&self) -> usize

The number of cells of this heightfield.

source

pub fn heights(&self) -> &Storage::Heights

The height at each cell endpoint.

source

pub fn scale(&self) -> &Vector<Real>

The scale factor applied to this heightfield.

source

pub fn set_scale(&mut self, new_scale: Vector<Real>)

Sets the scale factor applied to this heightfield.

source

pub fn scaled(self, scale: &Vector<Real>) -> Self

Returns a scaled version of this heightfield.

source

pub fn root_aabb(&self) -> &Aabb

The Aabb of this heightfield.

source

pub fn cell_width(&self) -> Real

The width of a single cell of this heightfield.

source

pub fn unit_cell_width(&self) -> Real

The width of a single cell of this heightfield, without taking the scale factor into account.

source

pub fn start_x(&self) -> Real

The left-most x-coordinate of this heightfield.

source

pub fn cell_at_point(&self, pt: &Point2<Real>) -> Option<usize>

Index of the cell a point is on after vertical projection.

source

pub fn height_at_point(&self, pt: &Point2<Real>) -> Option<Real>

Height of the heightfield a the given point after vertical projection on the heightfield surface.

source

pub fn segments<'a>(&'a self) -> impl Iterator<Item = Segment> + 'a

Iterator through all the segments of this heightfield.

source

pub fn segment_at(&self, i: usize) -> Option<Segment>

The i-th segment of the heightfield if it has not been removed.

source

pub fn set_segment_removed(&mut self, i: usize, removed: bool)

Mark the i-th segment of this heightfield as removed or not.

source

pub fn is_segment_removed(&self, i: usize) -> bool

Checks if the i-th segment has been removed.

source

pub fn unclamped_elements_range_in_local_aabb( &self, aabb: &Aabb ) -> Range<isize>

The range of segment ids that may intersect the given local Aabb.

source

pub fn map_elements_in_local_aabb( &self, aabb: &Aabb, f: &mut impl FnMut(u32, &Segment) )

Applies f to each segment of this heightfield that intersects the given aabb.

source§

impl GenericHeightField<DefaultStorage>

source

pub fn to_polyline(&self) -> (Vec<Point2<Real>>, Vec<[u32; 2]>)

Rasterize this heightfield as a (potentially discontinuous) polyline.

Trait Implementations§

source§

impl<Storage> Clone for GenericHeightField<Storage>
where Storage: HeightFieldStorage, Storage::Heights: Clone, Storage::Status: Clone,

source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<Storage: Debug + HeightFieldStorage> Debug for GenericHeightField<Storage>
where Storage::Heights: Debug, Storage::Status: Debug,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<Storage: HeightFieldStorage> PointQuery for GenericHeightField<Storage>

source§

fn project_local_point_with_max_dist( &self, pt: &Point<Real>, solid: bool, max_dist: Real ) -> Option<PointProjection>

Projects a point on self, unless the projection lies further than the given max distance. Read more
source§

fn project_local_point(&self, point: &Point<Real>, _: bool) -> PointProjection

Projects a point on self. Read more
source§

fn project_local_point_and_get_feature( &self, point: &Point<Real> ) -> (PointProjection, FeatureId)

Projects a point on the boundary of self and returns the id of the feature the point was projected on.
source§

fn contains_local_point(&self, _point: &Point<Real>) -> bool

Tests if the given point is inside of self.
source§

fn project_point_with_max_dist( &self, m: &Isometry<Real>, pt: &Point<Real>, solid: bool, max_dist: Real ) -> Option<PointProjection>

Projects a point on self transformed by m, unless the projection lies further than the given max distance.
source§

fn distance_to_local_point(&self, pt: &Point<Real>, solid: bool) -> Real

Computes the minimal distance between a point and self.
source§

fn project_point( &self, m: &Isometry<Real>, pt: &Point<Real>, solid: bool ) -> PointProjection

Projects a point on self transformed by m.
source§

fn distance_to_point( &self, m: &Isometry<Real>, pt: &Point<Real>, solid: bool ) -> Real

Computes the minimal distance between a point and self transformed by m.
source§

fn project_point_and_get_feature( &self, m: &Isometry<Real>, pt: &Point<Real> ) -> (PointProjection, FeatureId)

Projects a point on the boundary of self transformed by m and returns the id of the feature the point was projected on.
source§

fn contains_point(&self, m: &Isometry<Real>, pt: &Point<Real>) -> bool

Tests if the given point is inside of self transformed by m.
source§

impl<Storage: HeightFieldStorage> PointQueryWithLocation for GenericHeightField<Storage>

§

type Location = (usize, TrianglePointLocation)

Additional shape-specific projection information Read more
source§

fn project_local_point_and_get_location( &self, _point: &Point<Real>, _: bool ) -> (PointProjection, Self::Location)

Projects a point on self.
source§

fn project_point_and_get_location( &self, m: &Isometry<Real>, pt: &Point<Real>, solid: bool ) -> (PointProjection, Self::Location)

Projects a point on self transformed by m.
source§

fn project_local_point_and_get_location_with_max_dist( &self, pt: &Point<Real>, solid: bool, max_dist: Real ) -> Option<(PointProjection, Self::Location)>

Projects a point on self, with a maximum projection distance.
source§

fn project_point_and_get_location_with_max_dist( &self, m: &Isometry<Real>, pt: &Point<Real>, solid: bool, max_dist: Real ) -> Option<(PointProjection, Self::Location)>

Projects a point on self transformed by m, with a maximum projection distance.
source§

impl<Storage: HeightFieldStorage> RayCast for GenericHeightField<Storage>

source§

fn cast_local_ray_and_get_normal( &self, ray: &Ray, max_toi: Real, _: bool ) -> Option<RayIntersection>

Computes the time of impact, and normal between this transformed shape and a ray.
source§

fn cast_local_ray(&self, ray: &Ray, max_toi: Real, solid: bool) -> Option<Real>

Computes the time of impact between this transform shape and a ray.
source§

fn intersects_local_ray(&self, ray: &Ray, max_toi: Real) -> bool

Tests whether a ray intersects this transformed shape.
source§

fn cast_ray( &self, m: &Isometry<Real>, ray: &Ray, max_toi: Real, solid: bool ) -> Option<Real>

Computes the time of impact between this transform shape and a ray.
source§

fn cast_ray_and_get_normal( &self, m: &Isometry<Real>, ray: &Ray, max_toi: Real, solid: bool ) -> Option<RayIntersection>

Computes the time of impact, and normal between this transformed shape and a ray.
source§

fn intersects_ray(&self, m: &Isometry<Real>, ray: &Ray, max_toi: Real) -> bool

Tests whether a ray intersects this transformed shape.
source§

impl<Storage> Copy for GenericHeightField<Storage>
where Storage: HeightFieldStorage, Storage::Heights: Copy, Storage::Status: Copy,

Auto Trait Implementations§

§

impl<Storage> RefUnwindSafe for GenericHeightField<Storage>

§

impl<Storage> Send for GenericHeightField<Storage>
where <Storage as HeightFieldStorage>::Heights: Send, <Storage as HeightFieldStorage>::Status: Send,

§

impl<Storage> Sync for GenericHeightField<Storage>
where <Storage as HeightFieldStorage>::Heights: Sync, <Storage as HeightFieldStorage>::Status: Sync,

§

impl<Storage> Unpin for GenericHeightField<Storage>
where <Storage as HeightFieldStorage>::Heights: Unpin, <Storage as HeightFieldStorage>::Status: Unpin,

§

impl<Storage> UnwindSafe for GenericHeightField<Storage>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> Downcast for T
where T: Any,

source§

fn into_any(self: Box<T>) -> Box<dyn Any>

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.
source§

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.
source§

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.
source§

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.
source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<SS, SP> SupersetOf<SS> for SP
where SS: SubsetOf<SP>,

source§

fn to_subset(&self) -> Option<SS>

The inverse inclusion map: attempts to construct self from the equivalent element of its superset. Read more
source§

fn is_in_subset(&self) -> bool

Checks if self is actually part of its subset T (and can be converted to it).
source§

fn to_subset_unchecked(&self) -> SS

Use with care! Same as self.to_subset but without any property checks. Always succeeds.
source§

fn from_subset(element: &SS) -> SP

The inclusion map: converts self to the equivalent element of its superset.
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.