Added experimental code to give a background per line for the race
result. Too much is hardcoded atm, so it needs some work should we want this look. Check for #ifdef USE_PER_LINE_BACKGROUND to see what was done. git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/trunk@5991 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
parent
5fbc6eb0bb
commit
79b0471b01
@ -242,11 +242,13 @@ namespace GUIEngine
|
|||||||
|
|
||||||
irr::video::ITexture* bg_image;
|
irr::video::ITexture* bg_image;
|
||||||
|
|
||||||
|
#ifdef USE_PER_LINE_BACKGROUND
|
||||||
|
public:
|
||||||
|
#endif
|
||||||
void drawBoxFromStretchableTexture(SkinWidgetContainer* w, const irr::core::rect< irr::s32 > &dest,
|
void drawBoxFromStretchableTexture(SkinWidgetContainer* w, const irr::core::rect< irr::s32 > &dest,
|
||||||
BoxRenderParams& params, bool deactivated=false,
|
BoxRenderParams& params, bool deactivated=false,
|
||||||
const irr::core::rect<irr::s32>* clipRect=NULL);
|
const irr::core::rect<irr::s32>* clipRect=NULL);
|
||||||
|
private:
|
||||||
// my utility methods, to work around irrlicht's very Windows-95-like-look-enforcing skin system
|
// my utility methods, to work around irrlicht's very Windows-95-like-look-enforcing skin system
|
||||||
void process3DPane(irr::gui::IGUIElement *element, const irr::core::rect< irr::s32 > &rect, const bool pressed);
|
void process3DPane(irr::gui::IGUIElement *element, const irr::core::rect< irr::s32 > &rect, const bool pressed);
|
||||||
void drawButton(Widget* w, const irr::core::rect< irr::s32 > &rect, const bool pressed, const bool focused);
|
void drawButton(Widget* w, const irr::core::rect< irr::s32 > &rect, const bool pressed, const bool focused);
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
#include "guiengine/engine.hpp"
|
#include "guiengine/engine.hpp"
|
||||||
#include "guiengine/scalable_font.hpp"
|
#include "guiengine/scalable_font.hpp"
|
||||||
#include "guiengine/widget.hpp"
|
#include "guiengine/widget.hpp"
|
||||||
|
#include "io/file_manager.hpp"
|
||||||
#include "modes/world_with_rank.hpp"
|
#include "modes/world_with_rank.hpp"
|
||||||
#include "states_screens/dialogs/race_over_dialog.hpp"
|
#include "states_screens/dialogs/race_over_dialog.hpp"
|
||||||
#include "states_screens/main_menu_screen.hpp"
|
#include "states_screens/main_menu_screen.hpp"
|
||||||
@ -293,8 +294,8 @@ void RaceResultGUI::determineTableLayout()
|
|||||||
m_time_for_points = 1.0f;
|
m_time_for_points = 1.0f;
|
||||||
|
|
||||||
// Determine text height
|
// Determine text height
|
||||||
r = m_font->getDimension(L"Y");
|
r = m_font->getDimension(L"Y");
|
||||||
m_distance_between_rows = (int)(1.5f*r.Height);
|
m_distance_between_rows = (int)(1.5f*r.Height);
|
||||||
|
|
||||||
// If there are too many karts, reduce size between rows
|
// If there are too many karts, reduce size between rows
|
||||||
if(m_distance_between_rows * num_karts > height)
|
if(m_distance_between_rows * num_karts > height)
|
||||||
@ -314,18 +315,18 @@ void RaceResultGUI::determineTableLayout()
|
|||||||
core::dimension2du r_all_p = m_font->getDimension(L"999");
|
core::dimension2du r_all_p = m_font->getDimension(L"999");
|
||||||
unsigned int width_all_points = r_all_p.Width;
|
unsigned int width_all_points = r_all_p.Width;
|
||||||
|
|
||||||
unsigned int table_width = m_width_icon + m_width_column_space
|
m_table_width = m_width_icon + m_width_column_space
|
||||||
+ m_width_kart_name;
|
+ m_width_kart_name;
|
||||||
|
|
||||||
if(race_manager->getMinorMode()!=RaceManager::MINOR_MODE_FOLLOW_LEADER)
|
if(race_manager->getMinorMode()!=RaceManager::MINOR_MODE_FOLLOW_LEADER)
|
||||||
table_width += m_width_finish_time + m_width_column_space;
|
m_table_width += m_width_finish_time + m_width_column_space;
|
||||||
|
|
||||||
// Only in GP mode are the points displayed.
|
// Only in GP mode are the points displayed.
|
||||||
if (race_manager->getMajorMode()==RaceManager::MAJOR_MODE_GRAND_PRIX)
|
if (race_manager->getMajorMode()==RaceManager::MAJOR_MODE_GRAND_PRIX)
|
||||||
table_width += m_width_new_points + width_all_points
|
m_table_width += m_width_new_points + width_all_points
|
||||||
+ 2 * m_width_column_space;
|
+ 2 * m_width_column_space;
|
||||||
|
|
||||||
m_leftmost_column = table_area->m_x + (table_area->m_w - table_width)/2;
|
m_leftmost_column = table_area->m_x + (table_area->m_w - m_table_width)/2;
|
||||||
} // determineTableLayout
|
} // determineTableLayout
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -583,6 +584,16 @@ void RaceResultGUI::displayOneEntry(unsigned int x, unsigned int y,
|
|||||||
video::SColor color = ri->m_is_player_kart ? video::SColor(255,255,0, 0 )
|
video::SColor color = ri->m_is_player_kart ? video::SColor(255,255,0, 0 )
|
||||||
: video::SColor(255,255,255,255);
|
: video::SColor(255,255,255,255);
|
||||||
|
|
||||||
|
#ifdef USE_PER_LINE_BACKGROUND
|
||||||
|
// Draw the background image
|
||||||
|
core::rect<s32> dest(x-50, y,
|
||||||
|
x+50+m_table_width,
|
||||||
|
(int)(y+m_distance_between_rows));
|
||||||
|
ri->m_box_params.setTexture(irr_driver->getTexture( (file_manager->getGUIDir() + "skins/glass/glassbutton_focused.png").c_str() ) );
|
||||||
|
GUIEngine::getSkin()->drawBoxFromStretchableTexture(&(ri->m_widget_container),
|
||||||
|
dest,
|
||||||
|
ri->m_box_params);
|
||||||
|
#endif
|
||||||
unsigned int current_x = x;
|
unsigned int current_x = x;
|
||||||
|
|
||||||
// First draw the icon
|
// First draw the icon
|
||||||
|
@ -95,6 +95,12 @@ private:
|
|||||||
video::ITexture *m_kart_icon;
|
video::ITexture *m_kart_icon;
|
||||||
/** The times of all karts in the right order. */
|
/** The times of all karts in the right order. */
|
||||||
core::stringw m_finish_time_string;
|
core::stringw m_finish_time_string;
|
||||||
|
#ifdef USE_PER_LINE_BACKGROUND
|
||||||
|
/** For the background bar behind each line. */
|
||||||
|
GUIEngine::SkinWidgetContainer m_widget_container;
|
||||||
|
/** The parameter for rendering the background box. */
|
||||||
|
GUIEngine::BoxRenderParams m_box_params;
|
||||||
|
#endif
|
||||||
}; // Rowinfo
|
}; // Rowinfo
|
||||||
|
|
||||||
std::vector<RowInfo> m_all_row_infos;
|
std::vector<RowInfo> m_all_row_infos;
|
||||||
@ -140,6 +146,9 @@ private:
|
|||||||
|
|
||||||
/** Size of space between columns. */
|
/** Size of space between columns. */
|
||||||
unsigned int m_width_column_space;
|
unsigned int m_width_column_space;
|
||||||
|
|
||||||
|
/** The overall width of the table. */
|
||||||
|
unsigned int m_table_width;
|
||||||
|
|
||||||
/** The font to use. */
|
/** The font to use. */
|
||||||
gui::ScalableFont *m_font;
|
gui::ScalableFont *m_font;
|
||||||
|
Loading…
Reference in New Issue
Block a user