namespace otk {
-OtkLabel::OtkLabel(OtkWidget *parent)
- : OtkWidget(parent), _text("")
+Label::Label(Widget *parent)
+ : Widget(parent), _text("")
{
- const ScreenInfo *info = OBDisplay::screenInfo(getScreen());
- _xftdraw = XftDrawCreate(OBDisplay::display, getWindow(), info->getVisual(),
- info->getColormap());
-
- setTexture(getStyle()->getLabelUnfocus());
}
-OtkLabel::~OtkLabel()
+Label::~Label()
{
- XftDrawDestroy(_xftdraw);
}
-void OtkLabel::update(void)
+void Label::setStyle(Style *style)
+{
+ Widget::setStyle(style);
+
+ setTexture(style->getLabelUnfocus());
+}
+
+
+void Label::update(void)
{
if (_dirty) {
- const BFont &ft = getStyle()->getFont();
- unsigned int bevel = getStyle()->getBevelWidth() / 2;
+ const Font *ft = style()->getFont();
+ unsigned int sidemargin = style()->getBevelWidth() * 2;
- std::string t = _text; // the actual text to draw
- int x = bevel; // x coord for the text
+ ustring t = _text; // the actual text to draw
+ int x = sidemargin; // x coord for the text
// find a string that will fit inside the area for text
- int max_length = width() - bevel * 2;
+ int max_length = width() - sidemargin * 2;
if (max_length <= 0) {
t = ""; // can't fit anything
} else {
do {
t.resize(text_len);
- length = ft.measureString(t);
+ length = ft->measureString(t);
} while (length > max_length && text_len-- > 0);
// justify the text
- switch (getStyle()->textJustify()) {
+ switch (style()->textJustify()) {
case Style::RightJustify:
x += max_length - length;
break;
}
}
- OtkWidget::update();
+ Widget::update();
- ft.drawString(_xftdraw, x, bevel, *getStyle()->getTextUnfocus(), t);
+ display->renderControl(_screen)->
+ drawString(this, *ft, x, 0, *style()->getTextUnfocus(), t);
} else
- OtkWidget::update();
+ Widget::update();
}
}