mirror of
https://github.com/bulletphysics/bullet3
synced 2024-12-14 22:00:05 +00:00
more compounds work, the basics work. now some stackless tree-tree traversal is needed to speedup compound versus compound.
This commit is contained in:
parent
fdaa3a7abc
commit
50a2694c5b
@ -25,6 +25,7 @@ CollisionObject::CollisionObject()
|
|||||||
m_ccdSweptShereRadius(0.f),
|
m_ccdSweptShereRadius(0.f),
|
||||||
m_ccdSquareMotionTreshold(0.f)
|
m_ccdSquareMotionTreshold(0.f)
|
||||||
{
|
{
|
||||||
|
m_cachedInvertedWorldTransform.setIdentity();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -39,6 +39,8 @@ struct CollisionObject
|
|||||||
//it can be either previous or future (predicted) transform
|
//it can be either previous or future (predicted) transform
|
||||||
SimdTransform m_interpolationWorldTransform;
|
SimdTransform m_interpolationWorldTransform;
|
||||||
|
|
||||||
|
SimdTransform m_cachedInvertedWorldTransform;
|
||||||
|
|
||||||
enum CollisionFlags
|
enum CollisionFlags
|
||||||
{
|
{
|
||||||
isStatic = 1,
|
isStatic = 1,
|
||||||
|
@ -72,11 +72,20 @@ void CompoundCollisionAlgorithm::ProcessCollision (BroadphaseProxy* ,BroadphaseP
|
|||||||
//temporarily exchange parent CollisionShape with childShape, and recurse
|
//temporarily exchange parent CollisionShape with childShape, and recurse
|
||||||
CollisionShape* childShape = compoundShape->GetChildShape(i);
|
CollisionShape* childShape = compoundShape->GetChildShape(i);
|
||||||
CollisionObject* colObj = static_cast<CollisionObject*>(m_childProxies[i].m_clientObject);
|
CollisionObject* colObj = static_cast<CollisionObject*>(m_childProxies[i].m_clientObject);
|
||||||
|
|
||||||
|
//backup
|
||||||
|
SimdTransform orgTrans = colObj->m_worldTransform;
|
||||||
CollisionShape* orgShape = colObj->m_collisionShape;
|
CollisionShape* orgShape = colObj->m_collisionShape;
|
||||||
|
|
||||||
|
SimdTransform childTrans = compoundShape->GetChildTransform(i);
|
||||||
|
SimdTransform newChildWorldTrans = orgTrans*childTrans ;
|
||||||
|
colObj->m_worldTransform = newChildWorldTrans;
|
||||||
|
|
||||||
colObj->m_collisionShape = childShape;
|
colObj->m_collisionShape = childShape;
|
||||||
m_childCollisionAlgorithms[i]->ProcessCollision(&m_childProxies[i],&m_otherProxy,dispatchInfo);
|
m_childCollisionAlgorithms[i]->ProcessCollision(&m_childProxies[i],&m_otherProxy,dispatchInfo);
|
||||||
//revert back
|
//revert back
|
||||||
colObj->m_collisionShape =orgShape;
|
colObj->m_collisionShape =orgShape;
|
||||||
|
colObj->m_worldTransform = orgTrans;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -31,8 +31,12 @@ void ManifoldResult::AddContactPoint(const SimdVector3& normalOnBInWorld,const S
|
|||||||
if (depth > m_manifoldPtr->GetContactBreakingTreshold())
|
if (depth > m_manifoldPtr->GetContactBreakingTreshold())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
SimdTransform transAInv = m_body0->m_worldTransform.inverse();
|
|
||||||
SimdTransform transBInv= m_body1->m_worldTransform.inverse();
|
SimdTransform transAInv = m_body0->m_cachedInvertedWorldTransform;
|
||||||
|
SimdTransform transBInv= m_body1->m_cachedInvertedWorldTransform;
|
||||||
|
|
||||||
|
//transAInv = m_body0->m_worldTransform.inverse();
|
||||||
|
//transBInv= m_body1->m_worldTransform.inverse();
|
||||||
SimdVector3 pointA = pointInWorld + normalOnBInWorld * depth;
|
SimdVector3 pointA = pointInWorld + normalOnBInWorld * depth;
|
||||||
SimdVector3 localA = transAInv(pointA );
|
SimdVector3 localA = transAInv(pointA );
|
||||||
SimdVector3 localB = transBInv(pointInWorld);
|
SimdVector3 localB = transBInv(pointInWorld);
|
||||||
|
@ -113,6 +113,7 @@ void SimulationIslandManager::StoreIslandActivationState(CollisionWorld* colWorl
|
|||||||
//
|
//
|
||||||
void SimulationIslandManager::BuildAndProcessIslands(Dispatcher* dispatcher,CollisionObjectArray& collisionObjects, IslandCallback* callback)
|
void SimulationIslandManager::BuildAndProcessIslands(Dispatcher* dispatcher,CollisionObjectArray& collisionObjects, IslandCallback* callback)
|
||||||
{
|
{
|
||||||
|
|
||||||
int numBodies = collisionObjects.size();
|
int numBodies = collisionObjects.size();
|
||||||
|
|
||||||
for (int islandId=0;islandId<numBodies;islandId++)
|
for (int islandId=0;islandId<numBodies;islandId++)
|
||||||
@ -128,8 +129,10 @@ void SimulationIslandManager::BuildAndProcessIslands(Dispatcher* dispatcher,Coll
|
|||||||
for (i=0;i<numBodies;i++)
|
for (i=0;i<numBodies;i++)
|
||||||
{
|
{
|
||||||
CollisionObject* colObj0 = collisionObjects[i];
|
CollisionObject* colObj0 = collisionObjects[i];
|
||||||
|
|
||||||
if (colObj0->m_islandTag1 == islandId)
|
if (colObj0->m_islandTag1 == islandId)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (colObj0->GetActivationState()== ACTIVE_TAG)
|
if (colObj0->GetActivationState()== ACTIVE_TAG)
|
||||||
{
|
{
|
||||||
allSleeping = false;
|
allSleeping = false;
|
||||||
|
@ -77,6 +77,7 @@ void CompoundShape::CalculateLocalInertia(SimdScalar mass,SimdVector3& inertia)
|
|||||||
{
|
{
|
||||||
//approximation: take the inertia from the aabb for now
|
//approximation: take the inertia from the aabb for now
|
||||||
SimdTransform ident;
|
SimdTransform ident;
|
||||||
|
ident.setIdentity();
|
||||||
SimdVector3 aabbMin,aabbMax;
|
SimdVector3 aabbMin,aabbMax;
|
||||||
GetAabb(ident,aabbMin,aabbMax);
|
GetAabb(ident,aabbMin,aabbMax);
|
||||||
|
|
||||||
|
@ -54,7 +54,7 @@ subject to the following restrictions:
|
|||||||
|
|
||||||
float deltaTime = 1.f/60.f;
|
float deltaTime = 1.f/60.f;
|
||||||
float bulletSpeed = 40.f;
|
float bulletSpeed = 40.f;
|
||||||
bool createConstraint = true;
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
#if _MSC_VER >= 1310
|
#if _MSC_VER >= 1310
|
||||||
//only use SIMD Hull code under Win32
|
//only use SIMD Hull code under Win32
|
||||||
@ -89,6 +89,9 @@ extern int glutScreenHeight;
|
|||||||
const int maxProxies = 32766;
|
const int maxProxies = 32766;
|
||||||
const int maxOverlap = 65535;
|
const int maxOverlap = 65535;
|
||||||
|
|
||||||
|
bool createConstraint = true;//false;
|
||||||
|
bool useCompound = true;//false;
|
||||||
|
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
const int numObjects = 20;
|
const int numObjects = 20;
|
||||||
@ -124,7 +127,7 @@ CollisionShape* shapePtr[numShapes] =
|
|||||||
#ifdef USE_GROUND_PLANE
|
#ifdef USE_GROUND_PLANE
|
||||||
new StaticPlaneShape(SimdVector3(0,1,0),10),
|
new StaticPlaneShape(SimdVector3(0,1,0),10),
|
||||||
#else
|
#else
|
||||||
new BoxShape (SimdVector3(450,10,450)),
|
new BoxShape (SimdVector3(50,10,50)),
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
new BoxShape (SimdVector3(CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS)),
|
new BoxShape (SimdVector3(CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS)),
|
||||||
@ -170,7 +173,7 @@ int main(int argc,char** argv)
|
|||||||
#endif
|
#endif
|
||||||
physicsEnvironmentPtr->setDeactivationTime(2.f);
|
physicsEnvironmentPtr->setDeactivationTime(2.f);
|
||||||
|
|
||||||
physicsEnvironmentPtr->setGravity(0,-10,0);
|
physicsEnvironmentPtr->setGravity(0,-10,0);//0,0);//-10,0);
|
||||||
PHY_ShapeProps shapeProps;
|
PHY_ShapeProps shapeProps;
|
||||||
|
|
||||||
shapeProps.m_do_anisotropic = false;
|
shapeProps.m_do_anisotropic = false;
|
||||||
@ -205,13 +208,19 @@ int main(int argc,char** argv)
|
|||||||
shapeIndex[i] = 0;
|
shapeIndex[i] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
CompoundShape* compoundShape = new CompoundShape();
|
if (useCompound)
|
||||||
//shapePtr[1] = compoundShape;
|
{
|
||||||
|
CompoundShape* compoundShape = new CompoundShape();
|
||||||
|
CollisionShape* oldShape = shapePtr[1];
|
||||||
|
shapePtr[1] = compoundShape;
|
||||||
|
|
||||||
SimdTransform ident;
|
SimdTransform ident;
|
||||||
ident.setIdentity();
|
ident.setIdentity();
|
||||||
|
ident.setOrigin(SimdVector3(0,0,0));
|
||||||
compoundShape->AddChildShape(ident,new BoxShape (SimdVector3(CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS)));
|
compoundShape->AddChildShape(ident,oldShape);//
|
||||||
|
ident.setOrigin(SimdVector3(0,0,2));
|
||||||
|
compoundShape->AddChildShape(ident,new SphereShape(0.9));//
|
||||||
|
}
|
||||||
|
|
||||||
for (i=0;i<numObjects;i++)
|
for (i=0;i<numObjects;i++)
|
||||||
{
|
{
|
||||||
@ -509,11 +518,13 @@ void renderme()
|
|||||||
ident.setIdentity();
|
ident.setIdentity();
|
||||||
ident.getOpenGLMatrix(vec);
|
ident.getOpenGLMatrix(vec);
|
||||||
glPushMatrix();
|
glPushMatrix();
|
||||||
glLoadMatrixf(vec);
|
|
||||||
|
glLoadMatrixf(vec);
|
||||||
|
|
||||||
GL_ShapeDrawer::DrawOpenGL(m,physObjects[i]->GetRigidBody()->GetCollisionShape(),wireColor,getDebugMode());
|
GL_ShapeDrawer::DrawOpenGL(m,physObjects[i]->GetRigidBody()->GetCollisionShape(),wireColor,getDebugMode());
|
||||||
|
|
||||||
glPopMatrix();
|
glPopMatrix();
|
||||||
|
|
||||||
///this block is just experimental code to show some internal issues with replacing shapes on the fly.
|
///this block is just experimental code to show some internal issues with replacing shapes on the fly.
|
||||||
if (getDebugMode()!=0 && (i>0))
|
if (getDebugMode()!=0 && (i>0))
|
||||||
{
|
{
|
||||||
@ -668,6 +679,9 @@ void clientDisplay(void) {
|
|||||||
|
|
||||||
|
|
||||||
physicsEnvironmentPtr->UpdateAabbs(deltaTime);
|
physicsEnvironmentPtr->UpdateAabbs(deltaTime);
|
||||||
|
//draw contactpoints
|
||||||
|
physicsEnvironmentPtr->CallbackTriggers();
|
||||||
|
|
||||||
|
|
||||||
renderme();
|
renderme();
|
||||||
|
|
||||||
|
@ -52,6 +52,7 @@ void GLDebugDrawer::DrawContactPoint(const SimdVector3& pointOnB,const SimdVecto
|
|||||||
glVertex3d(to.getX(), to.getY(), to.getZ());
|
glVertex3d(to.getX(), to.getY(), to.getZ());
|
||||||
glEnd();
|
glEnd();
|
||||||
|
|
||||||
|
|
||||||
glRasterPos3f(from.x(), from.y(), from.z());
|
glRasterPos3f(from.x(), from.y(), from.z());
|
||||||
char buf[12];
|
char buf[12];
|
||||||
sprintf(buf," %d",lifeTime);
|
sprintf(buf," %d",lifeTime);
|
||||||
|
@ -114,7 +114,7 @@ void GL_ShapeDrawer::DrawOpenGL(float* m, const CollisionShape* shape, const Sim
|
|||||||
if (shape->GetShapeType() == COMPOUND_SHAPE_PROXYTYPE)
|
if (shape->GetShapeType() == COMPOUND_SHAPE_PROXYTYPE)
|
||||||
{
|
{
|
||||||
const CompoundShape* compoundShape = static_cast<const CompoundShape*>(shape);
|
const CompoundShape* compoundShape = static_cast<const CompoundShape*>(shape);
|
||||||
for (int i=0;i<compoundShape->GetNumChildShapes();i++)
|
for (int i=compoundShape->GetNumChildShapes()-1;i>=0;i--)
|
||||||
{
|
{
|
||||||
SimdTransform childTrans = compoundShape->GetChildTransform(i);
|
SimdTransform childTrans = compoundShape->GetChildTransform(i);
|
||||||
const CollisionShape* colShape = compoundShape->GetChildShape(i);
|
const CollisionShape* colShape = compoundShape->GetChildShape(i);
|
||||||
@ -123,16 +123,15 @@ void GL_ShapeDrawer::DrawOpenGL(float* m, const CollisionShape* shape, const Sim
|
|||||||
DrawOpenGL(childMat,colShape,color,debugMode);
|
DrawOpenGL(childMat,colShape,color,debugMode);
|
||||||
}
|
}
|
||||||
|
|
||||||
return;
|
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
//DrawCoordSystem();
|
//DrawCoordSystem();
|
||||||
|
|
||||||
glPushMatrix();
|
//glPushMatrix();
|
||||||
glEnable(GL_COLOR_MATERIAL);
|
glEnable(GL_COLOR_MATERIAL);
|
||||||
glColor3f(color.x(),color.y(), color.z());
|
glColor3f(color.x(),color.y(), color.z());
|
||||||
|
|
||||||
glRasterPos3f(0.0, 0.0, 0.0);
|
|
||||||
|
|
||||||
bool useWireframeFallback = true;
|
bool useWireframeFallback = true;
|
||||||
|
|
||||||
@ -268,6 +267,7 @@ void GL_ShapeDrawer::DrawOpenGL(float* m, const CollisionShape* shape, const Sim
|
|||||||
|
|
||||||
if (debugMode==IDebugDraw::DBG_DrawFeaturesText)
|
if (debugMode==IDebugDraw::DBG_DrawFeaturesText)
|
||||||
{
|
{
|
||||||
|
glRasterPos3f(0.0, 0.0, 0.0);
|
||||||
BMF_DrawString(BMF_GetFont(BMF_kHelvetica10),polyshape->GetExtraDebugInfo());
|
BMF_DrawString(BMF_GetFont(BMF_kHelvetica10),polyshape->GetExtraDebugInfo());
|
||||||
|
|
||||||
glColor3f(1.f, 1.f, 1.f);
|
glColor3f(1.f, 1.f, 1.f);
|
||||||
@ -329,7 +329,7 @@ void GL_ShapeDrawer::DrawOpenGL(float* m, const CollisionShape* shape, const Sim
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
glDisable(GL_DEPTH_BUFFER_BIT);
|
/*glDisable(GL_DEPTH_BUFFER_BIT);
|
||||||
if (debugMode==IDebugDraw::DBG_DrawText)
|
if (debugMode==IDebugDraw::DBG_DrawText)
|
||||||
{
|
{
|
||||||
BMF_DrawString(BMF_GetFont(BMF_kHelvetica10),shape->GetName());
|
BMF_DrawString(BMF_GetFont(BMF_kHelvetica10),shape->GetName());
|
||||||
@ -340,7 +340,9 @@ void GL_ShapeDrawer::DrawOpenGL(float* m, const CollisionShape* shape, const Sim
|
|||||||
BMF_DrawString(BMF_GetFont(BMF_kHelvetica10),shape->GetExtraDebugInfo());
|
BMF_DrawString(BMF_GetFont(BMF_kHelvetica10),shape->GetExtraDebugInfo());
|
||||||
}
|
}
|
||||||
glEnable(GL_DEPTH_BUFFER_BIT);
|
glEnable(GL_DEPTH_BUFFER_BIT);
|
||||||
glPopMatrix();
|
*/
|
||||||
|
|
||||||
|
// glPopMatrix();
|
||||||
}
|
}
|
||||||
glPopMatrix();
|
glPopMatrix();
|
||||||
|
|
||||||
|
@ -387,6 +387,7 @@ void CcdPhysicsEnvironment::addCcdPhysicsController(CcdPhysicsController* ctrl)
|
|||||||
|
|
||||||
const SimdTransform& t = ctrl->GetRigidBody()->getCenterOfMassTransform();
|
const SimdTransform& t = ctrl->GetRigidBody()->getCenterOfMassTransform();
|
||||||
|
|
||||||
|
body->m_cachedInvertedWorldTransform = body->m_worldTransform.inverse();
|
||||||
|
|
||||||
SimdPoint3 minAabb,maxAabb;
|
SimdPoint3 minAabb,maxAabb;
|
||||||
|
|
||||||
@ -638,6 +639,9 @@ bool CcdPhysicsEnvironment::proceedDeltaTimeOneStep(float timeStep)
|
|||||||
CcdPhysicsController* ctrl = m_controllers[k];
|
CcdPhysicsController* ctrl = m_controllers[k];
|
||||||
// SimdTransform predictedTrans;
|
// SimdTransform predictedTrans;
|
||||||
RigidBody* body = ctrl->GetRigidBody();
|
RigidBody* body = ctrl->GetRigidBody();
|
||||||
|
|
||||||
|
body->m_cachedInvertedWorldTransform = body->m_worldTransform.inverse();
|
||||||
|
|
||||||
if (body->IsActive())
|
if (body->IsActive())
|
||||||
{
|
{
|
||||||
if (!body->IsStatic())
|
if (!body->IsStatic())
|
||||||
@ -1558,10 +1562,10 @@ void CcdPhysicsEnvironment::requestCollisionCallback(PHY_IPhysicsController* ctr
|
|||||||
|
|
||||||
void CcdPhysicsEnvironment::CallbackTriggers()
|
void CcdPhysicsEnvironment::CallbackTriggers()
|
||||||
{
|
{
|
||||||
/*
|
|
||||||
CcdPhysicsController* ctrl0=0,*ctrl1=0;
|
CcdPhysicsController* ctrl0=0,*ctrl1=0;
|
||||||
|
|
||||||
if (m_triggerCallbacks[PHY_OBJECT_RESPONSE])
|
if (m_triggerCallbacks[PHY_OBJECT_RESPONSE] || (m_debugDrawer && (m_debugDrawer->GetDebugMode() & IDebugDraw::DBG_DrawContactPoints)))
|
||||||
{
|
{
|
||||||
//walk over all overlapping pairs, and if one of the involved bodies is registered for trigger callback, perform callback
|
//walk over all overlapping pairs, and if one of the involved bodies is registered for trigger callback, perform callback
|
||||||
int numManifolds = m_collisionWorld->GetDispatcher()->GetNumManifolds();
|
int numManifolds = m_collisionWorld->GetDispatcher()->GetNumManifolds();
|
||||||
@ -1571,6 +1575,16 @@ void CcdPhysicsEnvironment::CallbackTriggers()
|
|||||||
int numContacts = manifold->GetNumContacts();
|
int numContacts = manifold->GetNumContacts();
|
||||||
if (numContacts)
|
if (numContacts)
|
||||||
{
|
{
|
||||||
|
if (m_debugDrawer && (m_debugDrawer->GetDebugMode() & IDebugDraw::DBG_DrawContactPoints))
|
||||||
|
{
|
||||||
|
for (int j=0;j<numContacts;j++)
|
||||||
|
{
|
||||||
|
SimdVector3 color(1,0,0);
|
||||||
|
const ManifoldPoint& cp = manifold->GetContactPoint(j);
|
||||||
|
if (m_debugDrawer)
|
||||||
|
m_debugDrawer->DrawContactPoint(cp.m_positionWorldOnB,cp.m_normalWorldOnB,cp.GetDistance(),cp.GetLifeTime(),color);
|
||||||
|
}
|
||||||
|
}
|
||||||
RigidBody* obj0 = static_cast<RigidBody* >(manifold->GetBody0());
|
RigidBody* obj0 = static_cast<RigidBody* >(manifold->GetBody0());
|
||||||
RigidBody* obj1 = static_cast<RigidBody* >(manifold->GetBody1());
|
RigidBody* obj1 = static_cast<RigidBody* >(manifold->GetBody1());
|
||||||
|
|
||||||
@ -1596,7 +1610,7 @@ void CcdPhysicsEnvironment::CallbackTriggers()
|
|||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,6 +21,8 @@ subject to the following restrictions:
|
|||||||
#include "CollisionDispatch/ConvexConvexAlgorithm.h"
|
#include "CollisionDispatch/ConvexConvexAlgorithm.h"
|
||||||
#include "CollisionDispatch/EmptyCollisionAlgorithm.h"
|
#include "CollisionDispatch/EmptyCollisionAlgorithm.h"
|
||||||
#include "CollisionDispatch/ConvexConcaveCollisionAlgorithm.h"
|
#include "CollisionDispatch/ConvexConcaveCollisionAlgorithm.h"
|
||||||
|
#include "CollisionDispatch/CompoundCollisionAlgorithm.h"
|
||||||
|
|
||||||
#include "CollisionShapes/CollisionShape.h"
|
#include "CollisionShapes/CollisionShape.h"
|
||||||
#include "CollisionDispatch/CollisionObject.h"
|
#include "CollisionDispatch/CollisionObject.h"
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
@ -211,6 +213,18 @@ CollisionAlgorithm* ParallelIslandDispatcher::InternalFindAlgorithm(BroadphasePr
|
|||||||
return new ConvexConcaveCollisionAlgorithm(ci,&proxy1,&proxy0);
|
return new ConvexConcaveCollisionAlgorithm(ci,&proxy1,&proxy0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (body0->m_collisionShape->IsCompound())
|
||||||
|
{
|
||||||
|
return new CompoundCollisionAlgorithm(ci,&proxy0,&proxy1);
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
if (body1->m_collisionShape->IsCompound())
|
||||||
|
{
|
||||||
|
return new CompoundCollisionAlgorithm(ci,&proxy1,&proxy0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//failed to find an algorithm
|
//failed to find an algorithm
|
||||||
return new EmptyAlgorithm(ci);
|
return new EmptyAlgorithm(ci);
|
||||||
|
|
||||||
|
@ -46,6 +46,9 @@ bool SimulationIsland::Simulate(IDebugDraw* debugDrawer,int numSolverIterations,
|
|||||||
CcdPhysicsController* ctrl = m_controllers[k];
|
CcdPhysicsController* ctrl = m_controllers[k];
|
||||||
// SimdTransform predictedTrans;
|
// SimdTransform predictedTrans;
|
||||||
RigidBody* body = ctrl->GetRigidBody();
|
RigidBody* body = ctrl->GetRigidBody();
|
||||||
|
//todo: only do this when necessary, it's used for contact points
|
||||||
|
body->m_cachedInvertedWorldTransform = body->m_worldTransform.inverse();
|
||||||
|
|
||||||
if (body->IsActive())
|
if (body->IsActive())
|
||||||
{
|
{
|
||||||
if (!body->IsStatic())
|
if (!body->IsStatic())
|
||||||
|
Loading…
Reference in New Issue
Block a user