1) Removed some memory leaks in physics.

2) Fixed bug 1827284 (sand track bridge could not be used with bullet) by not
   converting triangles which have the 'ignore' property set.
3) Fixed bug 1826773 (jumping while in air was possible)
4) Started adding support for projectiles which stay close
   to the ground (not finished yet).


git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/trunk/supertuxkart@1284 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
hikerstk 2007-11-08 12:31:54 +00:00
parent 9f7c370334
commit c21c9b5573
10 changed files with 69 additions and 33 deletions

View File

@ -585,6 +585,16 @@ float Kart::getActualWheelForce()
} // getActualWheelForce } // getActualWheelForce
#endif #endif
//-----------------------------------------------------------------------------
#ifdef BULLET
bool Kart::isOnGround()
{
return m_vehicle->getWheelInfo(0).m_raycastInfo.m_isInContact &&
m_vehicle->getWheelInfo(1).m_raycastInfo.m_isInContact &&
m_vehicle->getWheelInfo(2).m_raycastInfo.m_isInContact &&
m_vehicle->getWheelInfo(3).m_raycastInfo.m_isInContact;
} // isOnGround
#endif
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
void Kart::handleExplosion(const sgVec3& pos, bool direct_hit) void Kart::handleExplosion(const sgVec3& pos, bool direct_hit)
{ {
@ -740,7 +750,7 @@ void Kart::update (float dt)
updatePhysics(dt); updatePhysics(dt);
sgCopyVec2 ( m_last_track_coords, m_curr_track_coords ); sgCopyVec2 ( m_last_track_coords, m_curr_track_coords );
if(m_material_hot && m_on_ground) if(m_material_hot && isOnGround())
{ {
float r=m_material_hot->getFriction(); float r=m_material_hot->getFriction();
if(r<m_current_friction) if(r<m_current_friction)
@ -944,8 +954,8 @@ void Kart::updatePhysics (float dt)
{ // going backward, apply reverse gear ratio { // going backward, apply reverse gear ratio
if ( fabs(m_speed) < m_max_speed*m_max_speed_reverse_ratio ) if ( fabs(m_speed) < m_max_speed*m_max_speed_reverse_ratio )
{ {
m_vehicle->applyEngineForce(-m_controls.brake*engine_power, 2); m_vehicle->applyEngineForce(-engine_power*m_controls.brake, 2);
m_vehicle->applyEngineForce(-m_controls.brake*engine_power, 3); m_vehicle->applyEngineForce(-engine_power*m_controls.brake, 3);
} }
else else
{ {
@ -961,7 +971,7 @@ void Kart::updatePhysics (float dt)
} }
} }
if(m_controls.jump) if(isOnGround() && m_controls.jump)
{ {
//Vector3 impulse(0.0f, 0.0f, 10.0f); //Vector3 impulse(0.0f, 0.0f, 10.0f);
// getVehicle()->getRigidBody()->applyCentralImpulse(impulse); // getVehicle()->getRigidBody()->applyCentralImpulse(impulse);
@ -1299,7 +1309,7 @@ void Kart::processSkidMarks()
if(m_skid_rear || m_skid_front) if(m_skid_rear || m_skid_front)
{ {
if(m_on_ground) if(isOnGround())
{ {
const float LENGTH = 0.57f; const float LENGTH = 0.57f;
if(m_skidmark_left) if(m_skidmark_left)

View File

@ -242,6 +242,7 @@ public:
float getSpeed () const {return m_speed; } float getSpeed () const {return m_speed; }
float handleWheelie(float dt); float handleWheelie(float dt);
float getActualWheelForce(); float getActualWheelForce();
bool isOnGround ();
#endif #endif
void adjustSpeedWeight(float f); void adjustSpeedWeight(float f);
void forceRescue (); void forceRescue ();

View File

@ -70,7 +70,9 @@ Moveable::~Moveable()
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
void Moveable::reset () void Moveable::reset ()
{ {
#ifndef BULLET
m_on_ground = true; m_on_ground = true;
#endif
m_collided = false; m_collided = false;
m_crashed = false; m_crashed = false;
m_material_hot = NULL; m_material_hot = NULL;
@ -176,16 +178,7 @@ void Moveable::update (float dt)
} // if m_history_position } // if m_history_position
const float HAT = m_curr_pos.xyz[2]-HOT; const float HAT = m_curr_pos.xyz[2]-HOT;
#ifdef BULLET #ifndef BULLET
m_on_ground = ( HAT <= 1.5 );
// FIXME: we need a correct test here, HOT/HAT are currently not defined
// for bullet (and would require a separate raycast, which can be
// expensive. Perhaps add a function to bullet to indicate if
// all/some/?? wheels toucht the ground.
// m_on_ground is currently only used (in the bullet version) for
// the gui display anyway
#else
m_on_ground = ( HAT <= 0.01 ); m_on_ground = ( HAT <= 0.01 );
doCollisionAnalysis(dt, HOT); doCollisionAnalysis(dt, HOT);
#endif #endif

View File

@ -56,7 +56,9 @@ protected:
int m_crashed; int m_crashed;
sgVec3 m_surface_avoidance_vector ; sgVec3 m_surface_avoidance_vector ;
int m_first_time ; int m_first_time ;
#ifndef BULLET
int m_on_ground ; int m_on_ground ;
#endif
float collectIsectData ( sgVec3 start, sgVec3 end ) ; float collectIsectData ( sgVec3 start, sgVec3 end ) ;
sgCoord* m_history_velocity; sgCoord* m_history_velocity;
@ -75,7 +77,9 @@ public:
virtual ~Moveable(); virtual ~Moveable();
ssgTransform* getModel () {return m_model ; } ssgTransform* getModel () {return m_model ; }
#ifndef BULLET
int isOnGround () {return m_on_ground; } int isOnGround () {return m_on_ground; }
#endif
MoveableType getMoveableType() const {return m_moveable_type; } MoveableType getMoveableType() const {return m_moveable_type; }
void setMoveableType(MoveableType m){m_moveable_type=m; } void setMoveableType(MoveableType m){m_moveable_type=m; }
sgCoord* getVelocity () {return & m_velocity; } sgCoord* getVelocity () {return & m_velocity; }

View File

@ -30,6 +30,7 @@
#include "moving_physics.hpp" #include "moving_physics.hpp"
#include "user_config.hpp" #include "user_config.hpp"
#include "sound_manager.hpp" #include "sound_manager.hpp"
#include "material_manager.hpp"
/** Initialise physics. */ /** Initialise physics. */
@ -38,17 +39,18 @@ float Physics::NOHIT=-99999.9f;
Physics::Physics(float gravity) Physics::Physics(float gravity)
{ {
btDefaultCollisionConfiguration* collisionConf m_collision_conf = new btDefaultCollisionConfiguration();
= new btDefaultCollisionConfiguration(); m_dispatcher = new btCollisionDispatcher(m_collision_conf);
m_dispatcher = new btCollisionDispatcher(collisionConf);
btVector3 worldMin(-1000, -1000, -1000); btVector3 worldMin(-1000, -1000, -1000);
btVector3 worldMax( 1000, 1000, 1000); btVector3 worldMax( 1000, 1000, 1000);
btBroadphaseInterface *axis_sweep = new btAxisSweep3(worldMin, worldMax); m_axis_sweep = new btAxisSweep3(worldMin, worldMax);
btConstraintSolver *constraintSolver = new btSequentialImpulseConstraintSolver(); m_constraint_solver = new btSequentialImpulseConstraintSolver();
m_dynamics_world = new btDiscreteDynamicsWorld(m_dispatcher, axis_sweep, m_dynamics_world = new btDiscreteDynamicsWorld(m_dispatcher,
constraintSolver, collisionConf); m_axis_sweep,
m_constraint_solver,
m_collision_conf);
m_dynamics_world->setGravity(btVector3(0.0f, 0.0f, -gravity)); m_dynamics_world->setGravity(btVector3(0.0f, 0.0f, -gravity));
if(user_config->m_bullet_debug) if(user_config->m_bullet_debug)
{ {
@ -63,6 +65,11 @@ Physics::~Physics()
{ {
delete m_dispatcher; delete m_dispatcher;
delete m_dynamics_world; delete m_dynamics_world;
delete m_axis_sweep;
delete m_collision_conf;
delete m_constraint_solver;
if(user_config->m_bullet_debug) delete m_debug_drawer;
} // ~Physics } // ~Physics
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
@ -104,6 +111,10 @@ void Physics::convertTrack(ssgEntity *track, sgMat4 m, btTriangleMesh* track_mes
else if(track->isAKindOf(ssgTypeLeaf())) else if(track->isAKindOf(ssgTypeLeaf()))
{ {
ssgLeaf *leaf = (ssgLeaf*)(track); ssgLeaf *leaf = (ssgLeaf*)(track);
Material *mat = material_manager->getMaterial(leaf);
// Don't convert triangles with material that is ignored (e.g. fuzzy_sand)
if(!mat || mat->isIgnore()) return;
for(int i=0; i<leaf->getNumTriangles(); i++) for(int i=0; i<leaf->getNumTriangles(); i++)
{ {
short v1,v2,v3; short v1,v2,v3;
@ -280,7 +291,7 @@ void Physics::handleCollisions() {
} // handleCollisions } // handleCollisions
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
float Physics::getHOT(btVector3 pos) float Physics::getHAT(btVector3 pos)
{ {
btVector3 to_pos(pos); btVector3 to_pos(pos);
to_pos.setZ(-100000.f); to_pos.setZ(-100000.f);
@ -289,7 +300,7 @@ float Physics::getHOT(btVector3 pos)
m_dynamics_world->rayTest(pos, to_pos, rayCallback); m_dynamics_world->rayTest(pos, to_pos, rayCallback);
if(!rayCallback.HasHit()) return NOHIT; if(!rayCallback.HasHit()) return NOHIT;
return 1.0f; return rayCallback.m_hitPointWorld.getZ() - pos.getZ();
} // getHOT } // getHOT
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
bool Physics::getTerrainNormal(btVector3 pos, btVector3* normal) bool Physics::getTerrainNormal(btVector3 pos, btVector3* normal)

View File

@ -33,6 +33,9 @@ protected:
Kart *m_kart; Kart *m_kart;
GLDebugDrawer *m_debug_drawer; GLDebugDrawer *m_debug_drawer;
btCollisionDispatcher *m_dispatcher; btCollisionDispatcher *m_dispatcher;
btBroadphaseInterface *m_axis_sweep;
btDefaultCollisionConfiguration *m_collision_conf;
btConstraintSolver *m_constraint_solver;
void convertTrack(ssgEntity *track, sgMat4 m, btTriangleMesh* track_mesh); void convertTrack(ssgEntity *track, sgMat4 m, btTriangleMesh* track_mesh);
public: public:
@ -50,7 +53,7 @@ public:
getPhysicsWorld () const {return m_dynamics_world;} getPhysicsWorld () const {return m_dynamics_world;}
void debugDraw (float m[16], btCollisionShape *s, const btVector3 color); void debugDraw (float m[16], btCollisionShape *s, const btVector3 color);
static float NOHIT; static float NOHIT;
float getHOT (btVector3 pos); float getHAT (btVector3 pos);
bool getTerrainNormal(btVector3 pos, btVector3* normal); bool getTerrainNormal(btVector3 pos, btVector3* normal);
}; };
// For non-bullet version: empty object // For non-bullet version: empty object

View File

@ -147,7 +147,7 @@ void PlayerKart::update(float dt)
m_collectable.use() ; m_collectable.use() ;
m_controls.fire = false; m_controls.fire = false;
} }
if ( m_on_ground && m_controls.rescue ) if ( isOnGround() && m_controls.rescue )
{ {
sound_manager -> playSfx ( SOUND_BEEP ) ; sound_manager -> playSfx ( SOUND_BEEP ) ;
forceRescue(); forceRescue();

View File

@ -112,6 +112,7 @@ void Projectile::init(Kart *kart, int collectable_)
// terrain is under the rocket). Once hot is done with bullet as // terrain is under the rocket). Once hot is done with bullet as
// well, this shouldn't be necessary anymore. // well, this shouldn't be necessary anymore.
placeModel(); placeModel();
m_current_HAT = world->getHAT(offset.getOrigin());
#else #else
sgCoord c; sgCoord c;
@ -147,6 +148,12 @@ void Projectile::update (float dt)
#ifdef BULLET #ifdef BULLET
if(m_exploded) return; if(m_exploded) return;
m_body->setLinearVelocity(m_initial_velocity); m_body->setLinearVelocity(m_initial_velocity);
m_HAT_counter++;
if(m_HAT_counter==10)
{
m_current_HAT = world->getHAT(getBody()->getCenterOfMassPosition());
m_HAT_counter = 0;
}
#else #else
// we don't even do any physics here - just set the // we don't even do any physics here - just set the
// velocity, and ignore everything else for projectiles. // velocity, and ignore everything else for projectiles.

View File

@ -36,6 +36,9 @@ class Projectile : public Moveable
#ifdef BULLET #ifdef BULLET
bool m_exploded; bool m_exploded;
btVector3 m_initial_velocity; btVector3 m_initial_velocity;
float m_current_HAT; // height above terrain
int m_HAT_counter; // compute HAT only every N timesteps
#endif #endif
public: public:

View File

@ -101,6 +101,10 @@ public:
Phase getPhase() const { return m_phase; } Phase getPhase() const { return m_phase; }
float getGravity() const { return m_track->getGravity(); } float getGravity() const { return m_track->getGravity(); }
Physics *getPhysics() const { return m_physics; } Physics *getPhysics() const { return m_physics; }
Track *getTrack() const { return m_track; }
#ifdef BULLET
float getHAT(btVector3 pos) const { return m_physics->getHAT(pos); }
#endif
Kart* getFastestKart() const { return m_fastest_kart; } Kart* getFastestKart() const { return m_fastest_kart; }
float getFastestLapTime() const { return m_fastest_lap; } float getFastestLapTime() const { return m_fastest_lap; }
void setFastestLap(Kart *k, float time) {m_fastest_kart=k;m_fastest_lap=time;} void setFastestLap(Kart *k, float time) {m_fastest_kart=k;m_fastest_lap=time;}