Lap count widget now works
git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/branches/irrlicht@3971 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
parent
390d076e7a
commit
9ad338fde6
@ -46,25 +46,25 @@ TrackInfoDialog::TrackInfoDialog(const std::string& trackIdent, const irr::core:
|
|||||||
|
|
||||||
m_track_ident = trackIdent;
|
m_track_ident = trackIdent;
|
||||||
|
|
||||||
// ---- Lap count spinner
|
// ---- Lap count m_spinner
|
||||||
SpinnerWidget* spinner = new SpinnerWidget();
|
m_spinner = new SpinnerWidget();
|
||||||
spinner->x = m_area.getWidth()/2 - 200;
|
m_spinner->x = m_area.getWidth()/2 - 200;
|
||||||
spinner->y = y2;
|
m_spinner->y = y2;
|
||||||
spinner->w = 400;
|
m_spinner->w = 400;
|
||||||
spinner->h = y3 - y2 - 15;
|
m_spinner->h = y3 - y2 - 15;
|
||||||
spinner->setParent(m_irrlicht_window);
|
m_spinner->setParent(m_irrlicht_window);
|
||||||
|
|
||||||
spinner->m_properties[PROP_MIN_VALUE] = "1";
|
m_spinner->m_properties[PROP_MIN_VALUE] = "1";
|
||||||
spinner->m_properties[PROP_MAX_VALUE] = "99";
|
m_spinner->m_properties[PROP_MAX_VALUE] = "99";
|
||||||
|
|
||||||
//I18N: In the track setup screen (number of laps choice, where %i is the number)
|
//I18N: In the track setup screen (number of laps choice, where %i is the number)
|
||||||
spinner->m_text = _("%i laps");
|
m_spinner->m_text = _("%i laps");
|
||||||
|
|
||||||
m_children.push_back(spinner);
|
m_children.push_back(m_spinner);
|
||||||
spinner->add();
|
m_spinner->add();
|
||||||
spinner->setValue(3);
|
m_spinner->setValue(3);
|
||||||
spinner->getIrrlichtElement()->setTabStop(true);
|
m_spinner->getIrrlichtElement()->setTabStop(true);
|
||||||
spinner->getIrrlichtElement()->setTabGroup(false);
|
m_spinner->getIrrlichtElement()->setTabGroup(false);
|
||||||
|
|
||||||
// ---- Start button
|
// ---- Start button
|
||||||
ButtonWidget* okBtn = new ButtonWidget();
|
ButtonWidget* okBtn = new ButtonWidget();
|
||||||
@ -200,7 +200,7 @@ TrackInfoDialog::TrackInfoDialog(const std::string& trackIdent, const irr::core:
|
|||||||
// ------------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
// FIXME : this probably doesn't belong here
|
// FIXME : this probably doesn't belong here
|
||||||
void startGame(const std::string trackIdent)
|
void startGame(const std::string trackIdent, const int num_laps)
|
||||||
{
|
{
|
||||||
ModalDialog::dismiss();
|
ModalDialog::dismiss();
|
||||||
|
|
||||||
@ -215,7 +215,7 @@ void startGame(const std::string trackIdent)
|
|||||||
StateManager::get()->enterGameState();
|
StateManager::get()->enterGameState();
|
||||||
//race_manager->setDifficulty(RaceManager::RD_HARD);
|
//race_manager->setDifficulty(RaceManager::RD_HARD);
|
||||||
race_manager->setTrack(trackIdent.c_str());
|
race_manager->setTrack(trackIdent.c_str());
|
||||||
race_manager->setNumLaps( 3 );
|
race_manager->setNumLaps( num_laps );
|
||||||
race_manager->setCoinTarget( 0 ); // Might still be set from a previous challenge
|
race_manager->setCoinTarget( 0 ); // Might still be set from a previous challenge
|
||||||
//race_manager->setNumKarts( 1 );
|
//race_manager->setNumKarts( 1 );
|
||||||
network_manager->setupPlayerKartInfo();
|
network_manager->setupPlayerKartInfo();
|
||||||
@ -226,10 +226,15 @@ void startGame(const std::string trackIdent)
|
|||||||
|
|
||||||
void TrackInfoDialog::onEnterPressedInternal()
|
void TrackInfoDialog::onEnterPressedInternal()
|
||||||
{
|
{
|
||||||
startGame(m_track_ident);
|
const int num_laps = m_spinner->getValue();
|
||||||
|
startGame(m_track_ident, num_laps);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TrackInfoDialog::processEvent(std::string& eventSource)
|
void TrackInfoDialog::processEvent(std::string& eventSource)
|
||||||
{
|
{
|
||||||
if (eventSource == "start" ) startGame(m_track_ident);
|
if (eventSource == "start" )
|
||||||
|
{
|
||||||
|
const int num_laps = m_spinner->getValue();
|
||||||
|
startGame(m_track_ident, num_laps);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -29,6 +29,8 @@ class TrackInfoDialog : public GUIEngine::ModalDialog
|
|||||||
{
|
{
|
||||||
std::string m_track_ident;
|
std::string m_track_ident;
|
||||||
|
|
||||||
|
GUIEngine::SpinnerWidget* m_spinner;
|
||||||
|
|
||||||
irr::gui::IGUIImage* m_kart_icons[HIGHSCORE_COUNT];
|
irr::gui::IGUIImage* m_kart_icons[HIGHSCORE_COUNT];
|
||||||
irr::gui::IGUIStaticText* m_highscore_entries[HIGHSCORE_COUNT];
|
irr::gui::IGUIStaticText* m_highscore_entries[HIGHSCORE_COUNT];
|
||||||
public:
|
public:
|
||||||
|
Loading…
Reference in New Issue
Block a user