+// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*-
+
+#ifdef HAVE_CONFIG_H
+# include "../config.h"
+#endif
+
#include "label.hh"
namespace otk {
OtkLabel::OtkLabel(OtkWidget *parent)
: OtkWidget(parent), _text("")
{
- setTexture(getStyle()->getLabelUnfocus());
+ const ScreenInfo *info = OBDisplay::screenInfo(getScreen());
+ _xftdraw = XftDrawCreate(OBDisplay::display, getWindow(), info->getVisual(),
+ info->getColormap());
}
OtkLabel::~OtkLabel()
{
+ XftDrawDestroy(_xftdraw);
}
+void OtkLabel::setStyle(Style *style)
+{
+ OtkWidget::setStyle(style);
+
+ setTexture(getStyle()->getLabelUnfocus());
+}
+
+
void OtkLabel::update(void)
{
if (_dirty) {
const BFont &ft = getStyle()->getFont();
- unsigned int bevel = getStyle()->getBevelWidth();
+ unsigned int sidemargin = getStyle()->getBevelWidth() * 2;
std::string t = _text; // the actual text to draw
- int x = bevel; // x coord for the text
+ int x = sidemargin; // x coord for the text
// find a string that will fit inside the area for text
- int max_length = width() - getBevelWidth() * 2;
+ int max_length = width() - sidemargin * 2;
if (max_length <= 0) {
t = ""; // can't fit anything
} else {
OtkWidget::update();
- ft.drawString(getWindow(), x, bevel, *getStyle()->getTextUnfocus(), t);
+ ft.drawString(_xftdraw, x, 0, *getStyle()->getTextUnfocus(), t);
} else
OtkWidget::update();
}