FocusLabel::FocusLabel(Widget *parent)
: FocusWidget(parent), _text("")
{
+ setStyle(_style);
}
FocusLabel::~FocusLabel()
}
-void FocusLabel::setStyle(Style *style)
+void FocusLabel::setStyle(RenderStyle *style)
{
FocusWidget::setStyle(style);
- // XXX: do this again
- //setTexture(style->getLabelFocus());
- //setUnfocusTexture(style->getLabelUnfocus());
+ setTexture(style->labelFocusBackground());
+ setUnfocusTexture(style->labelUnfocusBackground());
}
+void FocusLabel::fitString(const std::string &str)
+{
+ const Font *ft = style()->labelFont();
+ fitSize(ft->measureString(str), ft->height());
+}
+
+void FocusLabel::fitSize(int w, int h)
+{
+ unsigned int sidemargin = style()->bevelWidth() * 2;
+ resize(w + sidemargin * 2, h);
+}
-void FocusLabel::renderForeground(void)
+void FocusLabel::update()
{
- const Font *ft = style()->getFont();
- Color *text_color = (isFocused() ? style()->getTextFocus()
- : style()->getTextUnfocus());
- unsigned int sidemargin = style()->getBevelWidth() * 2;
+ if (_dirty) {
+ int w = _rect.width(), h = _rect.height();
+ const Font *ft = style()->labelFont();
+ unsigned int sidemargin = style()->bevelWidth() * 2;
+ if (!_fixed_width)
+ w = ft->measureString(_text) + sidemargin * 2;
+ if (!_fixed_height)
+ h = ft->height();
+ internalResize(w, h);
+ }
+ FocusWidget::update();
+}
+
+
+void FocusLabel::renderForeground()
+{
+ FocusWidget::renderForeground();
+
+ const Font *ft = style()->labelFont();
+ RenderColor *text_color = (isFocused() ? style()->textFocusColor()
+ : style()->textUnfocusColor());
+ unsigned int sidemargin = style()->bevelWidth() * 2;
ustring t = _text; // the actual text to draw
int x = sidemargin; // x coord for the text
} while (length > max_length && text_len-- > 0);
// justify the text
- switch (style()->textJustify()) {
- case Style::RightJustify:
+ switch (style()->labelTextJustify()) {
+ case RenderStyle::RightJustify:
x += max_length - length;
break;
- case Style::CenterJustify:
+ case RenderStyle::CenterJustify:
x += (max_length - length) / 2;
break;
- case Style::LeftJustify:
+ case RenderStyle::LeftJustify:
break;
}
}
display->renderControl(_screen)->
- drawString(_surface, *ft, x, 0, *text_color, t);
+ drawString(*_surface, *ft, x, 0, *text_color, t);
}
}