Add nitro multiplier and revamp parachutes and air friction
This commit is contained in:
parent
be98a6c4c3
commit
1988cfe0be
@ -201,6 +201,8 @@ AbstractCharacteristic::ValueType AbstractCharacteristic::getType(
|
|||||||
return TYPE_FLOAT;
|
return TYPE_FLOAT;
|
||||||
case NITRO_ENGINE_FORCE:
|
case NITRO_ENGINE_FORCE:
|
||||||
return TYPE_FLOAT;
|
return TYPE_FLOAT;
|
||||||
|
case NITRO_ENGINE_MULT:
|
||||||
|
return TYPE_FLOAT;
|
||||||
case NITRO_CONSUMPTION:
|
case NITRO_CONSUMPTION:
|
||||||
return TYPE_FLOAT;
|
return TYPE_FLOAT;
|
||||||
case NITRO_SMALL_CONTAINER:
|
case NITRO_SMALL_CONTAINER:
|
||||||
@ -437,6 +439,8 @@ std::string AbstractCharacteristic::getName(CharacteristicType type)
|
|||||||
return "NITRO_DURATION";
|
return "NITRO_DURATION";
|
||||||
case NITRO_ENGINE_FORCE:
|
case NITRO_ENGINE_FORCE:
|
||||||
return "NITRO_ENGINE_FORCE";
|
return "NITRO_ENGINE_FORCE";
|
||||||
|
case NITRO_ENGINE_MULT:
|
||||||
|
return "NITRO_ENGINE_MULT";
|
||||||
case NITRO_CONSUMPTION:
|
case NITRO_CONSUMPTION:
|
||||||
return "NITRO_CONSUMPTION";
|
return "NITRO_CONSUMPTION";
|
||||||
case NITRO_SMALL_CONTAINER:
|
case NITRO_SMALL_CONTAINER:
|
||||||
@ -1395,6 +1399,18 @@ float AbstractCharacteristic::getNitroEngineForce() const
|
|||||||
return result;
|
return result;
|
||||||
} // getNitroEngineForce
|
} // getNitroEngineForce
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
float AbstractCharacteristic::getNitroEngineMult() const
|
||||||
|
{
|
||||||
|
float result;
|
||||||
|
bool is_set = false;
|
||||||
|
process(NITRO_ENGINE_MULT, &result, &is_set);
|
||||||
|
if (!is_set)
|
||||||
|
Log::fatal("AbstractCharacteristic", "Can't get characteristic %s",
|
||||||
|
getName(NITRO_ENGINE_MULT).c_str());
|
||||||
|
return result;
|
||||||
|
} // getNitroEngineMult
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
float AbstractCharacteristic::getNitroConsumption() const
|
float AbstractCharacteristic::getNitroConsumption() const
|
||||||
{
|
{
|
||||||
|
@ -185,6 +185,7 @@ public:
|
|||||||
// Nitro
|
// Nitro
|
||||||
NITRO_DURATION,
|
NITRO_DURATION,
|
||||||
NITRO_ENGINE_FORCE,
|
NITRO_ENGINE_FORCE,
|
||||||
|
NITRO_ENGINE_MULT,
|
||||||
NITRO_CONSUMPTION,
|
NITRO_CONSUMPTION,
|
||||||
NITRO_SMALL_CONTAINER,
|
NITRO_SMALL_CONTAINER,
|
||||||
NITRO_BIG_CONTAINER,
|
NITRO_BIG_CONTAINER,
|
||||||
@ -354,6 +355,7 @@ public:
|
|||||||
|
|
||||||
float getNitroDuration() const;
|
float getNitroDuration() const;
|
||||||
float getNitroEngineForce() const;
|
float getNitroEngineForce() const;
|
||||||
|
float getNitroEngineMult() const;
|
||||||
float getNitroConsumption() const;
|
float getNitroConsumption() const;
|
||||||
float getNitroSmallContainer() const;
|
float getNitroSmallContainer() const;
|
||||||
float getNitroBigContainer() const;
|
float getNitroBigContainer() const;
|
||||||
|
@ -2545,6 +2545,54 @@ void Kart::updateEngineSFX(float dt)
|
|||||||
}
|
}
|
||||||
} // updateEngineSFX
|
} // updateEngineSFX
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
/** Reduces the engine power according to speed
|
||||||
|
*
|
||||||
|
* TODO : find where the physics already apply a linear force decrease
|
||||||
|
* TODO : While this work fine, it should ideally be in physics
|
||||||
|
* However, the function use some kart properties and parachute
|
||||||
|
* effect needs to be applied, so keep both working if moving
|
||||||
|
* \param engine_power : the engine power on which to apply the decrease
|
||||||
|
*/
|
||||||
|
float Kart::applyAirFriction(float engine_power)
|
||||||
|
{
|
||||||
|
//The physics already do that a certain amount of engine force is needed to keep going
|
||||||
|
//at a given speed (~39,33 engine force = 1 speed for a mass of 350)
|
||||||
|
//But it's either too slow to accelerate to a target speed or makes it
|
||||||
|
//too easy to accelerate farther.
|
||||||
|
//Instead of making increasing gears have enormous power gaps, apply friction
|
||||||
|
|
||||||
|
float mass_factor = m_kart_properties->getMass()/350.0f;
|
||||||
|
float compense_linear_slowdown = 39.33f*getSpeed()*mass_factor;
|
||||||
|
|
||||||
|
engine_power += compense_linear_slowdown;
|
||||||
|
|
||||||
|
// The result will always be a positive number
|
||||||
|
float friction_intensity = fabsf(getSpeed());
|
||||||
|
|
||||||
|
// Not a pure quadratic evolution as it would be too brutal
|
||||||
|
friction_intensity *= sqrt(friction_intensity)*5;
|
||||||
|
|
||||||
|
// Apply parachute physics
|
||||||
|
// Currently, all karts have the same base friction
|
||||||
|
// If this is changed, a compensation needs to be added here
|
||||||
|
if(m_attachment->getType()==Attachment::ATTACH_PARACHUTE)
|
||||||
|
friction_intensity *= m_kart_properties->getParachuteFriction();
|
||||||
|
|
||||||
|
if (friction_intensity < 0.0f) friction_intensity = 0.0f;
|
||||||
|
|
||||||
|
// We substract the friction from the engine power
|
||||||
|
// 1)This is the logical behavior
|
||||||
|
// 2)That way, engine boosts remain useful at high speed
|
||||||
|
// 3)It helps heavier karts, who have an higher engine power
|
||||||
|
|
||||||
|
engine_power-=friction_intensity;
|
||||||
|
|
||||||
|
return engine_power;
|
||||||
|
} //applyAirFriction
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
/** Sets the engine power. It considers the engine specs, items that influence
|
/** Sets the engine power. It considers the engine specs, items that influence
|
||||||
* the available power, and braking/steering.
|
* the available power, and braking/steering.
|
||||||
@ -2554,9 +2602,14 @@ void Kart::updateEnginePowerAndBrakes(int ticks)
|
|||||||
updateNitro(ticks);
|
updateNitro(ticks);
|
||||||
float engine_power = getActualWheelForce();
|
float engine_power = getActualWheelForce();
|
||||||
|
|
||||||
// apply parachute physics if relevant
|
// apply nitro boost if relevant
|
||||||
if(m_attachment->getType()==Attachment::ATTACH_PARACHUTE)
|
if(getSpeedIncreaseTicksLeft(MaxSpeed::MS_INCREASE_NITRO) > 0)
|
||||||
engine_power*=0.2f;
|
{
|
||||||
|
engine_power*= m_kart_properties->getNitroEngineMult();
|
||||||
|
}
|
||||||
|
|
||||||
|
// This also applies parachute physics if relevant
|
||||||
|
engine_power = applyAirFriction(engine_power);
|
||||||
|
|
||||||
// apply bubblegum physics if relevant
|
// apply bubblegum physics if relevant
|
||||||
if (m_bubblegum_ticks > 0)
|
if (m_bubblegum_ticks > 0)
|
||||||
|
@ -265,6 +265,7 @@ protected:
|
|||||||
void updateEngineSFX(float dt);
|
void updateEngineSFX(float dt);
|
||||||
void updateSpeed();
|
void updateSpeed();
|
||||||
void updateNitro(int ticks);
|
void updateNitro(int ticks);
|
||||||
|
float applyAirFriction (float engine_power);
|
||||||
float getActualWheelForce();
|
float getActualWheelForce();
|
||||||
void playCrashSFX(const Material* m, AbstractKart *k);
|
void playCrashSFX(const Material* m, AbstractKart *k);
|
||||||
void loadData(RaceManager::KartType type, bool animatedModel);
|
void loadData(RaceManager::KartType type, bool animatedModel);
|
||||||
|
@ -558,7 +558,7 @@ float KartProperties::getAvgPower() const
|
|||||||
for (unsigned int i = 0; i < gear_power_increase.size(); ++i)
|
for (unsigned int i = 0; i < gear_power_increase.size(); ++i)
|
||||||
sum += gear_power_increase[i] * power;
|
sum += gear_power_increase[i] * power;
|
||||||
return sum / gear_power_increase.size();
|
return sum / gear_power_increase.size();
|
||||||
} // getAvgPower
|
} // getAvgPower
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// Script-generated content generated by tools/create_kart_properties.py getter
|
// Script-generated content generated by tools/create_kart_properties.py getter
|
||||||
@ -1015,6 +1015,12 @@ float KartProperties::getNitroEngineForce() const
|
|||||||
return m_cached_characteristic->getNitroEngineForce();
|
return m_cached_characteristic->getNitroEngineForce();
|
||||||
} // getNitroEngineForce
|
} // getNitroEngineForce
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
float KartProperties::getNitroEngineMult() const
|
||||||
|
{
|
||||||
|
return m_cached_characteristic->getNitroEngineMult();
|
||||||
|
} // getNitroEngineMult
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
float KartProperties::getNitroConsumption() const
|
float KartProperties::getNitroConsumption() const
|
||||||
{
|
{
|
||||||
|
@ -470,6 +470,7 @@ public:
|
|||||||
|
|
||||||
float getNitroDuration() const;
|
float getNitroDuration() const;
|
||||||
float getNitroEngineForce() const;
|
float getNitroEngineForce() const;
|
||||||
|
float getNitroEngineMult() const;
|
||||||
float getNitroConsumption() const;
|
float getNitroConsumption() const;
|
||||||
float getNitroSmallContainer() const;
|
float getNitroSmallContainer() const;
|
||||||
float getNitroBigContainer() const;
|
float getNitroBigContainer() const;
|
||||||
|
@ -545,6 +545,8 @@ void XmlCharacteristic::load(const XMLNode *node)
|
|||||||
&m_values[NITRO_DURATION]);
|
&m_values[NITRO_DURATION]);
|
||||||
sub_node->get("engine-force",
|
sub_node->get("engine-force",
|
||||||
&m_values[NITRO_ENGINE_FORCE]);
|
&m_values[NITRO_ENGINE_FORCE]);
|
||||||
|
sub_node->get("engine-mult",
|
||||||
|
&m_values[NITRO_ENGINE_MULT]);
|
||||||
sub_node->get("consumption",
|
sub_node->get("consumption",
|
||||||
&m_values[NITRO_CONSUMPTION]);
|
&m_values[NITRO_CONSUMPTION]);
|
||||||
sub_node->get("small-container",
|
sub_node->get("small-container",
|
||||||
|
Loading…
Reference in New Issue
Block a user