all repos — openbox @ 2efa2b32717af9583b17416623cbd6606f547676

openbox fork - make it a bit more like ryudo

otk/otk_test.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
75
76
#include "widget.hh"
#include "focuswidget.hh"
#include "display.hh"
#include "configuration.hh"
#include "timerqueuemanager.hh"
#include "image.hh"
#include "style.hh"

int main(void) {
  otk::OBDisplay::initialize(NULL);
  otk::Configuration style_conf(False);
  otk::OBTimerQueueManager *tm = new otk::OBTimerQueueManager();
  const otk::ScreenInfo *s_info =
    otk::OBDisplay::screenInfo(DefaultScreen(otk::OBDisplay::display));
  otk::BImageControl *ctrl = new otk::BImageControl(tm, s_info, True, 4, 5, 200);

  otk::Style *my_style = new otk::Style(ctrl);

  style_conf.setFile("/usr/local/share/openbox/styles/artwiz");
  style_conf.load();

  my_style->load(style_conf);

  otk::OtkFocusWidget foo(my_style);
  otk::OtkFocusWidget iconb(&foo);
  otk::OtkFocusWidget label(&foo);
  otk::OtkFocusWidget maxb(&foo);
  otk::OtkFocusWidget closeb(&foo);

  foo.setBevelWidth(2);
  foo.setDirection(otk::OtkWidget::Vertical);
  
  foo.setHeight(400);
  foo.setTexture(my_style->getTitleFocus());
  foo.setUnfocusTexture(my_style->getTitleUnfocus());

  // fixed size
  iconb.resize(15, 15);
  iconb.setTexture(my_style->getButtonFocus());
  iconb.setUnfocusTexture(my_style->getButtonUnfocus());

  // fix width to 60 and let the height be calculated by its parent
  label.setWidth(60);
  label.setStretchableVert(true);
  label.setTexture(my_style->getLabelFocus());
  label.setUnfocusTexture(my_style->getLabelUnfocus());

  // fixed size
  maxb.resize(15, 15);
  maxb.setTexture(my_style->getButtonFocus());
  maxb.setUnfocusTexture(my_style->getButtonUnfocus());

  // fixed size
  closeb.resize(15, 15);
  closeb.setTexture(my_style->getButtonFocus());
  closeb.setUnfocusTexture(my_style->getButtonUnfocus());

  // will recursively unfocus its children
  //foo.unfocus();
  foo.show();

  while (1) {
    if (XPending(otk::OBDisplay::display)) {
      XEvent e;
      XNextEvent(otk::OBDisplay::display, &e);
    } 
  }

  delete my_style;
  delete tm;
  delete ctrl;

  otk::OBDisplay::destroy();

  return 0;
}