| 
									
										
										
										
											2006-04-28 00:08:18 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  | Bullet Continuous Collision Detection and Physics Library | 
					
						
							|  |  |  | Copyright (c) 2003-2006 Erwin Coumans  http://continuousphysics.com/Bullet/
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | This software is provided 'as-is', without any express or implied warranty. | 
					
						
							|  |  |  | In no event will the authors be held liable for any damages arising from the use of this software. | 
					
						
							|  |  |  | Permission is granted to anyone to use this software for any purpose,  | 
					
						
							|  |  |  | including commercial applications, and to alter it and redistribute it freely,  | 
					
						
							|  |  |  | subject to the following restrictions: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. | 
					
						
							|  |  |  | 2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. | 
					
						
							|  |  |  | 3. This notice may not be removed or altered from any source distribution. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | #include "CcdPhysicsController.h"
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | #include "btBulletDynamicsCommon.h"
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "PHY_IMotionState.h"
 | 
					
						
							| 
									
										
										
										
											2005-12-31 07:20:08 +00:00
										 |  |  | #include "CcdPhysicsEnvironment.h"
 | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | #include "RAS_MeshObject.h"
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-05-22 21:03:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | class BP_Proxy; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | ///todo: fill all the empty CcdPhysicsController methods, hook them up to the btRigidBody class
 | 
					
						
							| 
									
										
										
										
											2005-08-13 08:05:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-03 18:22:30 +00:00
										 |  |  | //'temporarily' global variables
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | //float	gDeactivationTime = 2.f;
 | 
					
						
							|  |  |  | //bool	gDisableDeactivation = false;
 | 
					
						
							|  |  |  | extern float gDeactivationTime; | 
					
						
							|  |  |  | extern bool gDisableDeactivation; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-13 08:05:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-28 06:44:29 +00:00
										 |  |  | float gLinearSleepingTreshold = 0.8f; | 
					
						
							| 
									
										
										
										
											2005-08-03 18:22:30 +00:00
										 |  |  | float gAngularSleepingTreshold = 1.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | btVector3 startVel(0,0,0);//-10000);
 | 
					
						
							| 
									
										
										
										
											2008-03-01 19:17:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | CcdPhysicsController::CcdPhysicsController (const CcdConstructionInfo& ci) | 
					
						
							| 
									
										
										
										
											2005-12-31 07:20:08 +00:00
										 |  |  | :m_cci(ci) | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	m_collisionDelay = 0; | 
					
						
							| 
									
										
										
										
											2005-08-05 17:00:32 +00:00
										 |  |  | 	m_newClientInfo = 0; | 
					
						
							| 
									
										
										
										
											2008-08-05 16:23:33 +00:00
										 |  |  | 	m_registerCount = 0; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 	// copy pointers locally to allow smart release
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 	m_MotionState = ci.m_MotionState; | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 	m_collisionShape = ci.m_collisionShape; | 
					
						
							| 
									
										
										
										
											2008-08-21 21:04:42 +00:00
										 |  |  | 	// apply scaling before creating rigid body
 | 
					
						
							|  |  |  | 	m_collisionShape->setLocalScaling(m_cci.m_scaling); | 
					
						
							|  |  |  | 	if (m_cci.m_mass) | 
					
						
							|  |  |  | 		m_collisionShape->calculateLocalInertia(m_cci.m_mass, m_cci.m_localInertiaTensor); | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 	// shape info is shared, increment ref count
 | 
					
						
							|  |  |  | 	m_shapeInfo = ci.m_shapeInfo; | 
					
						
							|  |  |  | 	if (m_shapeInfo) | 
					
						
							|  |  |  | 		m_shapeInfo->AddRef(); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	m_bulletMotionState = 0; | 
					
						
							| 
									
										
										
										
											2006-02-21 05:36:56 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2005-12-31 07:20:08 +00:00
										 |  |  | 	CreateRigidbody(); | 
					
						
							| 
									
										
										
										
											2006-02-21 05:36:56 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2005-12-31 07:20:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	#ifdef WIN32
 | 
					
						
							|  |  |  | 	if (m_body->getInvMass()) | 
					
						
							|  |  |  | 		m_body->setLinearVelocity(startVel); | 
					
						
							|  |  |  | 	#endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | btTransform	CcdPhysicsController::GetTransformFromMotionState(PHY_IMotionState* motionState) | 
					
						
							| 
									
										
										
										
											2005-12-31 07:20:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	btTransform trans; | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 	float tmp[3]; | 
					
						
							| 
									
										
										
										
											2006-02-21 05:36:56 +00:00
										 |  |  | 	motionState->getWorldPosition(tmp[0],tmp[1],tmp[2]); | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	trans.setOrigin(btVector3(tmp[0],tmp[1],tmp[2])); | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	btQuaternion orn; | 
					
						
							| 
									
										
										
										
											2006-02-21 05:36:56 +00:00
										 |  |  | 	motionState->getWorldOrientation(orn[0],orn[1],orn[2],orn[3]); | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 	trans.setRotation(orn); | 
					
						
							| 
									
										
										
										
											2006-02-21 05:36:56 +00:00
										 |  |  | 	return trans; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | class	BlenderBulletMotionState : public btMotionState | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	PHY_IMotionState*	m_blenderMotionState; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	BlenderBulletMotionState(PHY_IMotionState* bms) | 
					
						
							|  |  |  | 		:m_blenderMotionState(bms) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	virtual void	getWorldTransform(btTransform& worldTrans ) const | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		float pos[3]; | 
					
						
							|  |  |  | 		float quatOrn[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		m_blenderMotionState->getWorldPosition(pos[0],pos[1],pos[2]); | 
					
						
							|  |  |  | 		m_blenderMotionState->getWorldOrientation(quatOrn[0],quatOrn[1],quatOrn[2],quatOrn[3]); | 
					
						
							|  |  |  | 		worldTrans.setOrigin(btVector3(pos[0],pos[1],pos[2])); | 
					
						
							|  |  |  | 		worldTrans.setBasis(btMatrix3x3(btQuaternion(quatOrn[0],quatOrn[1],quatOrn[2],quatOrn[3]))); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	virtual void	setWorldTransform(const btTransform& worldTrans) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		m_blenderMotionState->setWorldPosition(worldTrans.getOrigin().getX(),worldTrans.getOrigin().getY(),worldTrans.getOrigin().getZ()); | 
					
						
							|  |  |  | 		btQuaternion rotQuat = worldTrans.getRotation(); | 
					
						
							|  |  |  | 		m_blenderMotionState->setWorldOrientation(rotQuat[0],rotQuat[1],rotQuat[2],rotQuat[3]); | 
					
						
							| 
									
										
										
										
											2006-12-04 04:13:42 +00:00
										 |  |  | 		m_blenderMotionState->calculateWorldTransformations(); | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-23 04:49:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-21 05:36:56 +00:00
										 |  |  | void CcdPhysicsController::CreateRigidbody() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-23 04:49:17 +00:00
										 |  |  | 	btTransform trans = GetTransformFromMotionState(m_MotionState); | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-23 04:49:17 +00:00
										 |  |  | 	m_bulletMotionState = new BlenderBulletMotionState(m_MotionState); | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-03 11:11:11 +00:00
										 |  |  | 	m_body = new btRigidBody(m_cci.m_mass, | 
					
						
							|  |  |  | 		m_bulletMotionState, | 
					
						
							|  |  |  | 		m_collisionShape, | 
					
						
							|  |  |  | 		m_cci.m_localInertiaTensor * m_cci.m_inertiaFactor, | 
					
						
							|  |  |  | 		m_cci.m_linearDamping,m_cci.m_angularDamping, | 
					
						
							|  |  |  | 		m_cci.m_friction,m_cci.m_restitution); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 	//
 | 
					
						
							|  |  |  | 	// init the rigidbody properly
 | 
					
						
							|  |  |  | 	//
 | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-04-17 01:33:10 +00:00
										 |  |  | 	//setMassProps this also sets collisionFlags
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	//convert collision flags!
 | 
					
						
							| 
									
										
										
										
											2008-03-01 19:17:37 +00:00
										 |  |  | 	//special case: a near/radar sensor controller should not be defined static or it will
 | 
					
						
							|  |  |  | 	//generate loads of static-static collision messages on the console
 | 
					
						
							|  |  |  | 	if ((m_cci.m_collisionFilterGroup & CcdConstructionInfo::SensorFilter) != 0) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		// reset the flags that have been set so far
 | 
					
						
							|  |  |  | 		m_body->setCollisionFlags(0); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2006-12-01 01:04:27 +00:00
										 |  |  | 	m_body->setCollisionFlags(m_body->getCollisionFlags() | m_cci.m_collisionFlags); | 
					
						
							| 
									
										
										
										
											2005-12-31 07:20:08 +00:00
										 |  |  | 	m_body->setGravity( m_cci.m_gravity); | 
					
						
							|  |  |  | 	m_body->setDamping(m_cci.m_linearDamping, m_cci.m_angularDamping); | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-01 16:00:59 +00:00
										 |  |  | 	if (!m_cci.m_bRigid) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		m_body->setAngularFactor(0.f); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | static void DeleteBulletShape(btCollisionShape* shape) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (shape->getShapeType() == TRIANGLE_MESH_SHAPE_PROXYTYPE) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		// shapes based on meshes use an interface that contains the vertices.
 | 
					
						
							|  |  |  | 		btTriangleMeshShape* meshShape = static_cast<btTriangleMeshShape*>(shape); | 
					
						
							|  |  |  | 		btStridingMeshInterface* meshInterface = meshShape->getMeshInterface(); | 
					
						
							|  |  |  | 		if (meshInterface) | 
					
						
							|  |  |  | 			delete meshInterface; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	delete shape; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | CcdPhysicsController::~CcdPhysicsController() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	//will be reference counted, due to sharing
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	if (m_cci.m_physicsEnv) | 
					
						
							|  |  |  | 		m_cci.m_physicsEnv->removeCcdPhysicsController(this); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-01 19:17:37 +00:00
										 |  |  | 	if (m_MotionState) | 
					
						
							|  |  |  | 		delete m_MotionState; | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	if (m_bulletMotionState) | 
					
						
							|  |  |  | 		delete m_bulletMotionState; | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 	delete m_body; | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (m_collisionShape) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		// collision shape is always unique to the controller, can delete it here
 | 
					
						
							|  |  |  | 		if (m_collisionShape->isCompound()) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			// bullet does not delete the child shape, must do it here
 | 
					
						
							|  |  |  | 			btCompoundShape* compoundShape = (btCompoundShape*)m_collisionShape; | 
					
						
							|  |  |  | 			int numChild = compoundShape->getNumChildShapes(); | 
					
						
							|  |  |  | 			for (int i=numChild-1 ; i >= 0; i--) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				btCollisionShape* childShape = compoundShape->getChildShape(i); | 
					
						
							|  |  |  | 				DeleteBulletShape(childShape); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		DeleteBulletShape(m_collisionShape); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (m_shapeInfo) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		m_shapeInfo->Release(); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-01 19:17:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 		/**
 | 
					
						
							|  |  |  | 			SynchronizeMotionStates ynchronizes dynas, kinematic and deformable entities (and do 'late binding') | 
					
						
							|  |  |  | 		*/ | 
					
						
							|  |  |  | bool		CcdPhysicsController::SynchronizeMotionStates(float time) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-04-17 01:33:10 +00:00
										 |  |  | 	//sync non-static to motionstate, and static from motionstate (todo: add kinematic etc.)
 | 
					
						
							| 
									
										
										
										
											2006-04-14 04:03:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	if (!m_body->isStaticObject()) | 
					
						
							| 
									
										
										
										
											2006-04-14 04:03:56 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 		const btVector3& worldPos = m_body->getCenterOfMassPosition(); | 
					
						
							| 
									
										
										
										
											2006-04-14 04:03:56 +00:00
										 |  |  | 		m_MotionState->setWorldPosition(worldPos[0],worldPos[1],worldPos[2]); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 		const btQuaternion& worldquat = m_body->getOrientation(); | 
					
						
							| 
									
										
										
										
											2006-04-14 04:03:56 +00:00
										 |  |  | 		m_MotionState->setWorldOrientation(worldquat[0],worldquat[1],worldquat[2],worldquat[3]); | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-14 04:03:56 +00:00
										 |  |  | 		m_MotionState->calculateWorldTransformations(); | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-14 04:03:56 +00:00
										 |  |  | 		float scale[3]; | 
					
						
							|  |  |  | 		m_MotionState->getWorldScaling(scale[0],scale[1],scale[2]); | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 		btVector3 scaling(scale[0],scale[1],scale[2]); | 
					
						
							| 
									
										
										
										
											2006-04-14 04:03:56 +00:00
										 |  |  | 		GetCollisionShape()->setLocalScaling(scaling); | 
					
						
							|  |  |  | 	} else | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 		btVector3 worldPos; | 
					
						
							|  |  |  | 		btQuaternion worldquat; | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-11-21 12:26:05 +00:00
										 |  |  | /*		m_MotionState->getWorldPosition(worldPos[0],worldPos[1],worldPos[2]);
 | 
					
						
							| 
									
										
										
										
											2006-04-14 04:03:56 +00:00
										 |  |  | 		m_MotionState->getWorldOrientation(worldquat[0],worldquat[1],worldquat[2],worldquat[3]); | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 		btTransform oldTrans = m_body->getCenterOfMassTransform(); | 
					
						
							|  |  |  | 		btTransform newTrans(worldquat,worldPos); | 
					
						
							| 
									
										
										
										
											2006-05-11 00:13:42 +00:00
										 |  |  | 				 | 
					
						
							| 
									
										
										
										
											2006-04-14 04:03:56 +00:00
										 |  |  | 		m_body->setCenterOfMassTransform(newTrans); | 
					
						
							|  |  |  | 		//need to keep track of previous position for friction effects...
 | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		m_MotionState->calculateWorldTransformations(); | 
					
						
							| 
									
										
										
										
											2006-11-21 12:26:05 +00:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2006-04-14 04:03:56 +00:00
										 |  |  | 		float scale[3]; | 
					
						
							|  |  |  | 		m_MotionState->getWorldScaling(scale[0],scale[1],scale[2]); | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 		btVector3 scaling(scale[0],scale[1],scale[2]); | 
					
						
							| 
									
										
										
										
											2006-04-14 04:03:56 +00:00
										 |  |  | 		GetCollisionShape()->setLocalScaling(scaling); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 	return true; | 
					
						
							| 
									
										
										
										
											2006-04-14 04:03:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/**
 | 
					
						
							|  |  |  | 			WriteMotionStateToDynamics synchronizes dynas, kinematic and deformable entities (and do 'late binding') | 
					
						
							|  |  |  | 		*/ | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | void		CcdPhysicsController::WriteMotionStateToDynamics(bool nondynaonly) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | void		CcdPhysicsController::WriteDynamicsToMotionState() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 		// controller replication
 | 
					
						
							|  |  |  | void		CcdPhysicsController::PostProcessReplica(class PHY_IMotionState* motionstate,class PHY_IPhysicsController* parentctrl) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2005-12-31 07:20:08 +00:00
										 |  |  | 	m_MotionState = motionstate; | 
					
						
							| 
									
										
										
										
											2008-08-05 16:23:33 +00:00
										 |  |  | 	m_registerCount = 0; | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 	m_collisionShape = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// always create a new shape to avoid scaling bug
 | 
					
						
							|  |  |  | 	if (m_shapeInfo) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		m_shapeInfo->AddRef(); | 
					
						
							|  |  |  | 		m_collisionShape = m_shapeInfo->CreateBulletShape(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (m_collisionShape) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			// new shape has no scaling, apply initial scaling
 | 
					
						
							|  |  |  | 			m_collisionShape->setLocalScaling(m_cci.m_scaling); | 
					
						
							|  |  |  | 			if (m_cci.m_mass) | 
					
						
							|  |  |  | 				m_collisionShape->calculateLocalInertia(m_cci.m_mass, m_cci.m_localInertiaTensor); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2006-02-21 05:36:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-31 07:20:08 +00:00
										 |  |  | 	m_body = 0; | 
					
						
							|  |  |  | 	CreateRigidbody(); | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (m_body) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (m_cci.m_mass) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			m_body->setMassProps(m_cci.m_mass, m_cci.m_localInertiaTensor * m_cci.m_inertiaFactor); | 
					
						
							|  |  |  | 		}  | 
					
						
							|  |  |  | 	}			 | 
					
						
							| 
									
										
										
										
											2005-12-31 07:20:08 +00:00
										 |  |  | 	m_cci.m_physicsEnv->addCcdPhysicsController(this); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*	SM_Object* dynaparent=0;
 | 
					
						
							|  |  |  | 	SumoPhysicsController* sumoparentctrl = (SumoPhysicsController* )parentctrl; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (sumoparentctrl) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		dynaparent = sumoparentctrl->GetSumoObject(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	SM_Object* orgsumoobject = m_sumoObj; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	m_sumoObj	=	new SM_Object( | 
					
						
							|  |  |  | 		orgsumoobject->getShapeHandle(),  | 
					
						
							|  |  |  | 		orgsumoobject->getMaterialProps(),			 | 
					
						
							|  |  |  | 		orgsumoobject->getShapeProps(), | 
					
						
							|  |  |  | 		dynaparent); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	m_sumoObj->setRigidBody(orgsumoobject->isRigidBody()); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	m_sumoObj->setMargin(orgsumoobject->getMargin()); | 
					
						
							|  |  |  | 	m_sumoObj->setPosition(orgsumoobject->getPosition()); | 
					
						
							|  |  |  | 	m_sumoObj->setOrientation(orgsumoobject->getOrientation()); | 
					
						
							|  |  |  | 	//if it is a dyna, register for a callback
 | 
					
						
							|  |  |  | 	m_sumoObj->registerCallback(*this); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	m_sumoScene->add(* (m_sumoObj)); | 
					
						
							|  |  |  | 	*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// kinematic methods
 | 
					
						
							|  |  |  | void		CcdPhysicsController::RelativeTranslate(float dlocX,float dlocY,float dlocZ,bool local) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-04-17 06:27:57 +00:00
										 |  |  | 	if (m_body) | 
					
						
							| 
									
										
										
										
											2005-11-11 05:02:14 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2006-11-21 12:26:05 +00:00
										 |  |  | 		m_body->activate(true); | 
					
						
							|  |  |  | 		if (m_body->isStaticObject()) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			m_body->setCollisionFlags(m_body->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-17 06:27:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 		btVector3 dloc(dlocX,dlocY,dlocZ); | 
					
						
							|  |  |  | 		btTransform xform = m_body->getCenterOfMassTransform(); | 
					
						
							| 
									
										
										
										
											2006-04-17 06:27:57 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if (local) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			dloc = xform.getBasis()*dloc; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2005-11-11 05:02:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-17 06:27:57 +00:00
										 |  |  | 		xform.setOrigin(xform.getOrigin() + dloc); | 
					
						
							|  |  |  | 		m_body->setCenterOfMassTransform(xform); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-17 19:52:56 +00:00
										 |  |  | void		CcdPhysicsController::RelativeRotate(const float rotval[9],bool local) | 
					
						
							| 
									
										
										
										
											2005-08-08 17:08:42 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 	if (m_body) | 
					
						
							| 
									
										
										
										
											2005-08-17 19:52:56 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2006-11-21 12:26:05 +00:00
										 |  |  | 		m_body->activate(true); | 
					
						
							|  |  |  | 		if (m_body->isStaticObject()) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			m_body->setCollisionFlags(m_body->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2006-04-17 06:27:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-23 21:48:17 +00:00
										 |  |  | 		btMatrix3x3 drotmat(	rotval[0],rotval[4],rotval[8], | 
					
						
							|  |  |  | 								rotval[1],rotval[5],rotval[9], | 
					
						
							|  |  |  | 								rotval[2],rotval[6],rotval[10]); | 
					
						
							| 
									
										
										
										
											2005-08-17 19:52:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 		btMatrix3x3 currentOrn; | 
					
						
							| 
									
										
										
										
											2005-08-17 19:52:56 +00:00
										 |  |  | 		GetWorldOrientation(currentOrn); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 		btTransform xform = m_body->getCenterOfMassTransform(); | 
					
						
							| 
									
										
										
										
											2005-08-17 19:52:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		xform.setBasis(xform.getBasis()*(local ?  | 
					
						
							|  |  |  | 		drotmat : (currentOrn.inverse() * drotmat * currentOrn))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		m_body->setCenterOfMassTransform(xform); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-08 17:08:42 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2005-08-17 19:52:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | void CcdPhysicsController::GetWorldOrientation(btMatrix3x3& mat) | 
					
						
							| 
									
										
										
										
											2005-08-17 19:52:56 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float orn[4]; | 
					
						
							|  |  |  | 	m_MotionState->getWorldOrientation(orn[0],orn[1],orn[2],orn[3]); | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	btQuaternion quat(orn[0],orn[1],orn[2],orn[3]); | 
					
						
							| 
									
										
										
										
											2005-08-17 19:52:56 +00:00
										 |  |  | 	mat.setRotation(quat); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | void		CcdPhysicsController::getOrientation(float &quatImag0,float &quatImag1,float &quatImag2,float &quatReal) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	btQuaternion q = m_body->getCenterOfMassTransform().getRotation(); | 
					
						
							| 
									
										
										
										
											2005-11-11 05:02:14 +00:00
										 |  |  | 	quatImag0 = q[0]; | 
					
						
							|  |  |  | 	quatImag1 = q[1]; | 
					
						
							|  |  |  | 	quatImag2 = q[2]; | 
					
						
							|  |  |  | 	quatReal = q[3]; | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | void		CcdPhysicsController::setOrientation(float quatImag0,float quatImag1,float quatImag2,float quatReal) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 	if (m_body) | 
					
						
							| 
									
										
										
										
											2006-11-21 12:26:05 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 		m_body->activate(true); | 
					
						
							|  |  |  | 		if (m_body->isStaticObject()) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			m_body->setCollisionFlags(m_body->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-07-21 12:37:27 +00:00
										 |  |  | 		// not required
 | 
					
						
							|  |  |  | 		//m_MotionState->setWorldOrientation(quatImag0,quatImag1,quatImag2,quatReal);
 | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 		btTransform xform  = m_body->getCenterOfMassTransform(); | 
					
						
							|  |  |  | 		xform.setRotation(btQuaternion(quatImag0,quatImag1,quatImag2,quatReal)); | 
					
						
							|  |  |  | 		m_body->setCenterOfMassTransform(xform); | 
					
						
							| 
									
										
										
										
											2008-07-21 12:37:27 +00:00
										 |  |  | 		// not required
 | 
					
						
							|  |  |  | 		//m_bulletMotionState->setWorldTransform(xform);
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void CcdPhysicsController::setWorldOrientation(const btMatrix3x3& orn) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (m_body) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		m_body->activate(true); | 
					
						
							|  |  |  | 		if (m_body->isStaticObject()) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			m_body->setCollisionFlags(m_body->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		// not required
 | 
					
						
							|  |  |  | 		//m_MotionState->setWorldOrientation(quatImag0,quatImag1,quatImag2,quatReal);
 | 
					
						
							|  |  |  | 		btTransform xform  = m_body->getCenterOfMassTransform(); | 
					
						
							|  |  |  | 		xform.setBasis(orn); | 
					
						
							|  |  |  | 		m_body->setCenterOfMassTransform(xform); | 
					
						
							|  |  |  | 		// not required
 | 
					
						
							|  |  |  | 		//m_bulletMotionState->setWorldTransform(xform);
 | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-08-13 08:05:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2005-08-13 08:05:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | void		CcdPhysicsController::setPosition(float posX,float posY,float posZ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 	if (m_body) | 
					
						
							| 
									
										
										
										
											2006-11-21 12:26:05 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 		m_body->activate(true); | 
					
						
							|  |  |  | 		if (m_body->isStaticObject()) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			m_body->setCollisionFlags(m_body->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-07-21 12:37:27 +00:00
										 |  |  | 		// not required, this function is only used to update the physic controller
 | 
					
						
							|  |  |  | 		//m_MotionState->setWorldPosition(posX,posY,posZ);
 | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 		btTransform xform  = m_body->getCenterOfMassTransform(); | 
					
						
							|  |  |  | 		xform.setOrigin(btVector3(posX,posY,posZ)); | 
					
						
							|  |  |  | 		m_body->setCenterOfMassTransform(xform); | 
					
						
							| 
									
										
										
										
											2008-07-21 12:37:27 +00:00
										 |  |  | 		// not required
 | 
					
						
							|  |  |  | 		//m_bulletMotionState->setWorldTransform(xform);
 | 
					
						
							| 
									
										
										
										
											2006-11-21 12:26:05 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2007-01-05 02:31:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-13 08:05:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | void		CcdPhysicsController::resolveCombinedVelocities(float linvelX,float linvelY,float linvelZ,float angVelX,float angVelY,float angVelZ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void 		CcdPhysicsController::getPosition(PHY__Vector3&	pos) const | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	const btTransform& xform = m_body->getCenterOfMassTransform(); | 
					
						
							| 
									
										
										
										
											2005-12-31 21:59:56 +00:00
										 |  |  | 	pos[0] = xform.getOrigin().x(); | 
					
						
							|  |  |  | 	pos[1] = xform.getOrigin().y(); | 
					
						
							|  |  |  | 	pos[2] = xform.getOrigin().z(); | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void		CcdPhysicsController::setScaling(float scaleX,float scaleY,float scaleZ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	if (!btFuzzyZero(m_cci.m_scaling.x()-scaleX) || | 
					
						
							|  |  |  | 		!btFuzzyZero(m_cci.m_scaling.y()-scaleY) || | 
					
						
							|  |  |  | 		!btFuzzyZero(m_cci.m_scaling.z()-scaleZ)) | 
					
						
							| 
									
										
										
										
											2005-11-11 05:02:14 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 		m_cci.m_scaling = btVector3(scaleX,scaleY,scaleZ); | 
					
						
							| 
									
										
										
										
											2005-12-31 21:59:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 		if (m_body && m_body->getCollisionShape()) | 
					
						
							| 
									
										
										
										
											2005-12-31 21:59:56 +00:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 			m_body->getCollisionShape()->setLocalScaling(m_cci.m_scaling); | 
					
						
							| 
									
										
										
										
											2006-12-26 22:02:31 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			//printf("no inertia recalc for fixed objects with mass=0\n");
 | 
					
						
							|  |  |  | 			if (m_cci.m_mass) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				m_body->getCollisionShape()->calculateLocalInertia(m_cci.m_mass, m_cci.m_localInertiaTensor); | 
					
						
							|  |  |  | 				m_body->setMassProps(m_cci.m_mass, m_cci.m_localInertiaTensor * m_cci.m_inertiaFactor); | 
					
						
							|  |  |  | 			}  | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2005-12-31 21:59:56 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2005-11-11 05:02:14 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		// physics methods
 | 
					
						
							|  |  |  | void		CcdPhysicsController::ApplyTorque(float torqueX,float torqueY,float torqueZ,bool local) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	btVector3 torque(torqueX,torqueY,torqueZ); | 
					
						
							|  |  |  | 	btTransform xform = m_body->getCenterOfMassTransform(); | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 	if (m_body && torque.length2() > (SIMD_EPSILON*SIMD_EPSILON)) | 
					
						
							| 
									
										
										
										
											2006-12-25 02:02:13 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		m_body->activate(); | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 		if (m_body->isStaticObject()) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			m_body->setCollisionFlags(m_body->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		if (local) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			torque	= xform.getBasis()*torque; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		m_body->applyTorque(torque); | 
					
						
							| 
									
										
										
										
											2006-12-25 02:02:13 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2005-11-11 05:02:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | void		CcdPhysicsController::ApplyForce(float forceX,float forceY,float forceZ,bool local) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	btVector3 force(forceX,forceY,forceZ); | 
					
						
							| 
									
										
										
										
											2006-12-25 02:02:13 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 	if (m_body && force.length2() > (SIMD_EPSILON*SIMD_EPSILON)) | 
					
						
							| 
									
										
										
										
											2006-12-25 02:02:13 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		m_body->activate(); | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 		if (m_body->isStaticObject()) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			m_body->setCollisionFlags(m_body->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			btTransform xform = m_body->getCenterOfMassTransform(); | 
					
						
							|  |  |  | 			if (local) | 
					
						
							|  |  |  | 			{	 | 
					
						
							|  |  |  | 				force	= xform.getBasis()*force; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		m_body->applyCentralForce(force); | 
					
						
							| 
									
										
										
										
											2006-12-25 02:02:13 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | void		CcdPhysicsController::SetAngularVelocity(float ang_velX,float ang_velY,float ang_velZ,bool local) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	btVector3 angvel(ang_velX,ang_velY,ang_velZ); | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 	if (m_body && angvel.length2() > (SIMD_EPSILON*SIMD_EPSILON)) | 
					
						
							| 
									
										
										
										
											2006-04-26 03:20:28 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2006-11-21 12:26:05 +00:00
										 |  |  | 		m_body->activate(true); | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 		if (m_body->isStaticObject()) | 
					
						
							| 
									
										
										
										
											2006-04-17 06:27:57 +00:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 			m_body->setCollisionFlags(m_body->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			btTransform xform = m_body->getCenterOfMassTransform(); | 
					
						
							|  |  |  | 			if (local) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				angvel	= xform.getBasis()*angvel; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2006-04-17 06:27:57 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		m_body->setAngularVelocity(angvel); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | void		CcdPhysicsController::SetLinearVelocity(float lin_velX,float lin_velY,float lin_velZ,bool local) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-04-17 06:27:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	btVector3 linVel(lin_velX,lin_velY,lin_velZ); | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 	if (m_body && linVel.length2() > (SIMD_EPSILON*SIMD_EPSILON)) | 
					
						
							| 
									
										
										
										
											2005-11-11 05:02:14 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2006-11-21 12:26:05 +00:00
										 |  |  | 		m_body->activate(true); | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 		if (m_body->isStaticObject()) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			m_body->setCollisionFlags(m_body->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-17 06:27:57 +00:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 			btTransform xform = m_body->getCenterOfMassTransform(); | 
					
						
							|  |  |  | 			if (local) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				linVel	= xform.getBasis()*linVel; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2006-04-17 06:27:57 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		m_body->setLinearVelocity(linVel); | 
					
						
							| 
									
										
										
										
											2005-11-11 05:02:14 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | void		CcdPhysicsController::applyImpulse(float attachX,float attachY,float attachZ, float impulseX,float impulseY,float impulseZ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	btVector3 impulse(impulseX,impulseY,impulseZ); | 
					
						
							| 
									
										
										
										
											2005-08-05 17:00:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 	if (m_body && impulse.length2() > (SIMD_EPSILON*SIMD_EPSILON)) | 
					
						
							| 
									
										
										
										
											2006-04-17 06:27:57 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		m_body->activate(); | 
					
						
							| 
									
										
										
										
											2008-03-10 21:30:35 +00:00
										 |  |  | 		if (m_body->isStaticObject()) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			m_body->setCollisionFlags(m_body->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2006-04-17 06:27:57 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 		btVector3 pos(attachX,attachY,attachZ); | 
					
						
							| 
									
										
										
										
											2006-04-17 06:27:57 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		m_body->applyImpulse(impulse,pos); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-08-05 17:00:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | void		CcdPhysicsController::SetActive(bool active) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 		// reading out information from physics
 | 
					
						
							|  |  |  | void		CcdPhysicsController::GetLinearVelocity(float& linvX,float& linvY,float& linvZ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	const btVector3& linvel = this->m_body->getLinearVelocity(); | 
					
						
							| 
									
										
										
										
											2005-11-11 05:02:14 +00:00
										 |  |  | 	linvX = linvel.x(); | 
					
						
							|  |  |  | 	linvY = linvel.y(); | 
					
						
							|  |  |  | 	linvZ = linvel.z(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2005-12-31 07:20:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | void		CcdPhysicsController::GetAngularVelocity(float& angVelX,float& angVelY,float& angVelZ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	const btVector3& angvel= m_body->getAngularVelocity(); | 
					
						
							| 
									
										
										
										
											2005-12-31 07:20:08 +00:00
										 |  |  | 	angVelX = angvel.x(); | 
					
						
							|  |  |  | 	angVelY = angvel.y(); | 
					
						
							|  |  |  | 	angVelZ = angvel.z(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | void		CcdPhysicsController::GetVelocity(const float posX,const float posY,const float posZ,float& linvX,float& linvY,float& linvZ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	btVector3 pos(posX,posY,posZ); | 
					
						
							|  |  |  | 	btVector3 rel_pos = pos-m_body->getCenterOfMassPosition(); | 
					
						
							|  |  |  | 	btVector3 linvel = m_body->getVelocityInLocalPoint(rel_pos); | 
					
						
							| 
									
										
										
										
											2005-11-11 05:02:14 +00:00
										 |  |  | 	linvX = linvel.x(); | 
					
						
							|  |  |  | 	linvY = linvel.y(); | 
					
						
							|  |  |  | 	linvZ = linvel.z(); | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | void		CcdPhysicsController::getReactionForce(float& forceX,float& forceY,float& forceZ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// dyna's that are rigidbody are free in orientation, dyna's with non-rigidbody are restricted 
 | 
					
						
							|  |  |  | void		CcdPhysicsController::setRigidBody(bool rigid) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-04-17 01:33:10 +00:00
										 |  |  | 	if (!rigid) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		//fake it for now
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 		btVector3 inertia = m_body->getInvInertiaDiagLocal(); | 
					
						
							| 
									
										
										
										
											2006-04-17 01:33:10 +00:00
										 |  |  | 		inertia[1] = 0.f; | 
					
						
							|  |  |  | 		m_body->setInvInertiaDiagLocal(inertia); | 
					
						
							|  |  |  | 		m_body->updateInertiaTensor(); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// clientinfo for raycasts for example
 | 
					
						
							|  |  |  | void*		CcdPhysicsController::getNewClientInfo() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2005-08-05 17:00:32 +00:00
										 |  |  | 	return m_newClientInfo; | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | void		CcdPhysicsController::setNewClientInfo(void* clientinfo) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2005-08-05 17:00:32 +00:00
										 |  |  | 	m_newClientInfo = clientinfo; | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-04 19:07:39 +00:00
										 |  |  | void	CcdPhysicsController::UpdateDeactivation(float timeStep) | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	m_body->updateDeactivation( timeStep); | 
					
						
							| 
									
										
										
										
											2005-08-04 19:07:39 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool CcdPhysicsController::wantsSleeping() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	return m_body->wantsSleeping(); | 
					
						
							| 
									
										
										
										
											2005-07-16 10:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-05-22 21:03:43 +00:00
										 |  |  | PHY_IPhysicsController*	CcdPhysicsController::GetReplica() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 	// This is used only to replicate Near and Radar sensor controllers
 | 
					
						
							|  |  |  | 	// The replication of object physics controller is done in KX_BulletPhysicsController::GetReplica()
 | 
					
						
							| 
									
										
										
										
											2006-05-22 21:03:43 +00:00
										 |  |  | 	CcdConstructionInfo cinfo = m_cci; | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 	if (m_shapeInfo) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		// This situation does not normally happen
 | 
					
						
							|  |  |  | 		cinfo.m_collisionShape = m_shapeInfo->CreateBulletShape(); | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 	else if (m_collisionShape) | 
					
						
							| 
									
										
										
										
											2006-05-22 21:03:43 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 		switch (m_collisionShape->getShapeType()) | 
					
						
							| 
									
										
										
										
											2006-05-22 21:03:43 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 		case SPHERE_SHAPE_PROXYTYPE: | 
					
						
							|  |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 				btSphereShape* orgShape = (btSphereShape*)m_collisionShape; | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 				cinfo.m_collisionShape = new btSphereShape(*orgShape); | 
					
						
							| 
									
										
										
										
											2006-05-22 21:03:43 +00:00
										 |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 		case CONE_SHAPE_PROXYTYPE: | 
					
						
							| 
									
										
										
										
											2006-05-22 21:03:43 +00:00
										 |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 				btConeShape* orgShape = (btConeShape*)m_collisionShape; | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 				cinfo.m_collisionShape = new btConeShape(*orgShape); | 
					
						
							| 
									
										
										
										
											2006-05-22 21:03:43 +00:00
										 |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		default: | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				return 0; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	cinfo.m_MotionState = new DefaultMotionState(); | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 	cinfo.m_shapeInfo = m_shapeInfo; | 
					
						
							| 
									
										
										
										
											2006-05-22 21:03:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	CcdPhysicsController* replica = new CcdPhysicsController(cinfo); | 
					
						
							|  |  |  | 	return replica; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ///////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | ///A small utility class, DefaultMotionState
 | 
					
						
							|  |  |  | ///
 | 
					
						
							|  |  |  | ///////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | DefaultMotionState::DefaultMotionState() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	m_worldTransform.setIdentity(); | 
					
						
							| 
									
										
										
										
											2006-08-28 06:44:29 +00:00
										 |  |  | 	m_localScaling.setValue(1.f,1.f,1.f); | 
					
						
							| 
									
										
										
										
											2006-05-22 21:03:43 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | DefaultMotionState::~DefaultMotionState() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void	DefaultMotionState::getWorldPosition(float& posX,float& posY,float& posZ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	posX = m_worldTransform.getOrigin().x(); | 
					
						
							|  |  |  | 	posY = m_worldTransform.getOrigin().y(); | 
					
						
							|  |  |  | 	posZ = m_worldTransform.getOrigin().z(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void	DefaultMotionState::getWorldScaling(float& scaleX,float& scaleY,float& scaleZ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-08-28 06:44:29 +00:00
										 |  |  | 	scaleX = m_localScaling.getX(); | 
					
						
							|  |  |  | 	scaleY = m_localScaling.getY(); | 
					
						
							|  |  |  | 	scaleZ = m_localScaling.getZ(); | 
					
						
							| 
									
										
										
										
											2006-05-22 21:03:43 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void	DefaultMotionState::getWorldOrientation(float& quatIma0,float& quatIma1,float& quatIma2,float& quatReal) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	quatIma0 = m_worldTransform.getRotation().x(); | 
					
						
							|  |  |  | 	quatIma1 = m_worldTransform.getRotation().y(); | 
					
						
							|  |  |  | 	quatIma2 = m_worldTransform.getRotation().z(); | 
					
						
							|  |  |  | 	quatReal = m_worldTransform.getRotation()[3]; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | void	DefaultMotionState::setWorldPosition(float posX,float posY,float posZ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	btPoint3 pos(posX,posY,posZ); | 
					
						
							| 
									
										
										
										
											2006-05-22 21:03:43 +00:00
										 |  |  | 	m_worldTransform.setOrigin( pos ); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void	DefaultMotionState::setWorldOrientation(float quatIma0,float quatIma1,float quatIma2,float quatReal) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-11-21 00:53:40 +00:00
										 |  |  | 	btQuaternion orn(quatIma0,quatIma1,quatIma2,quatReal); | 
					
						
							| 
									
										
										
										
											2006-05-22 21:03:43 +00:00
										 |  |  | 	m_worldTransform.setRotation( orn ); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | void	DefaultMotionState::calculateWorldTransformations() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | // Shape constructor
 | 
					
						
							|  |  |  | bool CcdShapeConstructionInfo::SetMesh(RAS_MeshObject* meshobj, bool polytope) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	// assume no shape information
 | 
					
						
							|  |  |  | 	m_shapeType = PHY_SHAPE_NONE; | 
					
						
							|  |  |  | 	m_vertexArray.clear(); | 
					
						
							| 
									
										
											  
											
												BGE patch: KX_GameObject::rayCast() improvements to have X-Ray option, return true face normal and hit polygon information.
rayCast(to,from,dist,prop,face,xray,poly):
The face paremeter determines the orientation of the normal: 
  0 or omitted => hit normal is always oriented towards the ray origin (as if you casted the ray from outside)
  1 => hit normal is the real face normal (only for mesh object, otherwise face has no effect)
The ray has X-Ray capability if xray parameter is 1, otherwise the first object hit (other than self object) stops the ray.
The prop and xray parameters interact as follow:
    prop off, xray off: return closest hit or no hit if there is no object on the full extend of the ray.
    prop off, xray on : idem.
    prop on,  xray off: return closest hit if it matches prop, no hit otherwise.
    prop on,  xray on : return closest hit matching prop or no hit if there is no object matching prop on the full extend of the ray.
if poly is 0 or omitted, returns a 3-tuple with object reference, hit point and hit normal or (None,None,None) if no hit.
if poly is 1, returns a 4-tuple with in addition a KX_PolyProxy as 4th element.
The KX_PolyProxy object holds information on the polygon hit by the ray: the index of the vertex forming the poylgon, material, etc.
Attributes (read-only):
 matname: The name of polygon material, empty if no material.
 material: The material of the polygon
 texture: The texture name of the polygon.
 matid: The material index of the polygon, use this to retrieve vertex proxy from mesh proxy
 v1: vertex index of the first vertex of the polygon, use this to retrieve vertex proxy from mesh proxy
 v2: vertex index of the second vertex of the polygon, use this to retrieve vertex proxy from mesh proxy
 v3: vertex index of the third vertex of the polygon, use this to retrieve vertex proxy from mesh proxy
 v4: vertex index of the fourth vertex of the polygon, 0 if polygon has only 3 vertex
     use this to retrieve vertex proxy from mesh proxy
 visible: visible state of the polygon: 1=visible, 0=invisible
 collide: collide state of the polygon: 1=receives collision, 0=collision free.
Methods:
 getMaterialName(): Returns the polygon material name with MA prefix
 getMaterial(): Returns the polygon material
 getTextureName(): Returns the polygon texture name
 getMaterialIndex(): Returns the material bucket index of the polygon. 
 getNumVertex(): Returns the number of vertex of the polygon.
 isVisible(): Returns whether the polygon is visible or not
 isCollider(): Returns whether the polygon is receives collision or not
 getVertexIndex(vertex): Returns the mesh vertex index of a polygon vertex
 getMesh(): Returns a mesh proxy
New methods of KX_MeshProxy have been implemented to retrieve KX_PolyProxy objects:
 getNumPolygons(): Returns the number of polygon in the mesh.
 getPolygon(index): Gets the specified polygon from the mesh.
More details in PyDoc.
											
										 
											2008-08-27 19:34:19 +00:00
										 |  |  | 	m_polygonIndexArray.clear(); | 
					
						
							|  |  |  | 	m_meshObject = NULL; | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (!meshobj) | 
					
						
							|  |  |  | 		return false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Mesh has no polygons!
 | 
					
						
							|  |  |  | 	int numpolys = meshobj->NumPolygons(); | 
					
						
							|  |  |  | 	if (!numpolys) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return false; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// check that we have at least one colliding polygon
 | 
					
						
							|  |  |  | 	int numvalidpolys = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (int p=0; p<numpolys; p++) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		RAS_Polygon* poly = meshobj->GetPolygon(p); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// only add polygons that have the collisionflag set
 | 
					
						
							|  |  |  | 		if (poly->IsCollider()) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			numvalidpolys++; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// No collision polygons
 | 
					
						
							|  |  |  | 	if (numvalidpolys < 1) | 
					
						
							|  |  |  | 		return false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	m_shapeType = (polytope) ? PHY_SHAPE_POLYTOPE : PHY_SHAPE_MESH; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	numvalidpolys = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (int p2=0; p2<numpolys; p2++) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		RAS_Polygon* poly = meshobj->GetPolygon(p2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// only add polygons that have the collisionflag set
 | 
					
						
							|  |  |  | 		if (poly->IsCollider()) | 
					
						
							|  |  |  | 		{    | 
					
						
							|  |  |  | 			//Bullet can raycast any shape, so
 | 
					
						
							|  |  |  | 			if (polytope) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				for (int i=0;i<poly->VertexCount();i++) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					const float* vtx = meshobj->GetVertex(poly->GetVertexIndexBase().m_vtxarray,  | 
					
						
							|  |  |  | 						poly->GetVertexIndexBase().m_indexarray[i], | 
					
						
							|  |  |  | 						poly->GetMaterial()->GetPolyMaterial())->getLocalXYZ(); | 
					
						
							|  |  |  | 					btPoint3 point(vtx[0],vtx[1],vtx[2]); | 
					
						
							|  |  |  | 					m_vertexArray.push_back(point); | 
					
						
							|  |  |  | 					numvalidpolys++; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} else | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					const float* vtx = meshobj->GetVertex(poly->GetVertexIndexBase().m_vtxarray,  | 
					
						
							|  |  |  | 						poly->GetVertexIndexBase().m_indexarray[2], | 
					
						
							|  |  |  | 						poly->GetMaterial()->GetPolyMaterial())->getLocalXYZ(); | 
					
						
							|  |  |  | 					btPoint3 vertex0(vtx[0],vtx[1],vtx[2]); | 
					
						
							|  |  |  | 					vtx = meshobj->GetVertex(poly->GetVertexIndexBase().m_vtxarray,  | 
					
						
							|  |  |  | 						poly->GetVertexIndexBase().m_indexarray[1], | 
					
						
							|  |  |  | 						poly->GetMaterial()->GetPolyMaterial())->getLocalXYZ(); | 
					
						
							|  |  |  | 					btPoint3 vertex1(vtx[0],vtx[1],vtx[2]); | 
					
						
							|  |  |  | 					vtx = meshobj->GetVertex(poly->GetVertexIndexBase().m_vtxarray,  | 
					
						
							|  |  |  | 						poly->GetVertexIndexBase().m_indexarray[0], | 
					
						
							|  |  |  | 						poly->GetMaterial()->GetPolyMaterial())->getLocalXYZ(); | 
					
						
							|  |  |  | 					btPoint3 vertex2(vtx[0],vtx[1],vtx[2]); | 
					
						
							|  |  |  | 					m_vertexArray.push_back(vertex0); | 
					
						
							|  |  |  | 					m_vertexArray.push_back(vertex1); | 
					
						
							|  |  |  | 					m_vertexArray.push_back(vertex2); | 
					
						
							| 
									
										
											  
											
												BGE patch: KX_GameObject::rayCast() improvements to have X-Ray option, return true face normal and hit polygon information.
rayCast(to,from,dist,prop,face,xray,poly):
The face paremeter determines the orientation of the normal: 
  0 or omitted => hit normal is always oriented towards the ray origin (as if you casted the ray from outside)
  1 => hit normal is the real face normal (only for mesh object, otherwise face has no effect)
The ray has X-Ray capability if xray parameter is 1, otherwise the first object hit (other than self object) stops the ray.
The prop and xray parameters interact as follow:
    prop off, xray off: return closest hit or no hit if there is no object on the full extend of the ray.
    prop off, xray on : idem.
    prop on,  xray off: return closest hit if it matches prop, no hit otherwise.
    prop on,  xray on : return closest hit matching prop or no hit if there is no object matching prop on the full extend of the ray.
if poly is 0 or omitted, returns a 3-tuple with object reference, hit point and hit normal or (None,None,None) if no hit.
if poly is 1, returns a 4-tuple with in addition a KX_PolyProxy as 4th element.
The KX_PolyProxy object holds information on the polygon hit by the ray: the index of the vertex forming the poylgon, material, etc.
Attributes (read-only):
 matname: The name of polygon material, empty if no material.
 material: The material of the polygon
 texture: The texture name of the polygon.
 matid: The material index of the polygon, use this to retrieve vertex proxy from mesh proxy
 v1: vertex index of the first vertex of the polygon, use this to retrieve vertex proxy from mesh proxy
 v2: vertex index of the second vertex of the polygon, use this to retrieve vertex proxy from mesh proxy
 v3: vertex index of the third vertex of the polygon, use this to retrieve vertex proxy from mesh proxy
 v4: vertex index of the fourth vertex of the polygon, 0 if polygon has only 3 vertex
     use this to retrieve vertex proxy from mesh proxy
 visible: visible state of the polygon: 1=visible, 0=invisible
 collide: collide state of the polygon: 1=receives collision, 0=collision free.
Methods:
 getMaterialName(): Returns the polygon material name with MA prefix
 getMaterial(): Returns the polygon material
 getTextureName(): Returns the polygon texture name
 getMaterialIndex(): Returns the material bucket index of the polygon. 
 getNumVertex(): Returns the number of vertex of the polygon.
 isVisible(): Returns whether the polygon is visible or not
 isCollider(): Returns whether the polygon is receives collision or not
 getVertexIndex(vertex): Returns the mesh vertex index of a polygon vertex
 getMesh(): Returns a mesh proxy
New methods of KX_MeshProxy have been implemented to retrieve KX_PolyProxy objects:
 getNumPolygons(): Returns the number of polygon in the mesh.
 getPolygon(index): Gets the specified polygon from the mesh.
More details in PyDoc.
											
										 
											2008-08-27 19:34:19 +00:00
										 |  |  | 					m_polygonIndexArray.push_back(p2); | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 					numvalidpolys++; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				if (poly->VertexCount() == 4) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					const float* vtx = meshobj->GetVertex(poly->GetVertexIndexBase().m_vtxarray,  | 
					
						
							|  |  |  | 						poly->GetVertexIndexBase().m_indexarray[3], | 
					
						
							|  |  |  | 						poly->GetMaterial()->GetPolyMaterial())->getLocalXYZ(); | 
					
						
							|  |  |  | 					btPoint3 vertex0(vtx[0],vtx[1],vtx[2]); | 
					
						
							|  |  |  | 					vtx = meshobj->GetVertex(poly->GetVertexIndexBase().m_vtxarray,  | 
					
						
							|  |  |  | 						poly->GetVertexIndexBase().m_indexarray[2], | 
					
						
							|  |  |  | 						poly->GetMaterial()->GetPolyMaterial())->getLocalXYZ(); | 
					
						
							|  |  |  | 					btPoint3 vertex1(vtx[0],vtx[1],vtx[2]); | 
					
						
							|  |  |  | 					vtx = meshobj->GetVertex(poly->GetVertexIndexBase().m_vtxarray,  | 
					
						
							|  |  |  | 						poly->GetVertexIndexBase().m_indexarray[0], | 
					
						
							|  |  |  | 						poly->GetMaterial()->GetPolyMaterial())->getLocalXYZ(); | 
					
						
							|  |  |  | 					btPoint3 vertex2(vtx[0],vtx[1],vtx[2]); | 
					
						
							|  |  |  | 					m_vertexArray.push_back(vertex0); | 
					
						
							|  |  |  | 					m_vertexArray.push_back(vertex1); | 
					
						
							|  |  |  | 					m_vertexArray.push_back(vertex2); | 
					
						
							| 
									
										
											  
											
												BGE patch: KX_GameObject::rayCast() improvements to have X-Ray option, return true face normal and hit polygon information.
rayCast(to,from,dist,prop,face,xray,poly):
The face paremeter determines the orientation of the normal: 
  0 or omitted => hit normal is always oriented towards the ray origin (as if you casted the ray from outside)
  1 => hit normal is the real face normal (only for mesh object, otherwise face has no effect)
The ray has X-Ray capability if xray parameter is 1, otherwise the first object hit (other than self object) stops the ray.
The prop and xray parameters interact as follow:
    prop off, xray off: return closest hit or no hit if there is no object on the full extend of the ray.
    prop off, xray on : idem.
    prop on,  xray off: return closest hit if it matches prop, no hit otherwise.
    prop on,  xray on : return closest hit matching prop or no hit if there is no object matching prop on the full extend of the ray.
if poly is 0 or omitted, returns a 3-tuple with object reference, hit point and hit normal or (None,None,None) if no hit.
if poly is 1, returns a 4-tuple with in addition a KX_PolyProxy as 4th element.
The KX_PolyProxy object holds information on the polygon hit by the ray: the index of the vertex forming the poylgon, material, etc.
Attributes (read-only):
 matname: The name of polygon material, empty if no material.
 material: The material of the polygon
 texture: The texture name of the polygon.
 matid: The material index of the polygon, use this to retrieve vertex proxy from mesh proxy
 v1: vertex index of the first vertex of the polygon, use this to retrieve vertex proxy from mesh proxy
 v2: vertex index of the second vertex of the polygon, use this to retrieve vertex proxy from mesh proxy
 v3: vertex index of the third vertex of the polygon, use this to retrieve vertex proxy from mesh proxy
 v4: vertex index of the fourth vertex of the polygon, 0 if polygon has only 3 vertex
     use this to retrieve vertex proxy from mesh proxy
 visible: visible state of the polygon: 1=visible, 0=invisible
 collide: collide state of the polygon: 1=receives collision, 0=collision free.
Methods:
 getMaterialName(): Returns the polygon material name with MA prefix
 getMaterial(): Returns the polygon material
 getTextureName(): Returns the polygon texture name
 getMaterialIndex(): Returns the material bucket index of the polygon. 
 getNumVertex(): Returns the number of vertex of the polygon.
 isVisible(): Returns whether the polygon is visible or not
 isCollider(): Returns whether the polygon is receives collision or not
 getVertexIndex(vertex): Returns the mesh vertex index of a polygon vertex
 getMesh(): Returns a mesh proxy
New methods of KX_MeshProxy have been implemented to retrieve KX_PolyProxy objects:
 getNumPolygons(): Returns the number of polygon in the mesh.
 getPolygon(index): Gets the specified polygon from the mesh.
More details in PyDoc.
											
										 
											2008-08-27 19:34:19 +00:00
										 |  |  | 					m_polygonIndexArray.push_back(p2); | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 					numvalidpolys++; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			}		 | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!numvalidpolys) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		// should not happen
 | 
					
						
							|  |  |  | 		m_shapeType = PHY_SHAPE_NONE; | 
					
						
							|  |  |  | 		return false; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
											  
											
												BGE patch: KX_GameObject::rayCast() improvements to have X-Ray option, return true face normal and hit polygon information.
rayCast(to,from,dist,prop,face,xray,poly):
The face paremeter determines the orientation of the normal: 
  0 or omitted => hit normal is always oriented towards the ray origin (as if you casted the ray from outside)
  1 => hit normal is the real face normal (only for mesh object, otherwise face has no effect)
The ray has X-Ray capability if xray parameter is 1, otherwise the first object hit (other than self object) stops the ray.
The prop and xray parameters interact as follow:
    prop off, xray off: return closest hit or no hit if there is no object on the full extend of the ray.
    prop off, xray on : idem.
    prop on,  xray off: return closest hit if it matches prop, no hit otherwise.
    prop on,  xray on : return closest hit matching prop or no hit if there is no object matching prop on the full extend of the ray.
if poly is 0 or omitted, returns a 3-tuple with object reference, hit point and hit normal or (None,None,None) if no hit.
if poly is 1, returns a 4-tuple with in addition a KX_PolyProxy as 4th element.
The KX_PolyProxy object holds information on the polygon hit by the ray: the index of the vertex forming the poylgon, material, etc.
Attributes (read-only):
 matname: The name of polygon material, empty if no material.
 material: The material of the polygon
 texture: The texture name of the polygon.
 matid: The material index of the polygon, use this to retrieve vertex proxy from mesh proxy
 v1: vertex index of the first vertex of the polygon, use this to retrieve vertex proxy from mesh proxy
 v2: vertex index of the second vertex of the polygon, use this to retrieve vertex proxy from mesh proxy
 v3: vertex index of the third vertex of the polygon, use this to retrieve vertex proxy from mesh proxy
 v4: vertex index of the fourth vertex of the polygon, 0 if polygon has only 3 vertex
     use this to retrieve vertex proxy from mesh proxy
 visible: visible state of the polygon: 1=visible, 0=invisible
 collide: collide state of the polygon: 1=receives collision, 0=collision free.
Methods:
 getMaterialName(): Returns the polygon material name with MA prefix
 getMaterial(): Returns the polygon material
 getTextureName(): Returns the polygon texture name
 getMaterialIndex(): Returns the material bucket index of the polygon. 
 getNumVertex(): Returns the number of vertex of the polygon.
 isVisible(): Returns whether the polygon is visible or not
 isCollider(): Returns whether the polygon is receives collision or not
 getVertexIndex(vertex): Returns the mesh vertex index of a polygon vertex
 getMesh(): Returns a mesh proxy
New methods of KX_MeshProxy have been implemented to retrieve KX_PolyProxy objects:
 getNumPolygons(): Returns the number of polygon in the mesh.
 getPolygon(index): Gets the specified polygon from the mesh.
More details in PyDoc.
											
										 
											2008-08-27 19:34:19 +00:00
										 |  |  | 	m_meshObject = meshobj; | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 	return true; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | btCollisionShape* CcdShapeConstructionInfo::CreateBulletShape() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	btCollisionShape* collisionShape = 0; | 
					
						
							|  |  |  | 	btTriangleMeshShape* concaveShape = 0; | 
					
						
							|  |  |  | 	btTriangleMesh* collisionMeshData = 0; | 
					
						
							|  |  |  | 	btCompoundShape* compoundShape = 0; | 
					
						
							|  |  |  | 	CcdShapeConstructionInfo* nextShapeInfo; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	switch (m_shapeType)  | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2008-08-21 19:00:24 +00:00
										 |  |  | 	case PHY_SHAPE_NONE: | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-21 15:19:54 +00:00
										 |  |  | 	case PHY_SHAPE_BOX: | 
					
						
							|  |  |  | 		collisionShape = new btBoxShape(m_halfExtend); | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	case PHY_SHAPE_SPHERE: | 
					
						
							|  |  |  | 		collisionShape = new btSphereShape(m_radius); | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	case PHY_SHAPE_CYLINDER: | 
					
						
							|  |  |  | 		collisionShape = new btCylinderShapeZ(m_halfExtend); | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	case PHY_SHAPE_CONE: | 
					
						
							|  |  |  | 		collisionShape = new btConeShapeZ(m_radius, m_height); | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	case PHY_SHAPE_POLYTOPE: | 
					
						
							|  |  |  | 		collisionShape = new btConvexHullShape(&m_vertexArray.begin()->getX(), m_vertexArray.size()); | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	case PHY_SHAPE_MESH: | 
					
						
							|  |  |  | 		collisionMeshData = new btTriangleMesh(); | 
					
						
							|  |  |  | 		// m_vertexArray is necessarily a multiple of 3
 | 
					
						
							|  |  |  | 		for (std::vector<btPoint3>::iterator it=m_vertexArray.begin(); it != m_vertexArray.end(); ) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  |             collisionMeshData->addTriangle(*it++,*it++,*it++); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		concaveShape = new btBvhTriangleMeshShape( collisionMeshData, true ); | 
					
						
							|  |  |  | 		concaveShape->recalcLocalAabb(); | 
					
						
							|  |  |  | 		collisionShape = concaveShape; | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	case PHY_SHAPE_COMPOUND: | 
					
						
							|  |  |  | 		if (m_nextShape) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			compoundShape = new btCompoundShape(); | 
					
						
							|  |  |  | 			for (nextShapeInfo=m_nextShape; nextShapeInfo; nextShapeInfo = nextShapeInfo->m_nextShape) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				collisionShape = nextShapeInfo->CreateBulletShape(); | 
					
						
							|  |  |  | 				if (collisionShape) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					compoundShape->addChildShape(nextShapeInfo->m_childTrans, collisionShape); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			collisionShape = compoundShape; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return collisionShape; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void CcdShapeConstructionInfo::AddShape(CcdShapeConstructionInfo* shapeInfo) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	CcdShapeConstructionInfo* nextShape = this; | 
					
						
							|  |  |  | 	while (nextShape->m_nextShape != NULL) | 
					
						
							|  |  |  | 		nextShape = nextShape->m_nextShape; | 
					
						
							|  |  |  | 	nextShape->m_nextShape = shapeInfo; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | CcdShapeConstructionInfo::~CcdShapeConstructionInfo() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	CcdShapeConstructionInfo* childShape = m_nextShape; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	while (childShape) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		CcdShapeConstructionInfo* nextShape = childShape->m_nextShape; | 
					
						
							|  |  |  | 		childShape->m_nextShape = NULL; | 
					
						
							|  |  |  | 		childShape->Release(); | 
					
						
							|  |  |  | 		childShape = nextShape; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	m_vertexArray.clear(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 |