Fixed #812 - two karts given the same position, which happens in
0-lap races. Fixed by letting overall_distance be negative at start (which should have no other impact - time estimation function is improved to handle this). git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/trunk@12104 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
parent
8c1f9188e6
commit
60529bca5c
@ -161,20 +161,15 @@ void LinearWorld::update(float dt)
|
|||||||
if(kart->getKartAnimation()) continue;
|
if(kart->getKartAnimation()) continue;
|
||||||
|
|
||||||
kart_info.getSector()->update(kart->getXYZ());
|
kart_info.getSector()->update(kart->getXYZ());
|
||||||
if(kart_info.m_race_lap>=0)
|
|
||||||
kart_info.m_overall_distance = kart_info.m_race_lap
|
kart_info.m_overall_distance = kart_info.m_race_lap
|
||||||
* m_track->getTrackLength()
|
* m_track->getTrackLength()
|
||||||
+ getDistanceDownTrackForKart(kart->getWorldKartId());
|
+ getDistanceDownTrackForKart(kart->getWorldKartId());
|
||||||
else
|
|
||||||
kart_info.m_overall_distance = 0;
|
|
||||||
|
|
||||||
} // for n
|
} // for n
|
||||||
|
|
||||||
// Update all positions. This must be done after _all_ karts have
|
// Update all positions. This must be done after _all_ karts have
|
||||||
// updated their position and laps etc, otherwise inconsistencies
|
// updated their position and laps etc, otherwise inconsistencies
|
||||||
// (like two karts at same position) can occur.
|
// (like two karts at same position) can occur.
|
||||||
// ---------------------------------------------------------------
|
// ---------------------------------------------------------------
|
||||||
|
|
||||||
WorldWithRank::updateTrack(dt);
|
WorldWithRank::updateTrack(dt);
|
||||||
updateRacePosition();
|
updateRacePosition();
|
||||||
|
|
||||||
@ -546,7 +541,16 @@ float LinearWorld::estimateFinishTimeForKart(AbstractKart* kart)
|
|||||||
|
|
||||||
// Finish time is the time needed for the whole race with
|
// Finish time is the time needed for the whole race with
|
||||||
// the computed average speed computed.
|
// the computed average speed computed.
|
||||||
const float average_speed = kart_info.m_overall_distance/getTime();
|
float average_speed = getTime()==0
|
||||||
|
? 1.0f
|
||||||
|
: kart_info.m_overall_distance/getTime();
|
||||||
|
|
||||||
|
// Overall distance is negative before the starting line is crossed
|
||||||
|
// for the first time. Unlikely to happen in real races, but will
|
||||||
|
// happen in 0-laps races.
|
||||||
|
if(average_speed<0)
|
||||||
|
average_speed = 1.0f;
|
||||||
|
|
||||||
// Avoid NAN as results when average_speed is low
|
// Avoid NAN as results when average_speed is low
|
||||||
// Instead just set time to 99:59:00
|
// Instead just set time to 99:59:00
|
||||||
if(average_speed<0.1f)
|
if(average_speed<0.1f)
|
||||||
@ -608,7 +612,9 @@ void LinearWorld::moveKartAfterRescue(AbstractKart* kart)
|
|||||||
} // moveKartAfterRescue
|
} // moveKartAfterRescue
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
/** Find the position (rank) of every kart
|
/** Find the position (rank) of every kart. ATM it uses a stable O(n^2)
|
||||||
|
* algorithm by counting for each kart how many other karts are ahead of
|
||||||
|
* it.
|
||||||
*/
|
*/
|
||||||
void LinearWorld::updateRacePosition()
|
void LinearWorld::updateRacePosition()
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user