#ifndef OENGINE_BULLET_PHYSIC_H #define OENGINE_BULLET_PHYSIC_H #include #include "BulletCollision/CollisionDispatch/btGhostObject.h" #include #include #include #include "BulletShapeLoader.h" #include "BulletCollision/CollisionShapes/btScaledBvhTriangleMeshShape.h" class btRigidBody; class btBroadphaseInterface; class btDefaultCollisionConfiguration; class btSequentialImpulseConstraintSolver; class btCollisionDispatcher; class btDiscreteDynamicsWorld; class btHeightfieldTerrainShape; namespace BtOgre { class DebugDrawer; } namespace Ogre { class SceneManager; } namespace MWWorld { class World; } namespace OEngine { namespace Physic { struct PhysicEvent; class PhysicEngine; class RigidBody; enum CollisionType { CollisionType_Nothing = 0, // rayTest(btVector3& from,btVector3& to,bool raycastingObjectOnly = true, bool ignoreHeightMap = false, Ogre::Vector3* normal = NULL); /** * Return all objects hit by a ray. */ std::vector< std::pair > rayTest2(btVector3& from, btVector3& to); std::pair sphereCast (float radius, btVector3& from, btVector3& to); ///< @return (hit, relative distance) std::vector getCollisions(const std::string& name); // Get the nearest object that's inside the given object, filtering out objects of the // provided name std::pair getFilteredContact(const std::string &filter, const btVector3 &origin, btCollisionObject *object); //Bullet Stuff btOverlappingPairCache* pairCache; btBroadphaseInterface* broadphase; btDefaultCollisionConfiguration* collisionConfiguration; btSequentialImpulseConstraintSolver* solver; btCollisionDispatcher* dispatcher; btDiscreteDynamicsWorld* dynamicsWorld; //the NIF file loader. BulletShapeLoader* mShapeLoader; typedef std::map HeightFieldContainer; HeightFieldContainer mHeightFieldMap; typedef std::map RigidBodyContainer; RigidBodyContainer mCollisionObjectMap; RigidBodyContainer mRaycastingObjectMap; typedef std::map PhysicActorContainer; PhysicActorContainer mActorMap; Ogre::SceneManager* mSceneMgr; //debug rendering BtOgre::DebugDrawer* mDebugDrawer; bool isDebugCreated; bool mDebugActive; }; struct MyRayResultCallback : public btCollisionWorld::RayResultCallback { virtual btScalar addSingleResult( btCollisionWorld::LocalRayResult& rayResult, bool bNormalInWorldSpace) { results.push_back( std::make_pair(rayResult.m_hitFraction, rayResult.m_collisionObject) ); return rayResult.m_hitFraction; } static bool cmp( const std::pair& i, const std::pair& j ) { if( i.first > j.first ) return false; if( j.first > i.first ) return true; return false; } std::vector < std::pair > results; }; }} #endif