2012-03-19 19:38:44 -04:00
# include "trace.h"
# include <map>
2013-02-08 13:12:34 -08:00
# include <btBulletDynamicsCommon.h>
# include <btBulletCollisionCommon.h>
2013-02-06 21:47:09 -08:00
# include "physic.hpp"
2012-03-19 19:38:44 -04:00
2013-03-03 13:06:45 +00:00
# define BIT(x) (1<<(x))
2012-03-19 19:38:44 -04:00
2013-02-08 13:12:34 -08:00
enum traceWorldType
2012-03-19 19:38:44 -04:00
{
2013-02-08 13:12:34 -08:00
collisionWorldTrace = 1 ,
pickWorldTrace = 2 ,
bothWorldTrace = collisionWorldTrace | pickWorldTrace
} ;
2012-03-19 19:38:44 -04:00
2013-02-08 13:12:34 -08:00
enum collaborativePhysicsType
{
No_Physics = 0 , // Both are empty (example: statics you can walk through, like tall grass)
Only_Collision = 1 , // This object only has collision physics but no pickup physics (example: statics)
Only_Pickup = 2 , // This object only has pickup physics but no collision physics (example: items dropped on the ground)
Both_Physics = 3 // This object has both kinds of physics (example: activators)
} ;
2012-03-19 19:38:44 -04:00
2013-03-03 13:06:45 +00:00
enum collisiontypes {
COL_NOTHING = 0 , //<Collide with nothing
COL_WORLD = BIT ( 0 ) , //<Collide with world objects
COL_ACTOR_INTERNAL = BIT ( 1 ) , //<Collide internal capsule
COL_ACTOR_EXTERNAL = BIT ( 2 ) , //<collide with external capsule
COL_RAYCASTING = BIT ( 3 )
} ;
2013-02-20 04:14:52 -08:00
void newtrace ( traceResults * results , const Ogre : : Vector3 & start , const Ogre : : Vector3 & end , const Ogre : : Vector3 & BBHalfExtents , bool isInterior , OEngine : : Physic : : PhysicEngine * enginePass ) //Traceobj was a Aedra Object
2012-03-19 19:38:44 -04:00
{
2013-02-08 13:12:34 -08:00
const btVector3 btstart ( start . x , start . y , start . z + BBHalfExtents . z ) ;
const btVector3 btend ( end . x , end . y , end . z + BBHalfExtents . z ) ;
2013-02-20 04:14:52 -08:00
const btQuaternion btrot ( 0.0f , 0.0f , 0.0f ) ; //y, x, z
2012-03-19 19:38:44 -04:00
2012-08-14 18:04:58 -04:00
const btBoxShape newshape ( btVector3 ( BBHalfExtents . x , BBHalfExtents . y , BBHalfExtents . z ) ) ;
2013-02-08 13:12:34 -08:00
//const btCapsuleShapeZ newshape(BBHalfExtents.x, BBHalfExtents.z * 2 - BBHalfExtents.x * 2);
const btTransform from ( btrot , btstart ) ;
const btTransform to ( btrot , btend ) ;
btCollisionWorld : : ClosestConvexResultCallback newTraceCallback ( btstart , btend ) ;
2013-03-03 13:06:45 +00:00
newTraceCallback . m_collisionFilterMask = COL_WORLD | COL_RAYCASTING ;
2013-02-08 13:12:34 -08:00
enginePass - > dynamicsWorld - > convexSweepTest ( & newshape , from , to , newTraceCallback ) ;
// Copy the hit data over to our trace results struct:
2013-02-20 04:14:52 -08:00
if ( newTraceCallback . hasHit ( ) )
2013-02-08 13:12:34 -08:00
{
2013-02-20 04:14:52 -08:00
const btVector3 & tracehitnormal = newTraceCallback . m_hitNormalWorld ;
results - > fraction = newTraceCallback . m_closestHitFraction ;
results - > planenormal = Ogre : : Vector3 ( tracehitnormal . x ( ) , tracehitnormal . y ( ) , tracehitnormal . z ( ) ) ;
results - > endpos = ( end - start ) * results - > fraction + start ;
2013-02-08 13:12:34 -08:00
}
else
{
2013-02-20 04:14:52 -08:00
results - > endpos = end ;
results - > planenormal = Ogre : : Vector3 ( 0.0f , 0.0f , 1.0f ) ;
results - > fraction = 1.0f ;
2013-02-08 13:12:34 -08:00
}
2012-03-19 19:38:44 -04:00
}