PxParticleRigidBuffer

Defined in include/PxParticleBuffer.h

Inheritance Relationships

Base Type

class PxParticleRigidBuffer : public PxParticleBuffer

A particle buffer used to simulate rigid bodies using shape matching with particles.

See PxPhysics::createParticleRigidBuffer.

Public Functions

virtual PxU32 *getRigidOffsets() const = 0

Get the particle indices of the first particle for each shape matched rigid body.

Returns

A device buffer containing the list of particle start indices of each shape matched rigid body.

virtual PxReal *getRigidCoefficients() const = 0

Get the stiffness coefficients for all shape matched rigid bodies in this buffer.

Stiffness must be in the range [0, 1].

Returns

A device buffer containing the list of stiffness coefficients for each rigid body.

virtual PxVec4 *getRigidLocalPositions() const = 0

Get the local position of each particle relative to the rigid body’s center of mass.

Returns

A pointer to a device buffer containing the local position for each particle.

virtual PxVec4 *getRigidTranslations() const = 0

Get the world-space translations for all rigid bodies in this buffer.

Returns

A pointer to a device buffer containing the world-space translations for all shape-matched rigid bodies in this buffer.

virtual PxVec4 *getRigidRotations() const = 0

Get the world-space rotation of every shape-matched rigid body in this buffer.

Rotations are specified as quaternions.

Returns

A pointer to a device buffer containing the world-space rotation for every shape-matched rigid body in this buffer.

virtual PxVec4 *getRigidLocalNormals() const = 0

Get the local space normals for each particle relative to the shape of the corresponding rigid body.

The 4th component of every PxVec4 should be the negative signed distance of the particle inside its shape.

Returns

A pointer to a device buffer containing the local-space normals for each particle.

virtual void setNbRigids(PxU32 nbRigids) = 0

Set the number of shape matched rigid bodies in this buffer.

Parameters

nbRigids[in] The number of shape matched rigid bodies

virtual PxU32 getNbRigids() const = 0

Get the number of shape matched rigid bodies in this buffer.

Returns

The number of shape matched rigid bodies in this buffer.

virtual PxVec4 *getPositionInvMasses() const = 0

Get positions and inverse masses for this particle buffer.

Returns

A pointer to a device buffer containing the positions and inverse mass packed as PxVec4(pos.x, pos.y, pos.z, inverseMass).

virtual PxVec4 *getVelocities() const = 0

Get velocities for this particle buffer.

Returns

A pointer to a device buffer containing the velocities packed as PxVec4(vel.x, vel.y, vel.z, 0.0f).

virtual PxU32 *getPhases() const = 0

Get phases for this particle buffer.

See #PxParticlePhase

Returns

A pointer to a device buffer containing the per-particle phases for this particle buffer.

virtual PxParticleVolume *getParticleVolumes() const = 0

Get particle volumes for this particle buffer.

See PxParticleVolume

Returns

A pointer to a device buffer containing the PxParticleVolume s for this particle buffer.

virtual void setNbActiveParticles(PxU32 nbActiveParticles) = 0

Set the number of active particles for this particle buffer.

The number of active particles can be <= PxParticleBuffer::getMaxParticles(). The particle system will simulate the first x particles in the PxParticleBuffer, where x is the number of active particles.

Parameters

nbActiveParticles[in] The number of active particles.

virtual PxU32 getNbActiveParticles() const = 0

Get the number of active particles for this particle buffer.

Returns

The number of active particles.

virtual PxU32 getMaxParticles() const = 0

Get the maximum number particles this particle buffer can hold.

The maximum number of particles is specified when creating a PxParticleBuffer. See PxPhysics::createParticleBuffer.

Returns

The maximum number of particles.

virtual PxU32 getNbParticleVolumes() const = 0

Get the number of particle volumes in this particle buffer.

Returns

The number of PxParticleVolume s for this particle buffer.

virtual void setNbParticleVolumes(PxU32 nbParticleVolumes) = 0

Set the number of PxParticleVolume s for this particle buffer.

Parameters

nbParticleVolumes[in] The number of particle volumes in this particle buffer.

virtual PxU32 getMaxParticleVolumes() const = 0

Get the maximum number of particle volumes this particle buffer can hold.

See PxParticleVolume.

Returns

The maximum number of particle volumes this particle buffer can hold.

virtual void setRigidFilters(PxParticleRigidFilterPair *filters, PxU32 nbFilters) = 0

Set the PxParticleRigidFilterPair s for collision filtering of particles in this buffer with rigid bodies.

See PxParticleRigidFilterPair

Parameters
  • filters[in] A device buffer containing PxParticleRigidFilterPair s.

  • nbFilters[in] The number of particle-rigid body collision filtering pairs.

virtual void setRigidAttachments(PxParticleRigidAttachment *attachments, PxU32 nbAttachments) = 0

Set the particle-rigid body attachments for particles in this particle buffer.

See PxParticleRigidAttachment

Parameters
  • attachments[in] A device buffer containing PxParticleRigidAttachment s.

  • nbAttachments[in] The number of particle-rigid body attachments.

virtual PxU32 getFlatListStartIndex() const = 0

Get the start index for the first particle of this particle buffer in the complete list of particles of the particle system this buffer is used in.

The return value is only correct if the particle buffer is assigned to a particle system and at least one call to simulate() has been performed.

Returns

The index of the first particle in the complete particle list.

virtual void raiseFlags(PxParticleBufferFlag::Enum flags) = 0

Raise dirty flags on this particle buffer to communicate that the corresponding data has been updated by the user.

See PxParticleBufferFlag.

Parameters

flags[in] The flag corresponding to the data that is dirty.

virtual void release() = 0

Release this buffer and deallocate all the memory.

virtual void onParticleSystemDestroy() = 0

Cleanup helper used in case a particle system is released before the particle buffers have been removed.

virtual void setInternalData(void *data) = 0

Reserved for internal use.

virtual const char *getConcreteTypeName() const = 0

Returns string name of dynamic type.

Returns

Class name of most derived type of this object.

template<class T>
inline T *is()
template<class T>
inline const T *is() const
inline PxType getConcreteType() const

Returns concrete type of object.

See also

PxConcreteType

Returns

PxConcreteType::Enum of serialized object

inline void setBaseFlag(PxBaseFlag::Enum flag, bool value)

Set PxBaseFlag

Parameters
  • flag[in] The flag to be set

  • value[in] The flags new value

inline void setBaseFlags(PxBaseFlags inFlags)

Set PxBaseFlags

See also

PxBaseFlags

Parameters

inFlags[in] The flags to be set

inline PxBaseFlags getBaseFlags() const

Returns PxBaseFlags.

See also

PxBaseFlags

Returns

PxBaseFlags

inline virtual bool isReleasable() const

Whether the object is subordinate.

A class is subordinate, if it can only be instantiated in the context of another class.

Returns

Whether the class is subordinate

Public Members

PxU32 bufferIndex

Index of this buffer in the particle system it is assigned to.

const PxU32 bufferUniqueId

Unique index that does not change over the lifetime of a PxParticleBuffer.

Protected Functions

inline virtual ~PxParticleRigidBuffer()
inline PxParticleRigidBuffer(PxU32 uniqueId)
inline virtual bool isKindOf(const char *superClass) const

Returns whether a given type name matches with the type of this instance.

template<class T>
inline bool typeMatch() const

Protected Attributes

PxType mConcreteType
PxBaseFlags mBaseFlags
PxU32 mBuiltInRefCount