Apply updated version of Termina1's patch, thanks\!

git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/trunk@9958 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
auria 2011-10-08 20:50:07 +00:00
parent 823d7ca94e
commit 0fa8d27eff
2 changed files with 43 additions and 43 deletions

View File

@ -64,35 +64,6 @@ void RaceResultGUI::init()
music_manager->stopMusic(); music_manager->stopMusic();
m_finish_sound = sfx_manager->quickSound("race_finish"); m_finish_sound = sfx_manager->quickSound("race_finish");
if (race_manager->getMajorMode() == RaceManager::MAJOR_MODE_GRAND_PRIX)
{
const std::vector<std::string>& tracks = race_manager->getGrandPrix()->getTracks();
size_t currentTrack = race_manager->getTrackNumber();
for(size_t i=0; i<tracks.size(); i++)
{
Track* track = track_manager->getTrack(tracks[i]);
GUIEngine::IconButtonWidget* m_screenshot_widget = new GUIEngine::IconButtonWidget(GUIEngine::IconButtonWidget::SCALE_MODE_KEEP_CUSTOM_ASPECT_RATIO,
false, false, GUIEngine::IconButtonWidget::ICON_PATH_TYPE_ABSOLUTE);
m_screenshot_widget->setCustomAspectRatio(4.0f / 3.0f);
m_screenshot_widget->m_x = (int)(UserConfigParams::m_width*0.67);
m_screenshot_widget->m_y = (int)(UserConfigParams::m_height*(0.10+i*0.135));
m_screenshot_widget->m_w = (int)(UserConfigParams::m_width*0.17);
m_screenshot_widget->m_h = (int)(UserConfigParams::m_height*0.1275);
m_screenshot_widget->m_properties[GUIEngine::PROP_ICON] = (track != NULL ?
track->getScreenshotFile().c_str() :
file_manager->getDataDir() + "gui/main_help.png");
m_screenshot_widget->m_properties[GUIEngine::PROP_ID] = tracks[i];
if(i <= currentTrack)
m_screenshot_widget->setBadge(GUIEngine::OK_BADGE);
m_screenshot_widget->add();
m_widgets.push_back(m_screenshot_widget);
}
}
} // init } // init
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
@ -124,6 +95,7 @@ void RaceResultGUI::enableAllButtons()
} }
else if (race_manager->getMajorMode() == RaceManager::MAJOR_MODE_GRAND_PRIX) else if (race_manager->getMajorMode() == RaceManager::MAJOR_MODE_GRAND_PRIX)
{ {
enableGPProgress();
// In case of a GP: // In case of a GP:
// ---------------- // ----------------
top->setVisible(false); top->setVisible(false);
@ -361,11 +333,7 @@ void RaceResultGUI::determineTableLayout()
m_table_width += m_width_new_points + m_width_all_points m_table_width += m_width_new_points + m_width_all_points
+ 2 * m_width_column_space; + 2 * m_width_column_space;
m_leftmost_column = table_area->m_x;
if (race_manager->getMajorMode()==RaceManager::MAJOR_MODE_GRAND_PRIX)
m_leftmost_column = table_area->m_x;
else
m_leftmost_column = table_area->m_x + (table_area->m_w - m_table_width)/2;
m_gp_progress_x = (int)(UserConfigParams::m_width*0.65); m_gp_progress_x = (int)(UserConfigParams::m_width*0.65);
} // determineTableLayout } // determineTableLayout
@ -535,7 +503,10 @@ void RaceResultGUI::renderGlobal(float dt)
enableAllButtons(); enableAllButtons();
} }
break; break;
case RR_WAIT_TILL_END: break; case RR_WAIT_TILL_END:
if (race_manager->getMajorMode() == RaceManager::MAJOR_MODE_GRAND_PRIX)
displayGPProgress();
break;
} // switch } // switch
// Second phase: update X and Y positions for the various animations // Second phase: update X and Y positions for the various animations
@ -577,8 +548,6 @@ void RaceResultGUI::renderGlobal(float dt)
break; break;
} // switch } // switch
displayOneEntry((unsigned int)x, (unsigned int)y, i, true); displayOneEntry((unsigned int)x, (unsigned int)y, i, true);
if (race_manager->getMajorMode() == RaceManager::MAJOR_MODE_GRAND_PRIX)
displayGPProgress();
} // for i } // for i
} // renderGlobal } // renderGlobal
@ -724,12 +693,8 @@ void RaceResultGUI::displayOneEntry(unsigned int x, unsigned int y,
{ {
if (m_highscore_player != NULL && ri->m_player == m_highscore_player) if (m_highscore_player != NULL && ri->m_player == m_highscore_player)
{ {
current_x += m_width_all_points + m_width_column_space + 20;
core::recti dest_rect = core::recti(current_x, y, current_x+100, y+10); core::recti dest_rect = core::recti(current_x, y, current_x+100, y+10);
core::stringw message = (m_highscore_rank == 1 ? _("You topped the highscore list!") : _("New highscore!")); core::stringw message = (m_highscore_rank == 1 ? _("You topped the highscore list!") : _("New highscore!"));
GUIEngine::getSmallFont()->draw(message.c_str(), dest_rect, video::SColor(255,255,166,0), GUIEngine::getSmallFont()->draw(message.c_str(), dest_rect, video::SColor(255,255,166,0),
false, false, NULL, true /* ignoreRTL */); false, false, NULL, true /* ignoreRTL */);
@ -759,6 +724,38 @@ void RaceResultGUI::setHighscore(std::string who, StateManager::ActivePlayer* pl
m_highscore_time = time; m_highscore_time = time;
} }
void RaceResultGUI::enableGPProgress()
{
if (race_manager->getMajorMode() == RaceManager::MAJOR_MODE_GRAND_PRIX)
{
const std::vector<std::string>& tracks = race_manager->getGrandPrix()->getTracks();
size_t currentTrack = race_manager->getTrackNumber();
for(size_t i=0; i<tracks.size(); i++)
{
Track* track = track_manager->getTrack(tracks[i]);
GUIEngine::IconButtonWidget* m_screenshot_widget = new GUIEngine::IconButtonWidget(GUIEngine::IconButtonWidget::SCALE_MODE_KEEP_CUSTOM_ASPECT_RATIO,
false, false, GUIEngine::IconButtonWidget::ICON_PATH_TYPE_ABSOLUTE);
m_screenshot_widget->setCustomAspectRatio(4.0f / 3.0f);
m_screenshot_widget->m_x = (int)(UserConfigParams::m_width*0.67);
m_screenshot_widget->m_y = (int)(UserConfigParams::m_height*(0.10+i*0.135));
m_screenshot_widget->m_w = (int)(UserConfigParams::m_width*0.17);
m_screenshot_widget->m_h = (int)(UserConfigParams::m_height*0.1275);
m_screenshot_widget->m_properties[GUIEngine::PROP_ICON] = (track != NULL ?
track->getScreenshotFile().c_str() :
file_manager->getDataDir() + "gui/main_help.png");
m_screenshot_widget->m_properties[GUIEngine::PROP_ID] = tracks[i];
if(i <= currentTrack)
m_screenshot_widget->setBadge(GUIEngine::OK_BADGE);
m_screenshot_widget->add();
m_widgets.push_back(m_screenshot_widget);
}
}
}
void RaceResultGUI::displayGPProgress() void RaceResultGUI::displayGPProgress()
{ {
video::SColor color = video::SColor(255,255,0,0); video::SColor color = video::SColor(255,255,0,0);
@ -773,6 +770,8 @@ void RaceResultGUI::cleanupGPProgress()
const std::vector<std::string>& tracks = race_manager->getGrandPrix()->getTracks(); const std::vector<std::string>& tracks = race_manager->getGrandPrix()->getTracks();
for(size_t i=0; i<tracks.size(); i++) for(size_t i=0; i<tracks.size(); i++)
{ {
m_widgets.remove(getWidget(tracks[i].c_str())); GUIEngine::Widget *trackWidget = getWidget(tracks[i].c_str());
m_widgets.remove(trackWidget);
delete trackWidget;
} }
} }

View File

@ -187,6 +187,7 @@ private:
void determineTableLayout(); void determineTableLayout();
void determineGPLayout(); void determineGPLayout();
void enableAllButtons(); void enableAllButtons();
void enableGPProgress();
void displayGPProgress(); void displayGPProgress();
void cleanupGPProgress(); void cleanupGPProgress();
public: public: