Hide icons overlaping minimap

git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/trunk@5971 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
jmimu 2010-09-12 15:25:48 +00:00
parent 728d3743b0
commit 62eff31d0e
3 changed files with 418 additions and 268 deletions

File diff suppressed because it is too large Load Diff

View File

@ -92,6 +92,10 @@ RaceGUI::RaceGUI()
//I18N: Shown at the end of a race //I18N: Shown at the end of a race
m_string_finished = _("Finished"); m_string_finished = _("Finished");
m_string_lap = _("Lap"); m_string_lap = _("Lap");
m_string_rank = _("Rank");
//I18N: When some GlobalPlayerIcons are hidden, write "Top 10" to show it
m_string_top = _("Top %i");
//I18N: as in "ready, set, go", shown at the beginning of the race //I18N: as in "ready, set, go", shown at the beginning of the race
m_string_ready = _("Ready!"); m_string_ready = _("Ready!");
m_string_set = _("Set!"); m_string_set = _("Set!");
@ -322,6 +326,7 @@ void RaceGUI::renderPlayerView(const Kart *kart)
drawEnergyMeter (kart, viewport, scaling); drawEnergyMeter (kart, viewport, scaling);
drawSpeed (kart, viewport, scaling); drawSpeed (kart, viewport, scaling);
drawLap (info, kart, viewport); drawLap (info, kart, viewport);
drawRank (info, kart, viewport);
} // renderPlayerView } // renderPlayerView
@ -398,7 +403,7 @@ void RaceGUI::drawGlobalMiniMap()
// Draw players icons and their times (if defined in the current mode). // Draw players icons and their times (if defined in the current mode).
void RaceGUI::drawGlobalPlayerIcons(const KartIconDisplayInfo* info) void RaceGUI::drawGlobalPlayerIcons(const KartIconDisplayInfo* info)
{ {
int x_base = 15; int x_base = 10;
int y_base = 20; int y_base = 20;
int ICON_WIDTH=(int)(40*(UserConfigParams::m_width/800.0f)); int ICON_WIDTH=(int)(40*(UserConfigParams::m_width/800.0f));
int ICON_PLAYER_WIDTH=(int)(50*(UserConfigParams::m_width/800.0f)); int ICON_PLAYER_WIDTH=(int)(50*(UserConfigParams::m_width/800.0f));
@ -411,8 +416,8 @@ void RaceGUI::drawGlobalPlayerIcons(const KartIconDisplayInfo* info)
// Special case : when 3 players play, use 4th window to display such stuff // Special case : when 3 players play, use 4th window to display such stuff
if (race_manager->getNumLocalPlayers() == 3) if (race_manager->getNumLocalPlayers() == 3)
{ {
x_base = UserConfigParams::m_width/2 + 15; x_base = UserConfigParams::m_width/2 + x_base;
y_base = UserConfigParams::m_height/2 + 20; y_base = UserConfigParams::m_height/2 + y_base;
} }
WorldWithRank *world = (WorldWithRank*)(World::getWorld()); WorldWithRank *world = (WorldWithRank*)(World::getWorld());
@ -440,6 +445,12 @@ void RaceGUI::drawGlobalPlayerIcons(const KartIconDisplayInfo* info)
gui::ScalableFont* font = GUIEngine::getFont(); gui::ScalableFont* font = GUIEngine::getFont();
const unsigned int kart_amount = world->getNumKarts(); const unsigned int kart_amount = world->getNumKarts();
//where is the limit to hide last icons
float y_icons_limit=UserConfigParams::m_height-m_map_height-ICON_PLAYER_WIDTH;
if (race_manager->getNumLocalPlayers() == 3)
y_icons_limit=UserConfigParams::m_height-ICON_WIDTH;
for(int position = 1; position <= (int)kart_amount ; position++) for(int position = 1; position <= (int)kart_amount ; position++)
{ {
Kart *kart = world->getKartAtPosition(position); Kart *kart = world->getKartAtPosition(position);
@ -486,6 +497,8 @@ void RaceGUI::drawGlobalPlayerIcons(const KartIconDisplayInfo* info)
} }
previous_distance=distance; previous_distance=distance;
} // not three-strike-battle } // not three-strike-battle
previous_x=x;//save coord of the previous kart in list previous_x=x;//save coord of the previous kart in list
previous_y=y; previous_y=y;
@ -499,6 +512,22 @@ void RaceGUI::drawGlobalPlayerIcons(const KartIconDisplayInfo* info)
m_previous_icons_position[kart_id].X=x; m_previous_icons_position[kart_id].X=x;
m_previous_icons_position[kart_id].Y=y; m_previous_icons_position[kart_id].Y=y;
if (y>y_icons_limit)
{
//there are too many icons, write "Top 9", to express that
//there is not everybody shown
core::recti pos_top;
pos_top.UpperLeftCorner.Y = y_base-22;
pos_top.UpperLeftCorner.X = x_base;
static video::SColor color = video::SColor(255, 255, 255, 255);
pos_top.LowerRightCorner = pos_top.UpperLeftCorner;
font->draw(StringUtils::insertValues( m_string_top, position-1 ), pos_top, color);
break;
}
if (info[kart_id].m_text.size() > 0) if (info[kart_id].m_text.size() > 0)
{ {
video::SColor color = video::SColor(255, video::SColor color = video::SColor(255,
@ -911,6 +940,72 @@ void RaceGUI::drawLap(const KartIconDisplayInfo* info, const Kart* kart,
} }
} // drawLap } // drawLap
//-----------------------------------------------------------------------------
void RaceGUI::drawRank(const KartIconDisplayInfo* info, const Kart* kart,
const core::recti &viewport)
{
WorldWithRank *world = (WorldWithRank*)(World::getWorld());
const int rank = kart->getPosition();
const unsigned int kart_amount = world->getNumKarts();
core::recti pos;
pos.UpperLeftCorner.Y = viewport.LowerRightCorner.Y;
// place rank string somewhere on the left of the screen
if (m_minimap_on_left)
{
// check if mini-map is within Y coords of this player.
// if the mini-map is not even in the viewport of this player, don't
// bother placing the lap text at the right of the minimap.
if (UserConfigParams::m_height - m_map_bottom - m_map_height
> viewport.LowerRightCorner.Y)
{
pos.UpperLeftCorner.X = viewport.UpperLeftCorner.X
+ (int)(0.1f*UserConfigParams::m_width);
}
else
{
// place lap text at the right of the mini-map
const int calculated_x = viewport.UpperLeftCorner.X
+ (int)(0.05f*UserConfigParams::m_width);
// don't overlap minimap
pos.UpperLeftCorner.X = std::max(calculated_x,
m_map_right_side_x + 15);
}
}
else
{
// mini-map is on the right, and lap text on right,
// so no overlap possible
pos.UpperLeftCorner.X = viewport.UpperLeftCorner.X
+ (int)(0.05f*UserConfigParams::m_width);
}
gui::ScalableFont* font = GUIEngine::getFont();
int font_height = (int)(font->getDimension(L"X").Height);
if (kart->hasFinishedRace())
{
static video::SColor color = video::SColor(255, 255, 255, 255);
pos.UpperLeftCorner.Y -= (2+2)*font_height;
pos.LowerRightCorner = pos.UpperLeftCorner;
font->draw(m_string_finished.c_str(), pos, color);
}
else
{
static video::SColor color = video::SColor(255, 255, 255, 255);
pos.UpperLeftCorner.Y -= (3+2)*font_height;
pos.LowerRightCorner = pos.UpperLeftCorner;
font->draw(m_string_rank.c_str(), pos, color);
char str[256];
sprintf(str, "%d/%d", rank, kart_amount);
pos.UpperLeftCorner.Y += font_height;
pos.LowerRightCorner.Y += font_height;
font->draw(core::stringw(str).c_str(), pos, color);
}
} // drawRank
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
/** Removes messages which have been displayed long enough. This function /** Removes messages which have been displayed long enough. This function
* must be called after drawAllMessages, otherwise messages which are only * must be called after drawAllMessages, otherwise messages which are only

View File

@ -94,6 +94,12 @@ private:
/** Translated string 'lap' displayed every frame. */ /** Translated string 'lap' displayed every frame. */
core::stringw m_string_lap; core::stringw m_string_lap;
/** Translated string 'rank' displayed every frame. */
core::stringw m_string_rank;
/** Translated string 'Top %d' displayed every frame. */
core::stringw m_string_top;
/** Translated strings 'ready', 'set', 'go'. */ /** Translated strings 'ready', 'set', 'go'. */
core::stringw m_string_ready, m_string_set, m_string_go; core::stringw m_string_ready, m_string_set, m_string_go;
@ -166,6 +172,8 @@ private:
const core::vector2df &scaling); const core::vector2df &scaling);
void drawLap (const KartIconDisplayInfo* info, const Kart* kart, void drawLap (const KartIconDisplayInfo* info, const Kart* kart,
const core::recti &viewport); const core::recti &viewport);
void drawRank (const KartIconDisplayInfo* info, const Kart* kart,
const core::recti &viewport);
void drawGlobalPlayerIcons (const KartIconDisplayInfo* info); void drawGlobalPlayerIcons (const KartIconDisplayInfo* info);
/** Display items that are shown once only (for all karts). */ /** Display items that are shown once only (for all karts). */
void drawGlobalMiniMap (); void drawGlobalMiniMap ();