added a different type of seleection for karts and tracks
git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/branches/irrlicht@3380 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
parent
a826fc0311
commit
2e7de89e69
BIN
data/gui/glass_square_focused.png
Normal file
BIN
data/gui/glass_square_focused.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.9 KiB |
@ -9,7 +9,7 @@
|
|||||||
<model id="modelview" width="40%" proportion="3" align="center"/>
|
<model id="modelview" width="40%" proportion="3" align="center"/>
|
||||||
<label width="100%" height="25" text="Wilber" align="center" text_align="center" />
|
<label width="100%" height="25" text="Wilber" align="center" text_align="center" />
|
||||||
|
|
||||||
<ribbon_grid id="karts" proportion="2" width="100%" align="center" child_width="80" child_height="80"/>
|
<ribbon_grid id="karts" proportion="2" square_items="true" width="100%" align="center" child_width="80" child_height="80"/>
|
||||||
|
|
||||||
<tabs width="100%" height="25" id="kartgroups">
|
<tabs width="100%" height="25" id="kartgroups">
|
||||||
<button text="Standard"/>
|
<button text="Standard"/>
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
<label width="100%" height="25" text="Grand Prix" align="center" text_align="center" />
|
<label width="100%" height="25" text="Grand Prix" align="center" text_align="center" />
|
||||||
|
|
||||||
<buttonbar id="gps" height="175" width="100%" align="center">
|
<buttonbar id="gps" height="175" width="100%" align="center" square_items="true">
|
||||||
<icon-button id="gp1" width="171" height="128" icon="gui/track1.png" text="Penguin Playground"/>
|
<icon-button id="gp1" width="171" height="128" icon="gui/track1.png" text="Penguin Playground"/>
|
||||||
<icon-button id="gp2" width="171" height="128" icon="gui/track2.png" text="Snag Drive"/>
|
<icon-button id="gp2" width="171" height="128" icon="gui/track2.png" text="Snag Drive"/>
|
||||||
<icon-button id="gp3" width="171" height="128" icon="gui/track3.png" text="To the Moon and Back"/>
|
<icon-button id="gp3" width="171" height="128" icon="gui/track3.png" text="To the Moon and Back"/>
|
||||||
@ -11,8 +11,7 @@
|
|||||||
|
|
||||||
<label width="100%" height="25" text="All Tracks" align="center" text_align="center" />
|
<label width="100%" height="25" text="All Tracks" align="center" text_align="center" />
|
||||||
|
|
||||||
<ribbon_grid id="tracks" proportion="1" width="100%" text="-" align="center" child_width="160" child_height="120" />
|
<ribbon_grid id="tracks" proportion="1" width="100%" square_items="true" text="-" align="center" child_width="160" child_height="120" />
|
||||||
|
|
||||||
|
|
||||||
<tabs width="100%" height="25" id="trackgroups">
|
<tabs width="100%" height="25" id="trackgroups">
|
||||||
<button text="Standard"/>
|
<button text="Standard"/>
|
||||||
|
@ -136,6 +136,7 @@ if(prop_name != NULL) widget.m_properties[prop_flag] = prop_name; else widget.m_
|
|||||||
READ_PROPERTY(text_align, PROP_TEXT_ALIGN);
|
READ_PROPERTY(text_align, PROP_TEXT_ALIGN);
|
||||||
READ_PROPERTY(min_value, PROP_MIN_VALUE);
|
READ_PROPERTY(min_value, PROP_MIN_VALUE);
|
||||||
READ_PROPERTY(max_value, PROP_MAX_VALUE);
|
READ_PROPERTY(max_value, PROP_MAX_VALUE);
|
||||||
|
READ_PROPERTY(square_items, PROP_SQUARE);
|
||||||
#undef READ_PROPERTY
|
#undef READ_PROPERTY
|
||||||
|
|
||||||
//std::cout << "loaded widget " << id << std::endl;
|
//std::cout << "loaded widget " << id << std::endl;
|
||||||
|
114
src/gui/skin.cpp
114
src/gui/skin.cpp
@ -28,6 +28,7 @@ Skin::Skin(IGUISkin* fallback_skin)
|
|||||||
|
|
||||||
m_tex_iconhighlight = GUIEngine::getDriver()->getTexture( (file_manager->getGUIDir() + "/glass_iconhighlight.png").c_str() );
|
m_tex_iconhighlight = GUIEngine::getDriver()->getTexture( (file_manager->getGUIDir() + "/glass_iconhighlight.png").c_str() );
|
||||||
m_tex_ficonhighlight = GUIEngine::getDriver()->getTexture( (file_manager->getGUIDir() + "/glass_iconhighlight_focus.png").c_str() );
|
m_tex_ficonhighlight = GUIEngine::getDriver()->getTexture( (file_manager->getGUIDir() + "/glass_iconhighlight_focus.png").c_str() );
|
||||||
|
m_tex_squarefocus = GUIEngine::getDriver()->getTexture( (file_manager->getGUIDir() + "/glass_square_focused.png").c_str() );
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -117,11 +118,13 @@ void Skin::drawBoxFromStretchableTexture(const core::rect< s32 > &dest, ITexture
|
|||||||
const int dest_x2 = dest.LowerRightCorner.X;
|
const int dest_x2 = dest.LowerRightCorner.X;
|
||||||
const int dest_y2 = dest.LowerRightCorner.Y;
|
const int dest_y2 = dest.LowerRightCorner.Y;
|
||||||
|
|
||||||
const float scale = (float)(dest_y2-dest_y)/texture_h;
|
const float xscale = (float)(dest_x2-dest_x)/texture_w;
|
||||||
const int dest_left_border = left_border*scale;
|
const float yscale = (float)(dest_y2-dest_y)/texture_h;
|
||||||
const int dest_right_border = right_border*scale;
|
|
||||||
const int dest_top_border = top_border*scale;
|
const int dest_left_border = left_border*std::min<float>(yscale, 1.0);
|
||||||
const int dest_bottom_border = bottom_border*scale;
|
const int dest_right_border = right_border*std::min<float>(yscale, 1.0);
|
||||||
|
const int dest_top_border = top_border*std::min<float>(xscale, 1.0);
|
||||||
|
const int dest_bottom_border = bottom_border*std::min<float>(xscale, 1.0);
|
||||||
|
|
||||||
const float border_in_portion = 1 - border_out_portion;
|
const float border_in_portion = 1 - border_out_portion;
|
||||||
|
|
||||||
@ -317,54 +320,79 @@ void Skin::drawRibbonChild(const core::rect< s32 > &rect, const Widget* widget,
|
|||||||
/* icon ribbons */
|
/* icon ribbons */
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
bool use_glow = true;
|
||||||
|
|
||||||
|
if (widget->m_parent != NULL && widget->m_parent->m_properties[PROP_SQUARE] == "true") use_glow = false;
|
||||||
|
if (widget->m_parent != NULL && widget->m_parent->m_parent != NULL &&
|
||||||
|
widget->m_parent->m_parent->m_properties[PROP_SQUARE] == "true") use_glow = false;
|
||||||
|
|
||||||
|
|
||||||
if(widget->m_parent != NULL && widget->m_parent->m_type == WTYPE_RIBBON &&
|
if(widget->m_parent != NULL && widget->m_parent->m_type == WTYPE_RIBBON &&
|
||||||
((RibbonWidget*)widget->m_parent)->getRibbonType() == RIBBON_TOOLBAR &&
|
((RibbonWidget*)widget->m_parent)->getRibbonType() == RIBBON_TOOLBAR &&
|
||||||
!GUIEngine::getGUIEnv()->hasFocus(widget->m_parent->m_element)) mark_selected = false;
|
!GUIEngine::getGUIEnv()->hasFocus(widget->m_parent->m_element)) mark_selected = false;
|
||||||
|
|
||||||
if(mark_selected)
|
if(mark_selected)
|
||||||
{
|
{
|
||||||
int grow = 45;
|
if (use_glow)
|
||||||
static float glow_effect = 0;
|
|
||||||
|
|
||||||
if(focused || parent_focused)
|
|
||||||
{
|
{
|
||||||
const float dt = GUIEngine::getLatestDt();
|
int grow = 45;
|
||||||
glow_effect += dt*3;
|
static float glow_effect = 0;
|
||||||
if (glow_effect > 6.2832 /* 2*PI */) glow_effect -= 6.2832;
|
|
||||||
grow = 45 + 10*sin(glow_effect);
|
if(focused || parent_focused)
|
||||||
}
|
{
|
||||||
|
const float dt = GUIEngine::getLatestDt();
|
||||||
/*
|
glow_effect += dt*3;
|
||||||
const core::rect< s32 > rect2 = core::rect< s32 >(rect.UpperLeftCorner.X - 5 - grow,
|
if (glow_effect > 6.2832 /* 2*PI */) glow_effect -= 6.2832;
|
||||||
rect.UpperLeftCorner.Y - 5 - grow,
|
grow = 45 + 10*sin(glow_effect);
|
||||||
rect.UpperLeftCorner.X + rect.getWidth() + 5 + grow,
|
}
|
||||||
rect.UpperLeftCorner.Y + rect.getHeight() + 5 + grow);
|
|
||||||
*/
|
|
||||||
|
const int glow_center_x = rect.UpperLeftCorner.X + rect.getWidth()/2;
|
||||||
const int glow_center_x = rect.UpperLeftCorner.X + rect.getWidth()/2;
|
const int glow_center_y = rect.UpperLeftCorner.Y + rect.getHeight() - 5;
|
||||||
const int glow_center_y = rect.UpperLeftCorner.Y + rect.getHeight() - 5;
|
|
||||||
|
const core::rect< s32 > rect2 = core::rect< s32 >(glow_center_x - 45 - grow,
|
||||||
const core::rect< s32 > rect2 = core::rect< s32 >(glow_center_x - 45 - grow,
|
glow_center_y - 25 - grow/2,
|
||||||
glow_center_y - 25 - grow/2,
|
glow_center_x + 45 + grow,
|
||||||
glow_center_x + 45 + grow,
|
glow_center_y + 25 + grow/2);
|
||||||
glow_center_y + 25 + grow/2);
|
|
||||||
|
// GUIEngine::getDriver()->draw2DRectangle( SColor(2555, 0, 175, 255), rect2 );
|
||||||
// GUIEngine::getDriver()->draw2DRectangle( SColor(2555, 0, 175, 255), rect2 );
|
|
||||||
|
const int texture_w = m_tex_ficonhighlight->getSize().Width;
|
||||||
const int texture_w = m_tex_ficonhighlight->getSize().Width;
|
const int texture_h = m_tex_ficonhighlight->getSize().Height;
|
||||||
const int texture_h = m_tex_ficonhighlight->getSize().Height;
|
|
||||||
|
core::rect<s32> source_area = core::rect<s32>(0, 0, texture_w, texture_h);
|
||||||
core::rect<s32> source_area = core::rect<s32>(0, 0, texture_w, texture_h);
|
|
||||||
|
if(!focused && !parent_focused)
|
||||||
if(!focused && !parent_focused)
|
{
|
||||||
{
|
GUIEngine::getDriver()->draw2DImage(m_tex_iconhighlight, rect2, source_area,
|
||||||
GUIEngine::getDriver()->draw2DImage(m_tex_iconhighlight, rect2, source_area,
|
0 /* no clipping */, 0, true /* alpha */);
|
||||||
0 /* no clipping */, 0, true /* alpha */);
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
GUIEngine::getDriver()->draw2DImage(m_tex_ficonhighlight, rect2, source_area,
|
||||||
|
0 /* no clipping */, 0, true /* alpha */);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
/* if we're not using glow */
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
GUIEngine::getDriver()->draw2DImage(m_tex_ficonhighlight, rect2, source_area,
|
const int texture_w = m_tex_squarefocus->getSize().Width;
|
||||||
0 /* no clipping */, 0, true /* alpha */);
|
const int texture_h = m_tex_squarefocus->getSize().Height;
|
||||||
|
|
||||||
|
core::rect<s32> source_area = core::rect<s32>(0, 0, texture_w, texture_h);
|
||||||
|
|
||||||
|
|
||||||
|
//const core::rect< s32 > rect2 = core::rect< s32 >(rect.UpperLeftCorner.X - 5,
|
||||||
|
// rect.UpperLeftCorner.Y - 5,
|
||||||
|
// rect.UpperLeftCorner.X + rect.getWidth() + 5,
|
||||||
|
// rect.UpperLeftCorner.Y + rect.getHeight() + 5);
|
||||||
|
|
||||||
|
//GUIEngine::getDriver()->draw2DImage(m_tex_squarefocus, rect2, source_area,
|
||||||
|
// 0 /* no clipping */, 0, true /* alpha */);
|
||||||
|
|
||||||
|
drawBoxFromStretchableTexture(rect, m_tex_squarefocus,
|
||||||
|
6 /* left border */, 6 /* rightborder */,
|
||||||
|
6 /* top border */, 6 /* bottom border */, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -35,6 +35,7 @@ class Skin : public IGUISkin
|
|||||||
ITexture* m_tex_dtab;
|
ITexture* m_tex_dtab;
|
||||||
ITexture* m_tex_iconhighlight;
|
ITexture* m_tex_iconhighlight;
|
||||||
ITexture* m_tex_ficonhighlight;
|
ITexture* m_tex_ficonhighlight;
|
||||||
|
ITexture* m_tex_squarefocus;
|
||||||
|
|
||||||
void drawBoxFromStretchableTexture(const core::rect< s32 > &dest, ITexture* source,
|
void drawBoxFromStretchableTexture(const core::rect< s32 > &dest, ITexture* source,
|
||||||
const int left_border, const int right_border,
|
const int left_border, const int right_border,
|
||||||
|
@ -46,7 +46,8 @@ namespace GUIEngine
|
|||||||
PROP_ICON,
|
PROP_ICON,
|
||||||
PROP_TEXT_ALIGN,
|
PROP_TEXT_ALIGN,
|
||||||
PROP_MIN_VALUE,
|
PROP_MIN_VALUE,
|
||||||
PROP_MAX_VALUE
|
PROP_MAX_VALUE,
|
||||||
|
PROP_SQUARE
|
||||||
};
|
};
|
||||||
|
|
||||||
class Widget
|
class Widget
|
||||||
|
Loading…
Reference in New Issue
Block a user