Struct rapier2d::geometry::SharedShape[][src]

pub struct SharedShape(pub Arc<dyn Shape + 'static>);

The shape of a collider.

Implementations

impl SharedShape[src]

pub fn new(shape: impl Shape) -> SharedShape[src]

Wraps the given shape as a shared shape.

pub fn compound(
    shapes: Vec<(Isometry<f32, U2, Unit<Complex<f32>>>, SharedShape), Global>
) -> SharedShape
[src]

Initialize a compound shape defined by its subshapes.

pub fn ball(radius: f32) -> SharedShape[src]

Initialize a ball shape defined by its radius.

pub fn cuboid(hx: f32, hy: f32) -> SharedShape[src]

Initialize a cuboid shape defined by its half-extents.

pub fn round_cuboid(hx: f32, hy: f32, border_radius: f32) -> SharedShape[src]

Initialize a round cuboid shape defined by its half-extents and border radius.

pub fn capsule(a: Point<f32, U2>, b: Point<f32, U2>, radius: f32) -> SharedShape[src]

Initialize a capsule shape from its endpoints and radius.

pub fn segment(a: Point<f32, U2>, b: Point<f32, U2>) -> SharedShape[src]

Initialize a segment shape from its endpoints.

pub fn triangle(
    a: Point<f32, U2>,
    b: Point<f32, U2>,
    c: Point<f32, U2>
) -> SharedShape
[src]

Initializes a triangle shape.

pub fn round_triangle(
    a: Point<f32, U2>,
    b: Point<f32, U2>,
    c: Point<f32, U2>,
    border_radius: f32
) -> SharedShape
[src]

Initializes a triangle shape with round corners.

pub fn polyline(
    vertices: Vec<Point<f32, U2>, Global>,
    indices: Option<Vec<[u32; 2], Global>>
) -> SharedShape
[src]

Initializes a polyline shape defined by its vertex and index buffers.

If no index buffer is provided, the polyline is assumed to describe a line strip.

pub fn trimesh(
    vertices: Vec<Point<f32, U2>, Global>,
    indices: Vec<[u32; 3], Global>
) -> SharedShape
[src]

Initializes a triangle mesh shape defined by its vertex and index buffers.

pub fn convex_decomposition(
    vertices: &[Point<f32, U2>],
    indices: &[[u32; 2]]
) -> SharedShape
[src]

Initializes a compound shape obtained from the decomposition of the given trimesh (in 3D) or polyline (in 2D) into convex parts.

pub fn round_convex_decomposition(
    vertices: &[Point<f32, U2>],
    indices: &[[u32; 2]],
    border_radius: f32
) -> SharedShape
[src]

Initializes a compound shape obtained from the decomposition of the given trimesh (in 3D) or polyline (in 2D) into convex parts dilated with round corners.

pub fn convex_decomposition_with_params(
    vertices: &[Point<f32, U2>],
    indices: &[[u32; 2]],
    params: &VHACDParameters
) -> SharedShape
[src]

Initializes a compound shape obtained from the decomposition of the given trimesh (in 3D) or polyline (in 2D) into convex parts.

pub fn round_convex_decomposition_with_params(
    vertices: &[Point<f32, U2>],
    indices: &[[u32; 2]],
    params: &VHACDParameters,
    border_radius: f32
) -> SharedShape
[src]

Initializes a compound shape obtained from the decomposition of the given trimesh (in 3D) or polyline (in 2D) into convex parts dilated with round corners.

pub fn convex_hull(points: &[Point<f32, U2>]) -> Option<SharedShape>[src]

Creates a new shared shape that is the convex-hull of the given points.

pub fn convex_polyline(
    points: Vec<Point<f32, U2>, Global>
) -> Option<SharedShape>
[src]

Creates a new shared shape that is a convex polygon formed by the given set of points assumed to form a convex polyline (no convex-hull will be automatically computed).

pub fn round_convex_hull(
    points: &[Point<f32, U2>],
    border_radius: f32
) -> Option<SharedShape>
[src]

Creates a new shared shape with rounded corners that is the convex-hull of the given points, dilated by border_radius.

pub fn round_convex_polyline(
    points: Vec<Point<f32, U2>, Global>,
    border_radius: f32
) -> Option<SharedShape>
[src]

Creates a new shared shape with round corners that is a convex polygon formed by the given set of points assumed to form a convex polyline (no convex-hull will be automatically computed).

pub fn heightfield(
    heights: Matrix<f32, Dynamic, U1, VecStorage<f32, Dynamic, U1>>,
    scale: Matrix<f32, U2, U1, <DefaultAllocator as Allocator<f32, U2, U1>>::Buffer>
) -> SharedShape
[src]

Initializes an heightfield shape defined by its set of height and a scale factor along each coordinate axis.

Methods from Deref<Target = dyn Shape + 'static>

pub fn as_shape<T>(&self) -> Option<&T> where
    T: Shape
[src]

Converts this abstract shape to the given shape, if it is one.

pub fn as_ball(&self) -> Option<&Ball>[src]

Converts this abstract shape to a ball, if it is one.

pub fn as_cuboid(&self) -> Option<&Cuboid>[src]

Converts this abstract shape to a cuboid, if it is one.

pub fn as_capsule(&self) -> Option<&Capsule>[src]

Converts this abstract shape to a capsule, if it is one.

pub fn as_triangle(&self) -> Option<&Triangle>[src]

Converts this abstract shape to a triangle, if it is one.

pub fn as_compound(&self) -> Option<&Compound>[src]

Converts this abstract shape to a compound shape, if it is one.

pub fn as_trimesh(&self) -> Option<&TriMesh>[src]

Converts this abstract shape to a triangle mesh, if it is one.

pub fn as_polyline(&self) -> Option<&Polyline>[src]

Converts this abstract shape to a polyline, if it is one.

pub fn as_heightfield(&self) -> Option<&HeightField>[src]

Converts this abstract shape to a heightfield, if it is one.

pub fn as_round_cuboid(&self) -> Option<&RoundShape<Cuboid>>[src]

Converts this abstract shape to a round cuboid, if it is one.

pub fn as_round_triangle(&self) -> Option<&RoundShape<Triangle>>[src]

Converts this abstract shape to a round triangle, if it is one.

pub fn as_convex_polygon(&self) -> Option<&ConvexPolygon>[src]

pub fn as_round_convex_polygon(&self) -> Option<&RoundShape<ConvexPolygon>>[src]

Converts this abstract shape to a round convex polygon, if it is one.

pub fn is<__T>(&self) -> bool where
    __T: Shape
[src]

Returns true if the trait object wraps an object of type __T.

pub fn downcast_rc<__T>(
    self: Rc<dyn Shape + 'static>
) -> Result<Rc<__T>, Rc<dyn Shape + 'static>> where
    __T: Shape
[src]

Returns an Rc-ed object from an Rc-ed trait object if the underlying object is of type __T. Returns the original Rc-ed trait if it isn’t.

pub fn downcast_ref<__T>(&self) -> Option<&__T> where
    __T: Shape
[src]

Returns a reference to the object within the trait object if it is of type __T, or None if it isn’t.

pub fn downcast_arc<__T>(
    self: Arc<dyn Shape + 'static>
) -> Result<Arc<__T>, Arc<dyn Shape + 'static>> where
    __T: Shape + Any + Send + Sync
[src]

Returns an Arc-ed object from an Arc-ed trait object if the underlying object is of type __T. Returns the original Arc-ed trait if it isn’t.

Trait Implementations

impl Clone for SharedShape[src]

impl Deref for SharedShape[src]

type Target = dyn Shape + 'static

The resulting type after dereferencing.

Auto Trait Implementations

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> Downcast for T where
    T: Any
[src]

impl<T> DowncastSync for T where
    T: Send + Sync + Any
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> Pointable for T

type Init = T

The type for initializers.

impl<T> Same<T> for T

type Output = T

Should always be Self

impl<SS, SP> SupersetOf<SS> for SP where
    SS: SubsetOf<SP>, 
[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

impl<V, T> VZip<V> for T where
    V: MultiLane<T>,