- If there is 2 or 3 karts in the GP, karts in 2nd and (if any) 3rd place display a sad animation
- If there is 4 karts in the GP, the kart in 3rd displays a sad animation
- If there is 5 karts or more in the GP, all karts on the podium display a happy animation

The first kart in the GP always displays a happy animation even if alone.
This commit is contained in:
Alayan 2023-11-24 17:59:39 +01:00
parent bf88954e31
commit a57ac415bb
No known key found for this signature in database
3 changed files with 51 additions and 12 deletions

View File

@ -985,6 +985,7 @@ void RaceManager::exitRace(bool delete_world)
StateManager::get()->enterGameState(); StateManager::get()->enterGameState();
setMinorMode(RaceManager::MINOR_MODE_CUTSCENE); setMinorMode(RaceManager::MINOR_MODE_CUTSCENE);
int num_gp_karts = m_num_karts;
setNumKarts(0); setNumKarts(0);
setNumPlayers(0); setNumPlayers(0);
@ -995,6 +996,7 @@ void RaceManager::exitRace(bool delete_world)
raceWasStartedFromOverworld()); raceWasStartedFromOverworld());
GrandPrixWin* scene = GrandPrixWin::getInstance(); GrandPrixWin* scene = GrandPrixWin::getInstance();
scene->push(); scene->push();
scene->setNumGPKarts(num_gp_karts); // This must be set before we set karts
scene->setKarts(winners); scene->setKarts(winners);
scene->setPlayerWon(some_human_player_won); scene->setPlayerWon(some_human_player_won);
std::set<std::string> karts; std::set<std::string> karts;
@ -1024,6 +1026,7 @@ void RaceManager::exitRace(bool delete_world)
scene->setKarts(karts); scene->setKarts(karts);
} }
} }
kart_properties_manager->onDemandLoadKartTextures(used_karts); kart_properties_manager->onDemandLoadKartTextures(used_karts);
} }
@ -1118,6 +1121,7 @@ void RaceManager::startGP(const GrandPrixData &gp, bool from_overworld,
* \param trackIdent Internal name of the track to race on * \param trackIdent Internal name of the track to race on
* \param num_laps Number of laps to race, or -1 if number of laps is * \param num_laps Number of laps to race, or -1 if number of laps is
* not relevant in current mode * not relevant in current mode
* \param from_overworld If it was started from the Story Mode overworld
*/ */
void RaceManager::startSingleRace(const std::string &track_ident, void RaceManager::startSingleRace(const std::string &track_ident,
const int num_laps, const int num_laps,

View File

@ -119,6 +119,7 @@ GrandPrixWin::GrandPrixWin() : GrandPrixCutscene("grand_prix_win.stkgui")
m_podium_steps[i] = NULL; m_podium_steps[i] = NULL;
} }
m_player_won = false; m_player_won = false;
m_num_gp_karts = 0;
} // GrandPrixWin } // GrandPrixWin
// ------------------------------------------------------------------------------------- // -------------------------------------------------------------------------------------
@ -329,6 +330,13 @@ void GrandPrixWin::onUpdate(float dt)
} // onUpdate } // onUpdate
// -------------------------------------------------------------------------------------
void GrandPrixWin::setNumGPKarts(int num_gp_karts)
{
m_num_gp_karts = num_gp_karts;
}
// ------------------------------------------------------------------------------------- // -------------------------------------------------------------------------------------
void GrandPrixWin::setKarts(const std::pair<std::string, float> idents_arg[3]) void GrandPrixWin::setKarts(const std::pair<std::string, float> idents_arg[3])
@ -356,18 +364,41 @@ void GrandPrixWin::setKarts(const std::pair<std::string, float> idents_arg[3])
// Lod node has to be animated // Lod node has to be animated
auto* a_node = static_cast<scene::IAnimatedMeshSceneNode*> auto* a_node = static_cast<scene::IAnimatedMeshSceneNode*>
(lnode->getAllNodes()[0]); (lnode->getAllNodes()[0]);
const unsigned start_frame =
kart_model->getFrame(KartModel::AF_WIN_LOOP_START) > -1 ? // If the kart is not 1st (after the reorder, the id of the winner is 1, not 0)
kart_model->getFrame(KartModel::AF_WIN_LOOP_START) : // and there are very few karts in the GP, display a sad animation rather than
kart_model->getFrame(KartModel::AF_WIN_START) > -1 ? // a happy animation
kart_model->getFrame(KartModel::AF_WIN_START) : if ((i == 0 && m_num_gp_karts <= 3) ||
kart_model->getFrame(KartModel::AF_STRAIGHT); (i == 2 && m_num_gp_karts <= 4))
const unsigned end_frame = {
kart_model->getFrame(KartModel::AF_WIN_END) > -1 ? const unsigned start_frame =
kart_model->getFrame(KartModel::AF_WIN_END) : kart_model->getFrame(KartModel::AF_LOSE_LOOP_START) > -1 ?
kart_model->getFrame(KartModel::AF_STRAIGHT); kart_model->getFrame(KartModel::AF_LOSE_LOOP_START) :
a_node->setLoopMode(true); kart_model->getFrame(KartModel::AF_LOSE_START) > -1 ?
a_node->setFrameLoop(start_frame, end_frame); kart_model->getFrame(KartModel::AF_LOSE_START) :
kart_model->getFrame(KartModel::AF_STRAIGHT);
const unsigned end_frame =
kart_model->getFrame(KartModel::AF_LOSE_END) > -1 ?
kart_model->getFrame(KartModel::AF_LOSE_END) :
kart_model->getFrame(KartModel::AF_STRAIGHT);
a_node->setLoopMode(true);
a_node->setFrameLoop(start_frame, end_frame);
}
else // Standard happy animations
{
const unsigned start_frame =
kart_model->getFrame(KartModel::AF_WIN_LOOP_START) > -1 ?
kart_model->getFrame(KartModel::AF_WIN_LOOP_START) :
kart_model->getFrame(KartModel::AF_WIN_START) > -1 ?
kart_model->getFrame(KartModel::AF_WIN_START) :
kart_model->getFrame(KartModel::AF_STRAIGHT);
const unsigned end_frame =
kart_model->getFrame(KartModel::AF_WIN_END) > -1 ?
kart_model->getFrame(KartModel::AF_WIN_END) :
kart_model->getFrame(KartModel::AF_STRAIGHT);
a_node->setLoopMode(true);
a_node->setFrameLoop(start_frame, end_frame);
}
} }
m_kart_x[i] = KARTS_INITIAL_X[i]; m_kart_x[i] = KARTS_INITIAL_X[i];

View File

@ -58,6 +58,9 @@ class GrandPrixWin :
int m_phase; int m_phase;
/** Used to pick the happy/sad animations of karts */
int m_num_gp_karts;
float m_kart_x[3], m_kart_y[3], m_kart_z[3]; float m_kart_x[3], m_kart_y[3], m_kart_z[3];
float m_kart_rotation[3]; float m_kart_rotation[3];
@ -75,6 +78,7 @@ public:
MusicInformation* getInGameMenuMusic() const OVERRIDE; MusicInformation* getInGameMenuMusic() const OVERRIDE;
/** \pre must be called after pushing the screen, but before onUpdate had the chance to be invoked */ /** \pre must be called after pushing the screen, but before onUpdate had the chance to be invoked */
void setNumGPKarts(int num_gp_karts);
void setKarts(const std::pair<std::string, float> karts[3]); void setKarts(const std::pair<std::string, float> karts[3]);
void setPlayerWon(bool some_player_won) { m_player_won = some_player_won; } void setPlayerWon(bool some_player_won) { m_player_won = some_player_won; }
}; };