2014-10-20 16:48:20 +00:00
# ifndef PHYSICS_HH_INCLUDED
# define PHYSICS_HH_INCLUDED
2014-10-20 16:39:16 +00:00
2014-11-14 13:17:04 +00:00
# include <ACGL/Base/Settings.hh>
# include <ACGL/Math/Math.hh>
# include <vector>
2014-12-15 15:02:04 +00:00
# include <string>
# include <stdio.h>
2014-11-14 13:17:04 +00:00
2014-11-21 11:50:11 +00:00
# include "entity.hh"
2014-11-14 13:17:04 +00:00
# include "extern/bullet/src/BulletDynamics/Dynamics/btRigidBody.h"
# include "extern/bullet/src/BulletDynamics/Dynamics/btDynamicsWorld.h"
# include "extern/bullet/src/BulletDynamics/Dynamics/btDiscreteDynamicsWorld.h"
2014-11-14 13:23:10 +00:00
2014-11-14 13:17:04 +00:00
# include "extern/bullet/src/BulletCollision/CollisionShapes/btSphereShape.h"
2014-11-21 11:50:11 +00:00
# include "extern/bullet/src/BulletCollision/CollisionShapes/btBoxShape.h"
2014-11-14 13:23:10 +00:00
# include "extern/bullet/src/BulletCollision/CollisionShapes/btHeightfieldTerrainShape.h"
2014-11-17 11:57:16 +00:00
# include "extern/bullet/src/BulletCollision/CollisionShapes/btStaticPlaneShape.h"
2014-11-28 15:46:35 +00:00
# include "extern/bullet/src/BulletCollision/CollisionShapes/btBvhTriangleMeshShape.h"
# include "extern/bullet/src/BulletCollision/CollisionShapes/btTriangleMesh.h"
2014-12-15 15:02:04 +00:00
# include "extern/bullet/src/BulletCollision/CollisionShapes/btCollisionShape.h"
# include "extern/bullet/src/BulletCollision/CollisionShapes/btConvexTriangleMeshShape.h"
2014-11-14 13:17:04 +00:00
# include "extern/bullet/src/BulletDynamics/ConstraintSolver/btConstraintSolver.h"
# include "extern/bullet/src/BulletDynamics/ConstraintSolver/btSequentialImpulseConstraintSolver.h" //YAY!
2014-11-28 12:52:03 +00:00
# include "extern/bullet/src/BulletDynamics/ConstraintSolver/btPoint2PointConstraint.h"
2014-11-14 13:17:04 +00:00
# include "extern/bullet/src/BulletCollision/CollisionDispatch/btCollisionConfiguration.h"
# include "extern/bullet/src/BulletCollision/CollisionDispatch/btDefaultCollisionConfiguration.h"
# include "extern/bullet/src/BulletCollision/BroadphaseCollision/btBroadphaseInterface.h"
# include "extern/bullet/src/BulletCollision/BroadphaseCollision/btDbvtBroadphase.h"
# include "extern/bullet/src/BulletCollision/BroadphaseCollision/btDispatcher.h"
# include "extern/bullet/src/LinearMath/btScalar.h"
# include "extern/bullet/src/LinearMath/btMotionState.h"
# include "extern/bullet/src/LinearMath/btDefaultMotionState.h"
# include "extern/bullet/src/LinearMath/btQuaternion.h"
2014-11-14 14:15:29 +00:00
# include "extern/bullet/src/LinearMath/btVector3.h"
# include "extern/bullet/src/LinearMath/btMatrix3x3.h"
2014-11-14 13:17:04 +00:00
2014-11-07 15:44:12 +00:00
class Physics {
public :
2014-11-17 11:57:16 +00:00
Physics ( ) ;
2014-11-14 13:17:04 +00:00
~ Physics ( ) ;
2015-01-17 12:11:43 +00:00
void init ( ) ;
2014-11-28 11:06:17 +00:00
void takeUpdateStep ( float timeDiff ) ; //must be used in level.update to proagate the physics
void rollForward ( glm : : vec3 camPos , float strength ) ; //self explainitory
2014-11-17 15:07:40 +00:00
void rollLeft ( glm : : vec3 camPos , float strength ) ;
void rollRight ( glm : : vec3 camPos , float strength ) ;
void rollBack ( glm : : vec3 camPos , float strength ) ;
2014-11-14 13:23:10 +00:00
glm : : vec3 getPos ( int i ) ;
2014-11-14 14:15:29 +00:00
glm : : mat4 getRotation ( int i ) ;
2014-11-17 11:57:16 +00:00
void addStaticGroundPlane ( ) ;
2015-01-06 12:31:53 +00:00
void addCamera ( float rad , float distance ) ; //Do NOT impliment before Player has been created;
2014-11-28 12:52:03 +00:00
glm : : vec3 getCameraPosition ( ) ;
2015-01-06 12:31:53 +00:00
void addRigidBodyFromFile ( Entity entity , float mass , float dampningL , float dampningA , std : : string modelLocation , unsigned indice ) ;
void addTriangleMeshBody ( Entity entity , std : : string path , float mass , float dampningL , float dampningA , unsigned indice ) ;
2014-11-14 13:23:10 +00:00
void addTerrain ( int width , int length , float * * heightData ) ;
2014-12-15 15:02:04 +00:00
void addTerrainTriangles ( int width , int length , float * * heightData ) ; //add the terrain as a trimesh instead of a heightmap
2015-01-06 12:31:53 +00:00
void addPlayer ( float friction , float rad , Entity entity , float mass , float dampningL , float dampningA , unsigned indice ) ; //use these AFTER physicObjects.push_back(object)! if mass == 0 then the object is unmoveable
void addSphere ( float rad , Entity entity , float mass , float dampningL , float dampningA , unsigned indice ) ; //The Indice should be set to physicObjects.size()
void addBox ( float width , float height , float length , Entity entity , float mass , float dampningL , float dampningA , unsigned indice ) ; //this is used to ensuer that the system is synchronized
2015-01-16 15:17:26 +00:00
void addPositionConstraint ( int bodyIndice , float strength , glm : : vec3 position ) ;
void removePositionConstraint ( int bodyIndice ) ;
struct positionConstraint { btRigidBody * body ; float strength ; btVector3 position ; } ;
2014-11-14 13:23:10 +00:00
2014-11-14 13:17:04 +00:00
private :
2014-12-15 15:02:04 +00:00
btRigidBody * playerBall ; //allows for easier access to the ball
2014-11-28 11:06:17 +00:00
btRigidBody * terrainBody ; //duh
2014-11-28 12:52:03 +00:00
btRigidBody * cameraBody ;
2014-11-14 13:17:04 +00:00
std : : vector < btRigidBody * > bodies ; //list of all bodies. bodies are also in world, but save again to ease cleaning up process.
2014-11-17 11:57:16 +00:00
btRigidBody * staticGroundBody ;
2015-01-16 15:17:26 +00:00
std : : vector < positionConstraint > allPositionConstraints ;
2014-12-15 15:02:04 +00:00
2014-11-14 13:17:04 +00:00
btDynamicsWorld * world ; //contains physical attributes of the world.
btDispatcher * dispatcher ; //
btCollisionConfiguration * colConfig ; //defines the type of collision detection.
btBroadphaseInterface * broadphase ; //defines how objects are culled from collision detection.
btConstraintSolver * solver ; //solver for forces and impulses.
2014-11-07 15:44:12 +00:00
} ;
2014-11-28 12:52:03 +00:00
2014-12-15 15:02:04 +00:00
enum collisionTypes {
COL_NOTHING = 0 ,
COL_TERRAIN = 1 ,
COL_OBJECTS = 2 ,
COL_OBJECTS_NO_TERRAIN = 4
} ;
2014-11-28 12:52:03 +00:00
class btDistanceConstraint : public btPoint2PointConstraint
{
protected :
btScalar m_distance ;
public :
btDistanceConstraint ( btRigidBody & rbA , btRigidBody & rbB , const btVector3 & pivotInA , const btVector3 & pivotInB , btScalar dist )
: btPoint2PointConstraint ( rbA , rbB , pivotInA , pivotInB )
{
m_distance = dist ;
}
virtual void getInfo1 ( btConstraintInfo1 * info )
{
info - > m_numConstraintRows = 1 ;
info - > nub = 5 ;
}
virtual void getInfo2 ( btConstraintInfo2 * info )
{
btVector3 relA = m_rbA . getCenterOfMassTransform ( ) . getBasis ( ) * getPivotInA ( ) ;
btVector3 relB = m_rbB . getCenterOfMassTransform ( ) . getBasis ( ) * getPivotInB ( ) ;
btVector3 posA = m_rbA . getCenterOfMassTransform ( ) . getOrigin ( ) + relA ;
btVector3 posB = m_rbB . getCenterOfMassTransform ( ) . getOrigin ( ) + relB ;
btVector3 del = posB - posA ;
btScalar currDist = btSqrt ( del . dot ( del ) ) ;
btVector3 ortho = del / currDist ;
info - > m_J1linearAxis [ 0 ] = ortho [ 0 ] ;
info - > m_J1linearAxis [ 1 ] = ortho [ 1 ] ;
info - > m_J1linearAxis [ 2 ] = ortho [ 2 ] ;
btVector3 p , q ;
p = relA . cross ( ortho ) ;
q = relB . cross ( ortho ) ;
info - > m_J1angularAxis [ 0 ] = p [ 0 ] ;
info - > m_J1angularAxis [ 1 ] = p [ 1 ] ;
info - > m_J1angularAxis [ 2 ] = p [ 2 ] ;
info - > m_J2angularAxis [ 0 ] = - q [ 0 ] ;
info - > m_J2angularAxis [ 1 ] = - q [ 1 ] ;
info - > m_J2angularAxis [ 2 ] = - q [ 2 ] ;
btScalar rhs = ( currDist - m_distance ) * info - > fps * info - > erp ;
info - > m_constraintError [ 0 ] = rhs ;
info - > cfm [ 0 ] = btScalar ( 0.f ) ;
info - > m_lowerLimit [ 0 ] = - SIMD_INFINITY ;
info - > m_upperLimit [ 0 ] = SIMD_INFINITY ;
}
} ;
2014-10-20 16:48:20 +00:00
# endif