Modified Soccer Mode results screen.
git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/trunk@14249 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
parent
671f4d7441
commit
70ef7966e1
@ -54,6 +54,7 @@ void SoccerWorld::init()
|
|||||||
WorldWithRank::init();
|
WorldWithRank::init();
|
||||||
m_display_rank = false;
|
m_display_rank = false;
|
||||||
m_goal_timer = 0.f;
|
m_goal_timer = 0.f;
|
||||||
|
m_lastKartToHitBall = -1;
|
||||||
|
|
||||||
// check for possible problems if AI karts were incorrectly added
|
// check for possible problems if AI karts were incorrectly added
|
||||||
if(getNumKarts() > race_manager->getNumPlayers())
|
if(getNumKarts() > race_manager->getNumPlayers())
|
||||||
@ -62,7 +63,6 @@ void SoccerWorld::init()
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
m_goal_target = race_manager->getMaxGoal();
|
m_goal_target = race_manager->getMaxGoal();
|
||||||
printf("Max Goal: %d\n", m_goal_target);
|
|
||||||
m_goal_sound = sfx_manager->createSoundSource("goal_scored");
|
m_goal_sound = sfx_manager->createSoundSource("goal_scored");
|
||||||
|
|
||||||
} // init
|
} // init
|
||||||
@ -80,7 +80,11 @@ void SoccerWorld::reset()
|
|||||||
// Reset original positions for the soccer balls
|
// Reset original positions for the soccer balls
|
||||||
TrackObjectManager* tom = getTrack()->getTrackObjectManager();
|
TrackObjectManager* tom = getTrack()->getTrackObjectManager();
|
||||||
assert(tom);
|
assert(tom);
|
||||||
|
m_redScorers.clear();
|
||||||
|
m_redScoreTimes.clear();
|
||||||
|
m_blueScorers.clear();
|
||||||
|
m_blueScoreTimes.clear();
|
||||||
|
m_lastKartToHitBall = -1;
|
||||||
PtrVector<TrackObject>& objects = tom->getObjects();
|
PtrVector<TrackObject>& objects = tom->getObjects();
|
||||||
for(int i=0; i<objects.size(); i++)
|
for(int i=0; i<objects.size(); i++)
|
||||||
{
|
{
|
||||||
@ -143,6 +147,17 @@ void SoccerWorld::onCheckGoalTriggered(bool first_goal)
|
|||||||
World *world = World::getWorld();
|
World *world = World::getWorld();
|
||||||
world->setPhase(WorldStatus::GOAL_PHASE);
|
world->setPhase(WorldStatus::GOAL_PHASE);
|
||||||
m_goal_sound->play();
|
m_goal_sound->play();
|
||||||
|
if(m_lastKartToHitBall != -1)
|
||||||
|
{
|
||||||
|
if(first_goal){
|
||||||
|
m_redScorers.push_back(m_lastKartToHitBall);
|
||||||
|
m_redScoreTimes.push_back(world->getTime());
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
m_blueScorers.push_back(m_lastKartToHitBall);
|
||||||
|
m_blueScoreTimes.push_back(world->getTime());
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//m_check_goals_enabled = false; // TODO: remove?
|
//m_check_goals_enabled = false; // TODO: remove?
|
||||||
@ -178,6 +193,13 @@ void SoccerWorld::onCheckGoalTriggered(bool first_goal)
|
|||||||
// TODO: rescue the karts
|
// TODO: rescue the karts
|
||||||
} // onCheckGoalTriggered
|
} // onCheckGoalTriggered
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
/** Sets the last kart that hit the ball, to be able to
|
||||||
|
* identify the scorer later.
|
||||||
|
*/
|
||||||
|
void SoccerWorld::setLastKartTohitBall(unsigned int kartId){
|
||||||
|
m_lastKartToHitBall = kartId;
|
||||||
|
}
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
/** The battle is over if only one kart is left, or no player kart.
|
/** The battle is over if only one kart is left, or no player kart.
|
||||||
*/
|
*/
|
||||||
|
@ -51,7 +51,11 @@ private:
|
|||||||
SFXBase *m_goal_sound;
|
SFXBase *m_goal_sound;
|
||||||
/** Timer for displaying goal text*/
|
/** Timer for displaying goal text*/
|
||||||
float m_goal_timer;
|
float m_goal_timer;
|
||||||
|
int m_lastKartToHitBall;
|
||||||
|
std::vector<int> m_redScorers;
|
||||||
|
std::vector<float> m_redScoreTimes;
|
||||||
|
std::vector<int> m_blueScorers;
|
||||||
|
std::vector<float> m_blueScoreTimes;
|
||||||
public:
|
public:
|
||||||
|
|
||||||
SoccerWorld();
|
SoccerWorld();
|
||||||
@ -79,6 +83,21 @@ public:
|
|||||||
|
|
||||||
void onCheckGoalTriggered(bool first_goal);
|
void onCheckGoalTriggered(bool first_goal);
|
||||||
int getTeamLeader(unsigned int i);
|
int getTeamLeader(unsigned int i);
|
||||||
|
void setLastKartTohitBall(unsigned int kartId);
|
||||||
|
std::vector<int> getScorers(unsigned int team)
|
||||||
|
{
|
||||||
|
if(team == 0)
|
||||||
|
return m_redScorers;
|
||||||
|
else if(team == 1)
|
||||||
|
return m_blueScorers;
|
||||||
|
}
|
||||||
|
std::vector<float> getScoreTimes(unsigned int team)
|
||||||
|
{
|
||||||
|
if(team == 0)
|
||||||
|
return m_redScoreTimes;
|
||||||
|
else if(team == 1)
|
||||||
|
return m_blueScoreTimes;
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void initKartList();
|
void initKartList();
|
||||||
|
@ -528,6 +528,11 @@ void PhysicalObject::handleExplosion(const Vec3& pos, bool direct_hit)
|
|||||||
|
|
||||||
} // handleExplosion
|
} // handleExplosion
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
bool PhysicalObject::isSoccerBall()
|
||||||
|
{
|
||||||
|
return m_object->isSoccerBall();
|
||||||
|
}
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
/* EOF */
|
/* EOF */
|
||||||
|
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
#include "utils/vec3.hpp"
|
#include "utils/vec3.hpp"
|
||||||
#include "utils/leak_check.hpp"
|
#include "utils/leak_check.hpp"
|
||||||
|
|
||||||
|
|
||||||
class XMLNode;
|
class XMLNode;
|
||||||
class TrackObject;
|
class TrackObject;
|
||||||
|
|
||||||
@ -138,6 +139,7 @@ public:
|
|||||||
virtual void handleExplosion(const Vec3& pos, bool directHit);
|
virtual void handleExplosion(const Vec3& pos, bool directHit);
|
||||||
void update (float dt);
|
void update (float dt);
|
||||||
void init ();
|
void init ();
|
||||||
|
bool isSoccerBall();
|
||||||
|
|
||||||
// ------------------------------------------------------------------------
|
// ------------------------------------------------------------------------
|
||||||
/** Returns the rigid body of this physical object. */
|
/** Returns the rigid body of this physical object. */
|
||||||
|
@ -32,6 +32,7 @@
|
|||||||
#include "physics/stk_dynamics_world.hpp"
|
#include "physics/stk_dynamics_world.hpp"
|
||||||
#include "physics/triangle_mesh.hpp"
|
#include "physics/triangle_mesh.hpp"
|
||||||
#include "tracks/track.hpp"
|
#include "tracks/track.hpp"
|
||||||
|
#include "modes/soccer_world.hpp"
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
/** Initialise physics.
|
/** Initialise physics.
|
||||||
@ -188,6 +189,12 @@ void Physics::update(float dt)
|
|||||||
const KartProperties* kp = kart->getKartProperties();
|
const KartProperties* kp = kart->getKartProperties();
|
||||||
kart->setSquash(kp->getSquashDuration(), kp->getSquashSlowdown());
|
kart->setSquash(kp->getSquashDuration(), kp->getSquashSlowdown());
|
||||||
}
|
}
|
||||||
|
else if(obj->isSoccerBall())
|
||||||
|
{
|
||||||
|
int kartId = p->getUserPointer(1)->getPointerKart()->getWorldKartId();
|
||||||
|
SoccerWorld* soccerWorld = (SoccerWorld*)World::getWorld();
|
||||||
|
soccerWorld->setLastKartTohitBall(kartId);
|
||||||
|
}
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -298,14 +298,6 @@ void RaceResultGUI::onConfirm()
|
|||||||
*/
|
*/
|
||||||
void RaceResultGUI::determineTableLayout()
|
void RaceResultGUI::determineTableLayout()
|
||||||
{
|
{
|
||||||
if (race_manager->getMinorMode() == RaceManager::MINOR_MODE_SOCCER)
|
|
||||||
{
|
|
||||||
redTeamTexture = irr_driver->getTexture(
|
|
||||||
file_manager->getTextureFile("soccer_ball_red.png"));
|
|
||||||
blueTeamTexture = irr_driver->getTexture(
|
|
||||||
file_manager->getTextureFile("soccer_ball_blue.png"));
|
|
||||||
}
|
|
||||||
|
|
||||||
GUIEngine::Widget *table_area = getWidget("result-table");
|
GUIEngine::Widget *table_area = getWidget("result-table");
|
||||||
|
|
||||||
m_font = GUIEngine::getFont();
|
m_font = GUIEngine::getFont();
|
||||||
@ -520,6 +512,8 @@ void RaceResultGUI::onUpdate(float dt, irr::video::IVideoDriver*)
|
|||||||
*/
|
*/
|
||||||
void RaceResultGUI::renderGlobal(float dt)
|
void RaceResultGUI::renderGlobal(float dt)
|
||||||
{
|
{
|
||||||
|
bool isSoccerWorld = race_manager->getMinorMode() == RaceManager::MINOR_MODE_SOCCER;
|
||||||
|
|
||||||
m_timer += dt;
|
m_timer += dt;
|
||||||
assert(World::getWorld()->getPhase()==WorldStatus::RESULT_DISPLAY_PHASE);
|
assert(World::getWorld()->getPhase()==WorldStatus::RESULT_DISPLAY_PHASE);
|
||||||
unsigned int num_karts = m_all_row_infos.size();
|
unsigned int num_karts = m_all_row_infos.size();
|
||||||
@ -666,6 +660,9 @@ void RaceResultGUI::renderGlobal(float dt)
|
|||||||
case RR_WAIT_TILL_END:
|
case RR_WAIT_TILL_END:
|
||||||
break;
|
break;
|
||||||
} // switch
|
} // switch
|
||||||
|
if(isSoccerWorld)
|
||||||
|
displaySoccerResults();
|
||||||
|
else
|
||||||
displayOneEntry((unsigned int)x, (unsigned int)y, i, true);
|
displayOneEntry((unsigned int)x, (unsigned int)y, i, true);
|
||||||
} // for i
|
} // for i
|
||||||
|
|
||||||
@ -744,12 +741,6 @@ void RaceResultGUI::determineGPLayout()
|
|||||||
void RaceResultGUI::displayOneEntry(unsigned int x, unsigned int y,
|
void RaceResultGUI::displayOneEntry(unsigned int x, unsigned int y,
|
||||||
unsigned int n, bool display_points)
|
unsigned int n, bool display_points)
|
||||||
{
|
{
|
||||||
SoccerWorld* soccerWorld = (SoccerWorld*)World::getWorld();
|
|
||||||
bool isSoccerMode = race_manager->getMinorMode() == RaceManager::MINOR_MODE_SOCCER;
|
|
||||||
int m_team_goals[2] = {soccerWorld->getScore(0), soccerWorld->getScore(1)};
|
|
||||||
|
|
||||||
if (isSoccerMode && n > 0) return;
|
|
||||||
|
|
||||||
RowInfo *ri = &(m_all_row_infos[n]);
|
RowInfo *ri = &(m_all_row_infos[n]);
|
||||||
video::SColor color = ri->m_is_player_kart
|
video::SColor color = ri->m_is_player_kart
|
||||||
? video::SColor(255,255,0, 0 )
|
? video::SColor(255,255,0, 0 )
|
||||||
@ -770,8 +761,6 @@ void RaceResultGUI::displayOneEntry(unsigned int x, unsigned int y,
|
|||||||
|
|
||||||
// First draw the icon
|
// First draw the icon
|
||||||
// -------------------
|
// -------------------
|
||||||
if (!isSoccerMode)
|
|
||||||
{
|
|
||||||
if(ri->m_kart_icon)
|
if(ri->m_kart_icon)
|
||||||
{
|
{
|
||||||
core::recti source_rect(core::vector2di(0,0),
|
core::recti source_rect(core::vector2di(0,0),
|
||||||
@ -784,58 +773,16 @@ void RaceResultGUI::displayOneEntry(unsigned int x, unsigned int y,
|
|||||||
}
|
}
|
||||||
|
|
||||||
current_x += m_width_icon + m_width_column_space;
|
current_x += m_width_icon + m_width_column_space;
|
||||||
}
|
|
||||||
|
|
||||||
// Draw the name
|
// Draw the name
|
||||||
// -------------
|
// -------------
|
||||||
if (!isSoccerMode)
|
|
||||||
{
|
|
||||||
core::recti pos_name(current_x, y,
|
core::recti pos_name(current_x, y,
|
||||||
UserConfigParams::m_width, y+m_distance_between_rows);
|
UserConfigParams::m_width, y+m_distance_between_rows);
|
||||||
m_font->draw(ri->m_kart_name, pos_name, color, false, false, NULL,
|
m_font->draw(ri->m_kart_name, pos_name, color, false, false, NULL,
|
||||||
true /* ignoreRTL */);
|
true /* ignoreRTL */);
|
||||||
current_x += m_width_kart_name + m_width_column_space;
|
current_x += m_width_kart_name + m_width_column_space;
|
||||||
}
|
|
||||||
|
|
||||||
// Draw icon, name of team which won in soccer mode and score
|
|
||||||
// ----------------------------------------------------------
|
|
||||||
if (isSoccerMode)
|
|
||||||
{
|
|
||||||
core::stringw text;
|
|
||||||
irr::video::ITexture *team_icon;
|
|
||||||
if (m_team_goals[0] > m_team_goals[1])
|
|
||||||
{
|
|
||||||
text = core::stringw(_("Red team won"));
|
|
||||||
team_icon = redTeamTexture;
|
|
||||||
}
|
|
||||||
else if (m_team_goals[0] < m_team_goals[1])
|
|
||||||
{
|
|
||||||
text = core::stringw(_("Blue team won"));
|
|
||||||
team_icon = blueTeamTexture;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
text = core::stringw(_("Draw"));
|
|
||||||
|
|
||||||
core::recti source_rect(core::vector2di(0,0), team_icon->getSize());
|
|
||||||
core::recti dest_rect(current_x, y, current_x+m_width_icon, y+m_width_icon);
|
|
||||||
irr_driver->getVideoDriver()->draw2DImage(team_icon, dest_rect,
|
|
||||||
source_rect, NULL, NULL,
|
|
||||||
true);
|
|
||||||
|
|
||||||
current_x += m_width_icon + m_width_column_space;
|
|
||||||
core::recti pos_name(current_x, y,
|
|
||||||
UserConfigParams::m_width, y+m_distance_between_rows);
|
|
||||||
|
|
||||||
m_font->draw(text, pos_name, color, false, false, NULL, true /* ignoreRTL */);
|
|
||||||
core::dimension2du rect = m_font->getDimension(text.c_str());
|
|
||||||
current_x += rect.Width + 2*m_width_column_space;
|
|
||||||
|
|
||||||
text = core::stringw(m_team_goals[0]) + " : " + core::stringw(m_team_goals[1]);
|
|
||||||
dest_rect = core::recti(current_x, y, current_x+100, y+10);
|
|
||||||
m_font->draw(text, dest_rect, color, false, false, NULL, true /* ignoreRTL */);
|
|
||||||
rect = m_font->getDimension(text.c_str());
|
|
||||||
current_x += rect.Width + 2*m_width_column_space;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Draw the time except in FTL mode
|
// Draw the time except in FTL mode
|
||||||
// --------------------------------
|
// --------------------------------
|
||||||
@ -882,6 +829,124 @@ void RaceResultGUI::displayOneEntry(unsigned int x, unsigned int y,
|
|||||||
}
|
}
|
||||||
} // displayOneEntry
|
} // displayOneEntry
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void RaceResultGUI::displaySoccerResults()
|
||||||
|
{
|
||||||
|
|
||||||
|
//Draw win text
|
||||||
|
core::stringw resultText;
|
||||||
|
static video::SColor color;
|
||||||
|
gui::IGUIFont* font = GUIEngine::getTitleFont();
|
||||||
|
float currX = UserConfigParams::m_width/2;
|
||||||
|
RowInfo *ri = &(m_all_row_infos[0]);
|
||||||
|
float currY = ri->m_y_pos;
|
||||||
|
SoccerWorld* soccerWorld = (SoccerWorld*)World::getWorld();
|
||||||
|
int teamScore[2] = {soccerWorld->getScore(0), soccerWorld->getScore(1)};
|
||||||
|
|
||||||
|
if(teamScore[0] > teamScore[1])
|
||||||
|
{
|
||||||
|
resultText = _("Red Team Wins");
|
||||||
|
color = video::SColor(255, 255, 0, 0);
|
||||||
|
}
|
||||||
|
else if(teamScore[1] > teamScore[0])
|
||||||
|
{
|
||||||
|
resultText = _("Blue Team Wins");
|
||||||
|
color = video::SColor(255,0,0,255);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
resultText = _("It's a draw");
|
||||||
|
color = video::SColor(255, 255, 255, 255);
|
||||||
|
}
|
||||||
|
|
||||||
|
core::rect<s32> pos(currX, currY, currX, currY);
|
||||||
|
font->draw(resultText.c_str(), pos, color, true, true);
|
||||||
|
|
||||||
|
//Draw team scores:
|
||||||
|
currY += 20;
|
||||||
|
currX /= 2;
|
||||||
|
irr::video::ITexture* redTeamIcon = irr_driver->getTexture(
|
||||||
|
file_manager->getTextureFile("soccer_ball_red.png"));
|
||||||
|
irr::video::ITexture* blueTeamIcon = irr_driver->getTexture(
|
||||||
|
file_manager->getTextureFile("soccer_ball_blue.png"));
|
||||||
|
|
||||||
|
core::recti sourceRect(core::vector2di(0,0), redTeamIcon->getSize());
|
||||||
|
core::recti destRect(currX, currY, currX+redTeamIcon->getSize().Width/2,
|
||||||
|
currY+redTeamIcon->getSize().Height/2);
|
||||||
|
irr_driver->getVideoDriver()->draw2DImage(redTeamIcon, destRect,sourceRect,
|
||||||
|
NULL,NULL, true);
|
||||||
|
currX += UserConfigParams::m_width/2 - redTeamIcon->getSize().Width/2;
|
||||||
|
destRect = core::recti(currX, currY, currX+redTeamIcon->getSize().Width/2,
|
||||||
|
currY+redTeamIcon->getSize().Height/2);
|
||||||
|
irr_driver->getVideoDriver()->draw2DImage(blueTeamIcon,destRect,sourceRect,
|
||||||
|
NULL, NULL, true);
|
||||||
|
|
||||||
|
currX += redTeamIcon->getSize().Width/4;
|
||||||
|
currY += 10 + redTeamIcon->getSize().Height/2;
|
||||||
|
resultText = StringUtils::toWString(teamScore[1]);
|
||||||
|
pos = core::rect<s32>(currX, currY, currX, currY);
|
||||||
|
color = video::SColor(255,255,255,255);
|
||||||
|
font->draw(resultText.c_str(), pos, color, true, false);
|
||||||
|
|
||||||
|
currX -= UserConfigParams::m_width/2 - redTeamIcon->getSize().Width/2;
|
||||||
|
resultText = StringUtils::toWString(teamScore[0]);
|
||||||
|
pos = core::rect<s32>(currX,currY,currX,currY);
|
||||||
|
font->draw(resultText.c_str(), pos, color, true, false);
|
||||||
|
|
||||||
|
resultText = "-";
|
||||||
|
float centerX = UserConfigParams::m_width/2;
|
||||||
|
pos = core::rect<s32>(centerX, currY, centerX, currY);
|
||||||
|
font->draw(resultText.c_str(), pos, color, true, false);
|
||||||
|
|
||||||
|
//Draw goal scorers:
|
||||||
|
//The red scorers:
|
||||||
|
currY += 50;
|
||||||
|
font = GUIEngine::getSmallFont();
|
||||||
|
std::vector<int> scorers = soccerWorld->getScorers(0);
|
||||||
|
std::vector<float> scoreTimes = soccerWorld->getScoreTimes(0);
|
||||||
|
irr::video::ITexture* scorerIcon;
|
||||||
|
|
||||||
|
for(int i=0; i<scorers.size(); i++)
|
||||||
|
{
|
||||||
|
std::string kartName = race_manager->getKartIdent(scorers.at(i)).c_str();
|
||||||
|
resultText = kartName.c_str();
|
||||||
|
resultText.append(" ");
|
||||||
|
resultText.append(StringUtils::timeToString(scoreTimes.at(i)).c_str());
|
||||||
|
pos = core::rect<s32>(currX,currY,currX,currY);
|
||||||
|
font->draw(resultText,pos, color, true, false);
|
||||||
|
std::string path = "../karts/" + kartName + "/" + kartName + "icon.png";
|
||||||
|
scorerIcon = irr_driver->getTexture(file_manager->getTextureFile(path));
|
||||||
|
sourceRect = core::recti(core::vector2di(0,0), scorerIcon->getSize());
|
||||||
|
destRect = core::recti(currX-95, currY-5, currX - 65, currY+ 25);
|
||||||
|
irr_driver->getVideoDriver()->draw2DImage(scorerIcon, destRect, sourceRect,
|
||||||
|
NULL, NULL, true);
|
||||||
|
currY += 30;
|
||||||
|
}
|
||||||
|
|
||||||
|
//The blue scorers:
|
||||||
|
currY -= 30*scorers.size();
|
||||||
|
currX += UserConfigParams::m_width/2 - redTeamIcon->getSize().Width/2;
|
||||||
|
scorers = soccerWorld->getScorers(1);
|
||||||
|
scoreTimes = soccerWorld->getScoreTimes(1);
|
||||||
|
for(int i=0; i<scorers.size(); i++)
|
||||||
|
{
|
||||||
|
std::string kartName = race_manager->getKartIdent(scorers.at(i)).c_str();
|
||||||
|
resultText = kartName.c_str();
|
||||||
|
resultText.append(" ");
|
||||||
|
resultText.append(StringUtils::timeToString(scoreTimes.at(i)).c_str());
|
||||||
|
pos = core::rect<s32>(currX,currY,currX,currY);
|
||||||
|
font->draw(resultText,pos, color, true, false);
|
||||||
|
|
||||||
|
std::string path = "../karts/" + kartName + "/" + kartName + "icon.png";
|
||||||
|
scorerIcon = irr_driver->getTexture(file_manager->getTextureFile(path));
|
||||||
|
sourceRect = core::recti(core::vector2di(0,0), scorerIcon->getSize());
|
||||||
|
destRect = core::recti(currX-95, currY-5, currX - 65, currY+ 25);
|
||||||
|
irr_driver->getVideoDriver()->draw2DImage(scorerIcon, destRect, sourceRect,
|
||||||
|
NULL, NULL, true);
|
||||||
|
currY += 30;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
void RaceResultGUI::clearHighscores()
|
void RaceResultGUI::clearHighscores()
|
||||||
|
@ -198,6 +198,7 @@ private:
|
|||||||
void displayGPProgress();
|
void displayGPProgress();
|
||||||
void cleanupGPProgress();
|
void cleanupGPProgress();
|
||||||
void displayHighScores();
|
void displayHighScores();
|
||||||
|
void displaySoccerResults();
|
||||||
public:
|
public:
|
||||||
|
|
||||||
RaceResultGUI();
|
RaceResultGUI();
|
||||||
|
Loading…
Reference in New Issue
Block a user