| Bullet Collision Detection & Physics Library
    | 
 
 
 
Go to the documentation of this file.
   32                                                                                 m_softBodySolver(softBodySolver),
 
   73                 BT_PROFILE(
"predictUnconstraintMotionSoftBody");
 
   85                 btAssert(
"Solver initialization failed\n");
 
  129                                                                                  collisionFilterGroup,
 
  130                                                                                  collisionFilterMask);
 
  197                 btVector3 rayDir = (rayToWorld - rayFromWorld);
 
  225 #ifdef RECALCULATE_AABB 
  226                         btVector3 collisionObjectAabbMin,collisionObjectAabbMax;
 
  256 #ifndef USE_BRUTEFORCE_RAYBROADPHASE 
  263 #endif  //USE_BRUTEFORCE_RAYBROADPHASE 
  293                                                 if (normal.
dot(rayDir) > 0)
 
  304                                         bool normalInWorldSpace = 
true;
 
  
btIDebugDraw * m_debugDrawer
btCollisionObject can be used to manage collision detection objects.
static void DrawClusterTree(btSoftBody *psb, btIDebugDraw *idraw, int mindepth=0, int maxdepth=-1)
The btBroadphaseProxy is the main class that can be used with the Bullet broadphases.
static void solveClusters(const btAlignedObjectArray< btSoftBody * > &bodies)
btSoftBodyArray m_softBodies
#define btAlignedFree(ptr)
btSoftBodySolver * m_softBodySolver
Solver classes that encapsulate multiple soft bodies for solving.
const btSoftRigidDynamicsWorld * m_world
static void rayTestSingle(const btTransform &rayFromTrans, const btTransform &rayToTrans, btCollisionObject *collisionObject, const btCollisionShape *collisionShape, const btTransform &colObjWorldTransform, RayResultCallback &resultCallback)
rayTestSingle performs a raycast call and calls the resultCallback.
virtual btIDebugDraw * getDebugDrawer()
void setValue(const btScalar &_x, const btScalar &_y, const btScalar &_z)
float btScalar
The btScalar type abstracts floating point numbers, to easily switch between double and single floati...
void defaultCollisionHandler(const btCollisionObjectWrapper *pcoWrap)
float getTimeScale()
Return the timescale that the simulation is using.
virtual const char * serialize(void *dataBuffer, class btSerializer *serializer) const
fills the dataBuffer and returns the struct name (and 0 on failure)
The btDispatcher interface class can be used in combination with broadphase to dispatch calculations ...
static void DrawNodeTree(btSoftBody *psb, btIDebugDraw *idraw, int mindepth=0, int maxdepth=-1)
virtual ~btSoftRigidDynamicsWorld()
virtual void solveConstraints(float solverdt)=0
Solve constraints for a set of soft bodies.
btSoftSingleRayCallback(const btVector3 &rayFromWorld, const btVector3 &rayToWorld, const btSoftRigidDynamicsWorld *world, btCollisionWorld::RayResultCallback &resultCallback)
btDispatcher * m_dispatcher
void solveSoftBodiesConstraints(btScalar timeStep)
btAlignedObjectArray< btCollisionObject * > m_collisionObjects
static const btSoftBody * upcast(const btCollisionObject *colObj)
btSoftBodyWorldInfo m_sbi
virtual int getDebugMode() const =0
btScalar dot(const btVector3 &v) const
Return the dot product.
virtual void removeCollisionObject(btCollisionObject *collisionObject)
removeCollisionObject will first check if it is a rigid body, if so call removeRigidBody otherwise ca...
virtual void removeCollisionObject(btCollisionObject *collisionObject)
removeCollisionObject will first check if it is a rigid body, if so call removeRigidBody otherwise ca...
btBroadphaseInterface * m_broadphasePairCache
#define btAlignedAlloc(size, alignment)
static void DrawFrame(btSoftBody *psb, btIDebugDraw *idraw)
void removeSoftBody(btSoftBody *body)
virtual bool process(const btBroadphaseProxy *proxy)
btTransform & getWorldTransform()
The btCollisionShape class provides an interface for collision shapes that can be shared among btColl...
btScalar fraction
feature index
btScalar m_closestHitFraction
virtual void debugDrawWorld()
virtual void predictUnconstraintMotion(btScalar timeStep)
virtual void optimize(btAlignedObjectArray< btSoftBody * > &softBodies, bool forceUpdate=false)=0
Optimize soft bodies in this solver.
virtual void debugDrawWorld()
void setSoftBodySolver(btSoftBodySolver *softBodySolver)
btTransform m_rayFromTrans
btBroadphaseProxy * getBroadphaseHandle()
virtual void getAabb(const btTransform &t, btVector3 &aabbMin, btVector3 &aabbMax) const =0
getAabb returns the axis aligned bounding box in the coordinate frame of the given transform t.
int getNumCollisionObjects() const
virtual void serialize(btSerializer *serializer)
Preliminary serialization test for Bullet 2.76. Loading those files requires a separate parser (see B...
virtual void rayTest(const btVector3 &rayFrom, const btVector3 &rayTo, btBroadphaseRayCallback &rayCallback, const btVector3 &aabbMin=btVector3(0, 0, 0), const btVector3 &aabbMax=btVector3(0, 0, 0))=0
static void rayTestSingle(const btTransform &rayFromTrans, const btTransform &rayToTrans, btCollisionObject *collisionObject, const btCollisionShape *collisionShape, const btTransform &colObjWorldTransform, RayResultCallback &resultCallback)
rayTestSingle performs a raycast call and calls the resultCallback.
virtual int calculateSerializeBufferSize() const
void Initialize(int hashsize=2383, int clampCells=256 *1024)
virtual void predictUnconstraintMotion(btScalar timeStep)
virtual void finalizeChunk(btChunk *chunk, const char *structType, int chunkCode, void *oldPtr)=0
btVector3 can be used to represent 3D points and vectors.
void addSoftBody(btSoftBody *body, int collisionFilterGroup=btBroadphaseProxy::DefaultFilter, int collisionFilterMask=btBroadphaseProxy::AllFilter)
LocalShapeInfo gives extra information for complex shapes Currently, only btTriangleMeshShape is avai...
virtual void finishSerialization()=0
virtual void startSerialization()=0
void serializeSoftBodies(btSerializer *serializer)
virtual void internalSingleStepSimulation(btScalar timeStep)
virtual bool needsCollision(btBroadphaseProxy *proxy0) const
bool rayTest(const btVector3 &rayFrom, const btVector3 &rayTo, sRayCast &results)
Ray casting using rayFrom and rayTo in worldspace, (not direction!)
virtual void removeCollisionObject(btCollisionObject *collisionObject)
btSoftRigidDynamicsWorld(btDispatcher *dispatcher, btBroadphaseInterface *pairCache, btConstraintSolver *constraintSolver, btCollisionConfiguration *collisionConfiguration, btSoftBodySolver *softBodySolver=0)
The btSoftBody is an class to simulate cloth and volumetric soft bodies.
virtual void updateSoftBodies()=0
Perform necessary per-step updates of soft bodies such as recomputing normals and bounding boxes.
The btBroadphaseInterface class provides an interface to detect aabb-overlapping object pairs.
virtual ~btSoftBodySolver()
static void rayTestSingle(const btTransform &rayFromTrans, const btTransform &rayToTrans, btCollisionObject *collisionObject, const btCollisionShape *collisionShape, const btTransform &colObjWorldTransform, RayResultCallback &resultCallback)
rayTestSingle performs a raycast call and calls the resultCallback.
btSoftBodyArray & getSoftBodyArray()
int getInternalType() const
reserved for Bullet internal usage
virtual btScalar addSingleResult(LocalRayResult &rayResult, bool normalInWorldSpace)=0
virtual void predictMotion(float solverdt)=0
Predict motion of soft bodies into next timestep.
const btSoftMultiBodyDynamicsWorld * m_world
void serializeRigidBodies(btSerializer *serializer)
static void Draw(btSoftBody *psb, btIDebugDraw *idraw, int drawflags=fDrawFlags::Std)
void serializeCollisionObjects(btSerializer *serializer)
btDiscreteDynamicsWorld provides discrete rigid body simulation those classes replace the obsolete Cc...
virtual void addCollisionObject(btCollisionObject *collisionObject, int collisionFilterGroup=btBroadphaseProxy::DefaultFilter, int collisionFilterMask=btBroadphaseProxy::AllFilter)
RayResultCallback is used to report new raycast results.
void push_back(const T &_Val)
btBroadphaseInterface * m_broadphase
eFeature::_ feature
soft body
btSparseSdf< 3 > m_sparsesdf
btCollisionConfiguration allows to configure Bullet collision detection stack allocator size,...
static void DrawFaceTree(btSoftBody *psb, btIDebugDraw *idraw, int mindepth=0, int maxdepth=-1)
void remove(const T &key)
btVector3 & normalize()
Normalize this vector x^2 + y^2 + z^2 = 1.
btCollisionWorld::RayResultCallback & m_resultCallback
virtual bool checkInitialized()=0
Ensure that this solver is initialized.
virtual btChunk * allocate(size_t size, int numElements)=0
virtual void rayTest(const btVector3 &rayFromWorld, const btVector3 &rayToWorld, RayResultCallback &resultCallback) const
rayTest performs a raycast on all objects in the btCollisionWorld, and calls the resultCallback This ...
virtual void internalSingleStepSimulation(btScalar timeStep)
void serializeDynamicsWorldInfo(btSerializer *serializer)
int size() const
return the number of elements in the array
btVector3 m_rayDirectionInverse
added some cached data to accelerate ray-AABB tests
const btCollisionShape * getCollisionShape() const