all repos — openbox @ a4dd208a7955e25bca710d4bcf355de7e608b9e1

openbox fork - make it a bit more like ryudo

otk/label.cc (raw)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*-

#ifdef HAVE_CONFIG_H
# include "../config.h"
#endif

#include "label.hh"

namespace otk {

Label::Label(Widget *parent)
  : Widget(parent), _text("")
{
  const ScreenInfo *info = display->screenInfo(screen());
  _xftdraw = XftDrawCreate(**display, window(), info->visual(),
                           info->colormap());
}

Label::~Label()
{
  XftDrawDestroy(_xftdraw);
}

void Label::setStyle(Style *style)
{
  Widget::setStyle(style);

  setTexture(style->getLabelUnfocus());
}


void Label::update(void)
{
  if (_dirty) {
    const Font *ft = style()->getFont();
    unsigned int sidemargin = style()->getBevelWidth() * 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()->textJustify()) {
      case Style::RightJustify:
        x += max_length - length;
        break;
      case Style::CenterJustify:
        x += (max_length - length) / 2;
        break;
      case Style::LeftJustify:
        break;
      }
    }

    Widget::update();

    ft->drawString(_xftdraw, x, 0, *style()->getTextUnfocus(), t);
  } else
    Widget::update();
}

}