Worked around a potential linux audio bug: on one machine
the sfx manager kept on reporting that it was playing (the track intro sound), while it wasn't. That resulted in STK hanging (not reaching the 'ready set go' phase). git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/trunk@9192 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
parent
f17d1ad69b
commit
c9830eac8c
@ -103,9 +103,6 @@ void WorldStatus::enterRaceOverState()
|
|||||||
*/
|
*/
|
||||||
void WorldStatus::terminateRace()
|
void WorldStatus::terminateRace()
|
||||||
{
|
{
|
||||||
// FIXME JH: this is not necessary anymore,
|
|
||||||
// since registering the gui with the state manager
|
|
||||||
// does the same. pause(RESULT_DISPLAY_PHASE);
|
|
||||||
if(network_manager->getMode()==NetworkManager::NW_SERVER)
|
if(network_manager->getMode()==NetworkManager::NW_SERVER)
|
||||||
network_manager->sendRaceResults();
|
network_manager->sendRaceResults();
|
||||||
} // terminateRace
|
} // terminateRace
|
||||||
@ -130,8 +127,17 @@ void WorldStatus::update(const float dt)
|
|||||||
m_track_intro_sound->play();
|
m_track_intro_sound->play();
|
||||||
return;
|
return;
|
||||||
case TRACK_INTRO_PHASE:
|
case TRACK_INTRO_PHASE:
|
||||||
if(m_track_intro_sound->getStatus()==SFXManager::SFX_PLAYING)
|
m_auxiliary_timer += dt;
|
||||||
|
// Work around a bug that occurred on linux once:
|
||||||
|
// the sfx_manager kept on reporting that it is playing,
|
||||||
|
// while it was not - so STK would never reach the ready
|
||||||
|
// ... phase. Since the sound effect is about 3 seconds
|
||||||
|
// long, we use the aux timer to force the next phase
|
||||||
|
// after 3.5 seconds.
|
||||||
|
if(m_track_intro_sound->getStatus()==SFXManager::SFX_PLAYING
|
||||||
|
&& m_auxiliary_timer<3.5f)
|
||||||
return;
|
return;
|
||||||
|
m_auxiliary_timer = 0.0f;
|
||||||
m_prestart_sound->play();
|
m_prestart_sound->play();
|
||||||
m_phase = READY_PHASE;
|
m_phase = READY_PHASE;
|
||||||
for(unsigned int i=0; i<World::getWorld()->getNumKarts(); i++)
|
for(unsigned int i=0; i<World::getWorld()->getNumKarts(); i++)
|
||||||
|
Loading…
Reference in New Issue
Block a user