-#include <iostream>
+// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*-
+
+#ifdef HAVE_CONFIG_H
+# include "../config.h"
+#endif
+
#include "focuslabel.hh"
+#include "display.hh"
+#include "screeninfo.hh"
namespace otk {
-OtkFocusLabel::OtkFocusLabel(OtkWidget *parent)
- : OtkFocusWidget(parent), _text(""), _dirty(false)
+FocusLabel::FocusLabel(Widget *parent)
+ : FocusWidget(parent), _text("")
{
- setTexture(getStyle()->getLabelFocus());
- setUnfocusTexture(getStyle()->getLabelUnfocus());
+ setStyle(_style);
}
-OtkFocusLabel::~OtkFocusLabel()
+FocusLabel::~FocusLabel()
{
}
-void OtkFocusLabel::update(void)
-{
- if (_dirty) {
- const BFont &ft = getStyle()->getFont();
- BColor *text_color = (isFocused() ? getStyle()->getTextFocus()
- : getStyle()->getTextUnfocus());
- unsigned int bevel = getStyle()->getBevelWidth();
-
- std::string t = _text; // the actual text to draw
- int x = bevel; // x coord for the text
-
- // find a string that will fit inside the area for text
- int max_length = width() - getBevelWidth() * 2;
- if (max_length <= 0) {
- t = ""; // can't fit anything
- } else {
- size_t text_len = t.size();
- int length;
-
- do {
- t.resize(text_len);
- length = ft.measureString(t);
- } while (length > max_length && text_len-- > 0);
-
- // justify the text
- switch (getStyle()->textJustify()) {
- case Style::RightJustify:
- x += max_length - length;
- break;
- case Style::CenterJustify:
- x += (max_length - length) / 2;
- break;
- case Style::LeftJustify:
- break;
- }
- }
-
- OtkFocusWidget::update();
- ft.drawString(getWindow(), x, bevel, *text_color, t);
- } else
- OtkFocusWidget::update();
+void FocusLabel::setStyle(RenderStyle *style)
+{
+ FocusWidget::setStyle(style);
- _dirty = false;
+ setTexture(style->labelFocusBackground());
+ setUnfocusTexture(style->labelUnfocusBackground());
}
-int OtkFocusLabel::exposeHandler(const XExposeEvent &e)
-{
- _dirty = true;
- return OtkFocusWidget::exposeHandler(e);
-}
-int OtkFocusLabel::configureHandler(const XConfigureEvent &e)
+void FocusLabel::renderForeground()
{
- if (!(e.width == width() && e.height == height()))
- _dirty = true;
- return OtkFocusWidget::configureHandler(e);
+ otk::Widget::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
+
+ // find a string that will fit inside the area for text
+ int max_length = width() - sidemargin * 2;
+ if (max_length <= 0) {
+ t = ""; // can't fit anything
+ } else {
+ size_t text_len = t.size();
+ int length;
+
+ do {
+ t.resize(text_len);
+ length = ft->measureString(t);
+ } while (length > max_length && text_len-- > 0);
+
+ // justify the text
+ switch (style()->labelTextJustify()) {
+ case RenderStyle::RightJustify:
+ x += max_length - length;
+ break;
+ case RenderStyle::CenterJustify:
+ x += (max_length - length) / 2;
+ break;
+ case RenderStyle::LeftJustify:
+ break;
+ }
+ }
+
+ display->renderControl(_screen)->
+ drawString(*_surface, *ft, x, 0, *text_color, t);
}
}