1) Fixed incorrect pitch of rockets when firing.
2) The 'unlimited rocket' cheat is now bound to F7 (before it was a clear key, which isn't available on all keyboards - at least not on mine). Bullet only: 3) Gear parameters are now configureable and can be specified in stk_config.data and separately for each kart. 4) An explosion will somewhat push other karts that are close by away (some feedback on this feature is welcome - the impulse can be set in the stk_config file). git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/trunk/supertuxkart@1214 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
parent
334ec17dc2
commit
921c2621dc
@ -138,7 +138,7 @@ case "${host}" in
|
||||
# include <AL/alut.h>
|
||||
# define MIN_ALUT_VERSION 1
|
||||
int main() {
|
||||
if(alutGetMajorVersion()<MIN_ALUT_VERSION) return -1;
|
||||
/* if(alutGetMajorVersion()<MIN_ALUT_VERSION) return -1;*/
|
||||
return 0; }
|
||||
|
||||
],
|
||||
|
@ -21,6 +21,8 @@
|
||||
;; we have to use at least 21(!!)
|
||||
(shortcut-skipped-segments 5 ) ;; skipping more than this number of segments
|
||||
;; is considered to be a shortcut
|
||||
(explosion-impulse 10000.0 ) ;; explosion impulse on not directly hit karts
|
||||
|
||||
;; Other kart relates values
|
||||
;; -------------------------
|
||||
(jump-impulse 5400.0 ) ;; percentage of gravity!
|
||||
@ -76,6 +78,13 @@
|
||||
(gravity-center-shift 0.4 ) ;; Shift center of gravity down by that many
|
||||
;; units of kart_height (usually between 0 and 0.5)
|
||||
(suspension-rest 0.1 )
|
||||
;; The following two vectors define at what ratio of the maximum speed what
|
||||
;; gear is selected, e.g. 0.25 means: if speed <=0.25*maxSpeed --> gear 1,
|
||||
;; 0.5 means: if speed <=0.5 *maxSpeed --> gear 2
|
||||
;; The next vector contains the increase in max power (to simulate different
|
||||
;; gears), e.g. 2.5 as first entry means: 2.5*maxPower in gear 1
|
||||
(gear-switch-ratio 0.25 0.5 0.75)
|
||||
(gear-power-increase 2.5 1.8 1.4 )
|
||||
|
||||
) ;; end kart-defaults
|
||||
)
|
||||
|
@ -9,6 +9,5 @@
|
||||
(red 0.7)
|
||||
(green 0.0)
|
||||
(blue 0.0)
|
||||
|
||||
)
|
||||
;; EOF ;;
|
||||
|
@ -168,7 +168,7 @@ void RaceGUI::inputKeyboard(int key, int pressed)
|
||||
static int isWireframe = false ;
|
||||
switch ( key )
|
||||
{
|
||||
case 0x12: // TODO: Which key is that?
|
||||
case SDLK_F7:
|
||||
if(world->m_race_setup.getNumPlayers()==1)
|
||||
{ // ctrl-r
|
||||
Kart* kart = world->getPlayerKart(0);
|
||||
|
60
src/kart.cpp
60
src/kart.cpp
@ -571,41 +571,53 @@ void Kart::doZipperProcessing (float delta)
|
||||
//-----------------------------------------------------------------------------
|
||||
float Kart::getActualWheelForce()
|
||||
{
|
||||
if ( m_speed <= m_max_speed*0.25f )
|
||||
const std::vector<float>& gear_ratio=m_kart_properties->getGearSwitchRatio();
|
||||
for(unsigned int i=0; i<gear_ratio.size(); i++)
|
||||
{
|
||||
return( getMaxPower() * 2.5f ); // gear 1
|
||||
if(m_speed <= m_max_speed*gear_ratio[i])
|
||||
return getMaxPower()*m_kart_properties->getGearPowerIncrease()[i];
|
||||
}
|
||||
else if ( m_speed > m_max_speed*0.25f && m_speed <= m_max_speed*0.5f )
|
||||
{
|
||||
return( getMaxPower() * 1.8f ); // gear 2
|
||||
}
|
||||
else if ( m_speed > m_max_speed*0.5f && m_speed <= m_max_speed*0.75f )
|
||||
{
|
||||
return( getMaxPower() * 1.4f ); // gear 3
|
||||
}
|
||||
else if ( m_speed > m_max_speed*0.75f )
|
||||
{
|
||||
return( getMaxPower() ); // gear 4
|
||||
}
|
||||
return(0.0f);
|
||||
}
|
||||
return getMaxPower();
|
||||
|
||||
} // getActualWheelForce
|
||||
#endif
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
void Kart::getsProjectile ()
|
||||
void Kart::handleExplosion(const sgVec3& pos, bool direct_hit)
|
||||
{
|
||||
#ifdef BULLET
|
||||
btVector3 velocity = m_kart_body->getLinearVelocity();
|
||||
if(direct_hit) {
|
||||
btVector3 velocity = m_kart_body->getLinearVelocity();
|
||||
|
||||
velocity.setX( 0.0f );
|
||||
velocity.setY( 0.0f );
|
||||
velocity.setZ( 3.5f );
|
||||
velocity.setX( 0.0f );
|
||||
velocity.setY( 0.0f );
|
||||
velocity.setZ( 3.5f );
|
||||
|
||||
getVehicle()->getRigidBody()->setLinearVelocity( velocity );
|
||||
}
|
||||
else // only affected by a distant explosion
|
||||
{
|
||||
sgVec3 diff;
|
||||
sgSubVec3(diff, getCoord()->xyz, pos);
|
||||
float len2=sgLengthSquaredVec3(diff);
|
||||
|
||||
// The correct forumale would be to first normalise diff,
|
||||
// then apply the impulse (which decreases 1/r^2 depending
|
||||
// on the distance r), so:
|
||||
// diff/len(diff) * impulseSize/len(diff)^2
|
||||
// = diff*impulseSize/len(diff)^3
|
||||
// We use diff*impulseSize/len(diff)^2 here, this makes the impulse
|
||||
// somewhat larger, which is actually more fun :)
|
||||
sgScaleVec3(diff,stk_config->m_explosion_impulse/len2);
|
||||
btVector3 impulse(diff[0],diff[1], diff[2]);
|
||||
getVehicle()->getRigidBody()->applyCentralImpulse(impulse);
|
||||
}
|
||||
|
||||
getVehicle()->getRigidBody()->setLinearVelocity( velocity );
|
||||
#else
|
||||
forceCrash();
|
||||
// only the kart hit directly is affected.
|
||||
if(direct_hit) forceCrash();
|
||||
#endif
|
||||
}
|
||||
} // handleExplosion
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
void Kart::forceCrash ()
|
||||
|
@ -244,6 +244,7 @@ public:
|
||||
#endif
|
||||
void adjustSpeedWeight(float f);
|
||||
void forceRescue ();
|
||||
void handleExplosion (const sgVec3& pos, bool direct_hit);
|
||||
const std::string& getName () const {return m_kart_properties->getName();}
|
||||
virtual int isPlayerKart () const {return 0; }
|
||||
// addMessages gets called by world to add messages to the gui
|
||||
@ -257,7 +258,6 @@ public:
|
||||
virtual void doCollisionAnalysis(float dt, float hot );
|
||||
virtual void doObjectInteractions();
|
||||
virtual void OutsideTrack (int isReset) {m_rescue=true;}
|
||||
virtual void getsProjectile ();
|
||||
};
|
||||
|
||||
class TrafficDriver : public Kart
|
||||
|
@ -160,6 +160,15 @@ void KartProperties::getAllData(const lisp::Lisp* lisp)
|
||||
lisp->get("maximum-speed", m_maximum_speed );
|
||||
lisp->get("gravity-center-shift", m_gravity_center_shift );
|
||||
lisp->get("suspension-rest", m_suspension_rest );
|
||||
#ifdef BULLET
|
||||
// getVector appends to existing vectors, so a new one must be used to load
|
||||
std::vector<float> temp;
|
||||
lisp->getVector("gear-switch-ratio", temp);
|
||||
if(temp.size()>0) m_gear_switch_ratio = temp;
|
||||
temp.clear();
|
||||
lisp->getVector("gear-power-increase", temp);
|
||||
if(temp.size()>0) m_gear_power_increase = temp;
|
||||
#endif
|
||||
|
||||
} // getAllData
|
||||
|
||||
@ -215,6 +224,8 @@ void KartProperties::init_defaults()
|
||||
m_max_speed_reverse_ratio = stk_config->m_max_speed_reverse_ratio;
|
||||
m_gravity_center_shift = stk_config->m_gravity_center_shift;
|
||||
m_suspension_rest = stk_config->m_suspension_rest;
|
||||
m_gear_switch_ratio = stk_config->m_gear_switch_ratio;
|
||||
m_gear_power_increase = stk_config->m_gear_power_increase;
|
||||
|
||||
} // init_defaults
|
||||
|
||||
|
@ -21,6 +21,7 @@
|
||||
#define HEADER_KARTPROPERTIES_H
|
||||
|
||||
#include <string>
|
||||
#include <vector>
|
||||
#include "lisp/lisp.hpp"
|
||||
#include "no_copy.hpp"
|
||||
|
||||
@ -89,6 +90,15 @@ protected:
|
||||
float m_max_speed_reverse_ratio;
|
||||
float m_gravity_center_shift;
|
||||
float m_suspension_rest;
|
||||
// The following two vectors define at what ratio of the maximum speed what
|
||||
// gear is selected, e.g. 0.25 means: if speed <=0.25*maxSpeed --> gear 1,
|
||||
// 0.5 means: if speed <=0.5 *maxSpeed --> gear 2
|
||||
// The next vector contains the increase in max power (to simulate different
|
||||
// gears), e.g. 2.5 as first entry means: 2.5*maxPower in gear 1
|
||||
std::vector<float> m_gear_switch_ratio;
|
||||
std::vector<float> m_gear_power_increase;
|
||||
|
||||
|
||||
public:
|
||||
KartProperties ();
|
||||
virtual ~KartProperties ();
|
||||
@ -145,6 +155,10 @@ public:
|
||||
float getMaximumSpeed () const {return m_maximum_speed; }
|
||||
float getGravityCenterShift () const {return m_gravity_center_shift; }
|
||||
float getSuspensionRest () const {return m_suspension_rest; }
|
||||
const std::vector<float>&
|
||||
getGearSwitchRatio () const {return m_gear_switch_ratio; }
|
||||
const std::vector<float>&
|
||||
getGearPowerIncrease () const {return m_gear_power_increase; }
|
||||
};
|
||||
|
||||
#endif
|
||||
|
@ -68,6 +68,7 @@ public:
|
||||
int isOnGround () {return m_on_ground; }
|
||||
sgCoord* getVelocity () {return & m_velocity; }
|
||||
sgCoord* getCoord () {return &m_curr_pos; }
|
||||
const sgVec4* getNormalHOT () const {return m_normal_hot; }
|
||||
void setCoord (sgCoord* pos) {sgCopyCoord ( &m_curr_pos,pos); }
|
||||
virtual void placeModel () {m_model->setTransform(&m_curr_pos); }
|
||||
virtual void handleZipper () {};
|
||||
|
@ -42,7 +42,28 @@ void Projectile::init(Kart *kart, int collectable_)
|
||||
m_speed = collectable_manager->getSpeed(m_type);
|
||||
ssgTransform *m = getModel();
|
||||
m->addKid(collectable_manager->getModel(m_type));
|
||||
setCoord(kart->getCoord());
|
||||
|
||||
sgCoord c;
|
||||
sgCopyCoord(&c, kart->getCoord());
|
||||
const float angle_terrain = c.hpr[0]*M_PI/180.0f;
|
||||
// The projectile should have the pitch of the terrain on which the kart
|
||||
// is - while this is not really realistic, it plays much better this way
|
||||
const sgVec4* normal = kart->getNormalHOT();
|
||||
if(normal)
|
||||
{
|
||||
const float X = -sin(angle_terrain);
|
||||
const float Y = cos(angle_terrain);
|
||||
// Compute the angle between the normal of the plane and the line to
|
||||
// (x,y,0). (x,y,0) is normalised, so are the coordinates of the plane,
|
||||
// simplifying the computation of the scalar product.
|
||||
float pitch = ( (*normal)[0]*X + (*normal)[1]*Y ); // use ( x,y,0)
|
||||
|
||||
// The actual angle computed above is between the normal and the (x,y,0)
|
||||
// line, so to compute the actual angles 90 degrees must be subtracted.
|
||||
c.hpr[1] = acosf(pitch)/M_PI*180.0f-90.0f;
|
||||
}
|
||||
|
||||
setCoord(&c);
|
||||
scene->add(m);
|
||||
} // init
|
||||
|
||||
@ -80,12 +101,7 @@ void Projectile::doObjectInteractions ()
|
||||
|
||||
if ( D < 2.0f )
|
||||
{
|
||||
explode();
|
||||
#ifdef BULLET
|
||||
kart -> getsProjectile () ;
|
||||
#else
|
||||
kart -> forceCrash () ;
|
||||
#endif
|
||||
explode(kart);
|
||||
return;
|
||||
}
|
||||
else if ( D < ndist )
|
||||
@ -176,13 +192,13 @@ void Projectile::doCollisionAnalysis ( float dt, float hot )
|
||||
}
|
||||
else if ( m_type != COLLECT_NOTHING )
|
||||
{
|
||||
explode();
|
||||
explode(NULL); // no kart was hit directly
|
||||
}
|
||||
} // if m_collided||m_crashed
|
||||
} // doCollisionAnalysis
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
void Projectile::explode()
|
||||
void Projectile::explode(Kart *kart_hit)
|
||||
{
|
||||
m_has_hit_something=true;
|
||||
m_curr_pos.xyz[2] += 1.2f ;
|
||||
@ -196,6 +212,14 @@ void Projectile::explode()
|
||||
ssgTransform *m = getModel();
|
||||
m->removeAllKids();
|
||||
scene->remove(m);
|
||||
|
||||
for ( unsigned int i = 0 ; i < world->getNumKarts() ; i++ )
|
||||
{
|
||||
Kart *kart = world -> getKart(i);
|
||||
// handle the actual explosion. Set a flag it if was a direct hit.
|
||||
kart->handleExplosion(m_curr_pos.xyz, kart==kart_hit);
|
||||
}
|
||||
|
||||
} // explode
|
||||
|
||||
/* EOF */
|
||||
|
@ -41,14 +41,14 @@ public:
|
||||
void update (float);
|
||||
void doCollisionAnalysis (float dt, float hot);
|
||||
void doObjectInteractions();
|
||||
void explode ();
|
||||
void explode (Kart* kart);
|
||||
bool hasHit () {return m_has_hit_something;}
|
||||
void reset ()
|
||||
{
|
||||
Moveable::reset();
|
||||
sgCopyCoord(&m_last_pos,&m_reset_pos );
|
||||
}
|
||||
void OutsideTrack (int isReset) {explode();}
|
||||
void OutsideTrack (int isReset) {explode(NULL);}
|
||||
|
||||
} ;
|
||||
|
||||
|
@ -34,7 +34,25 @@ void STKConfig::load(const std::string filename)
|
||||
fprintf(stderr,"Missing default value for '%s' in '%s'.\n", \
|
||||
strA,filename.c_str());exit(-1); \
|
||||
}
|
||||
|
||||
#ifdef BULLET
|
||||
if(m_gear_switch_ratio.size()==0)
|
||||
{
|
||||
fprintf(stderr,"Missing default value for 'gear-switch-ratio' in '%s'.\n",
|
||||
filename.c_str());
|
||||
exit(-1);
|
||||
}
|
||||
if(m_gear_power_increase.size()==0)
|
||||
{
|
||||
fprintf(stderr,"Missing default value for 'gear-power-increase' in '%s'.\n",
|
||||
filename.c_str());
|
||||
exit(-1);
|
||||
}
|
||||
if(m_gear_switch_ratio.size()!=m_gear_power_increase.size()) {
|
||||
fprintf(stderr,"Number of entries for 'gear-switch-ratio' and 'gear-power-increase");
|
||||
fprintf(stderr,"in '%s' must be equal.\n", filename.c_str());
|
||||
exit(-1);
|
||||
}
|
||||
#endif
|
||||
CHECK_NEG(m_corn_r, "m_corn_r" );
|
||||
CHECK_NEG(m_corn_f, "m_corn_f" );
|
||||
|
||||
@ -91,7 +109,7 @@ void STKConfig::load(const std::string filename)
|
||||
CHECK_NEG(m_max_road_distance, "shortcut-road-distance" );
|
||||
CHECK_NEG(m_shortcut_segments, "shortcut-skipped-segments" );
|
||||
CHECK_NEG(m_suspension_rest, "suspension-rest" );
|
||||
|
||||
CHECK_NEG(m_explosion_impulse, "explosion-impulse" );
|
||||
|
||||
// Precompute some handy values to reduce work later
|
||||
m_magnet_range_sq = m_magnet_range_sq * m_magnet_range_sq;
|
||||
@ -119,7 +137,7 @@ void STKConfig::init_defaults()
|
||||
m_wheelie_lean_recovery = m_wheelie_step = m_wheelie_balance_recovery =
|
||||
m_wheelie_power_boost = m_chassis_linear_damping = m_chassis_angular_damping =
|
||||
m_maximum_speed = m_brake_force = m_gravity_center_shift = m_suspension_rest =
|
||||
m_max_speed_reverse_ratio = -99.9f;
|
||||
m_max_speed_reverse_ratio = m_explosion_impulse = -99.9f;
|
||||
|
||||
m_air_res_reduce[0] = 1.0f;
|
||||
} // init_defaults
|
||||
@ -146,6 +164,7 @@ void STKConfig::getAllData(const lisp::Lisp* lisp)
|
||||
lisp->get("bomb-time", m_bomb_time );
|
||||
lisp->get("bomb-time-increase", m_bomb_time_increase );
|
||||
lisp->get("anvil-time", m_anvil_time );
|
||||
lisp->get("explosion-impulse", m_explosion_impulse );
|
||||
|
||||
// Get the default KartProperties
|
||||
// ------------------------------
|
||||
|
@ -42,6 +42,7 @@ public:
|
||||
float m_max_road_distance; // max distance from road to be still ON road
|
||||
float m_shortcut_segments; // skipping more than this number of segments is
|
||||
// considered to be a shortcut
|
||||
float m_explosion_impulse; // impulse affecting each non-hit kart
|
||||
|
||||
STKConfig() : KartProperties() {};
|
||||
void init_defaults ();
|
||||
|
Loading…
Reference in New Issue
Block a user