X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=otk%2Fotk_test.cc;h=ccef19fa1b31e0f8eb1f749e993a5d9ebbac6fca;hb=e8b74211e7dcf08701809f657afa08df55dec218;hp=7bd6e9d618eb3eb6c5699107be01d7e21f7ce19f;hpb=590f7f58a6d4ba9214d3bd2d42ba2c353b492d4e;p=chaz%2Fopenbox diff --git a/otk/otk_test.cc b/otk/otk_test.cc index 7bd6e9d6..ccef19fa 100644 --- a/otk/otk_test.cc +++ b/otk/otk_test.cc @@ -1,9 +1,11 @@ -#include "widget.hh" +#include "focuswidget.hh" +#include "button.hh" #include "display.hh" #include "configuration.hh" #include "timerqueuemanager.hh" #include "image.hh" #include "style.hh" +#include int main(void) { otk::OBDisplay::initialize(NULL); @@ -13,38 +15,86 @@ int main(void) { 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(0ul, ctrl); + otk::Style *my_style = new otk::Style(ctrl); - const char *sfile = "/usr/local/share/openbox/styles/artwiz"; - - style_conf.setFile(sfile); + style_conf.setFile("/usr/local/share/openbox/styles/artwiz"); style_conf.load(); my_style->load(style_conf); - otk::OtkWidget foo(my_style); - otk::OtkWidget bar(&foo); - otk::OtkWidget baz(&foo); - otk::OtkWidget blef(&bar); + otk::OtkFocusWidget foo(my_style); + + foo.resize(600, 500); + foo.setTexture(my_style->getTitleFocus()); + foo.setUnfocusTexture(my_style->getTitleUnfocus()); + + foo.setBevelWidth(2); + foo.setDirection(otk::OtkWidget::Horizontal); - foo.setTexture(my_style->getButtonFocus()); - foo.setGeometry(0, 0, 100, 110); + otk::OtkFocusWidget left(&foo); + otk::OtkFocusWidget right(&foo); - bar.setTexture(my_style->getLabelFocus()); - bar.setGeometry(10, 10, 80, 40); + left.setDirection(otk::OtkWidget::Horizontal); + left.setStretchableVert(true); + left.setStretchableHorz(true); + left.setTexture(my_style->getTitleFocus()); + left.setUnfocusTexture(my_style->getTitleUnfocus()); + + right.setDirection(otk::OtkWidget::Vertical); + right.setBevelWidth(10); + right.setStretchableVert(true); + right.setWidth(300); + right.setTexture(my_style->getTitleFocus()); + right.setUnfocusTexture(my_style->getTitleUnfocus()); + + otk::OtkButton iconb(&left); + otk::OtkFocusWidget label(&left); + otk::OtkButton maxb(&left); + otk::OtkButton closeb(&left); + + // fixed size + iconb.setText("foo"); + iconb.press(); - baz.setTexture(my_style->getLabelFocus()); - baz.setGeometry(10, 60, 80, 40); + // fix width to 60 and let the height be calculated by its parent + //label.setHeight(20); + label.setStretchableVert(true); + label.setStretchableHorz(true); + label.setTexture(my_style->getLabelFocus()); + label.setUnfocusTexture(my_style->getLabelUnfocus()); - blef.setTexture(my_style->getHandleFocus()); - blef.setGeometry(10, 10, 60, 20); + // fixed size + maxb.setText("bar"); + + // fixed size + closeb.setText("fuubar"); + + otk::OtkFocusWidget rblef(&right); + otk::OtkButton rbutt1(&right); + otk::OtkButton rbutt2(&right); + + rblef.setStretchableHorz(true); + rblef.setHeight(50); + rblef.setTexture(my_style->getHandleFocus()); + rblef.setUnfocusTexture(my_style->getHandleUnfocus()); + + rbutt1.setText("this is fucking tight"); + rbutt2.setText("heh, WOOP"); + // will recursively unfocus its children + //foo.unfocus(); + foo.update(); foo.show(); while (1) { if (XPending(otk::OBDisplay::display)) { XEvent e; XNextEvent(otk::OBDisplay::display, &e); + if (e.type == Expose) { + foo.expose(e.xexpose); + } else if (e.type == ConfigureNotify) { + foo.configure(e.xconfigure); + } } }