X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=otk%2Fotk_test.cc;h=495b81d59ff687c425f3c7f748d9be517e936b83;hb=52b83a9dbb2b7823d5f78781f5948dfd8d77d50b;hp=810e046529f0fd02655850c06961d18631ec325e;hpb=2fb944068494f9b6ef97c28aac0c0d814d9bd607;p=chaz%2Fopenbox diff --git a/otk/otk_test.cc b/otk/otk_test.cc index 810e0465..495b81d5 100644 --- a/otk/otk_test.cc +++ b/otk/otk_test.cc @@ -1,57 +1,83 @@ -#include "widget.hh" -#include "display.hh" -#include "configuration.hh" -#include "timerqueuemanager.hh" -#include "image.hh" -#include "style.hh" +// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*- -#include +#ifdef HAVE_CONFIG_H +# include "../config.h" +#endif -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(0); - otk::BImageControl *ctrl = new otk::BImageControl(tm, s_info, True, 4, 5, 200); +#include "application.hh" +#include "focuswidget.hh" +#include "appwidget.hh" +#include "button.hh" - otk::Style *my_style = new otk::Style(0ul, ctrl); +int main(int argc, char **argv) { + otk::OtkApplication app(argc, argv); - const char *sfile = "/usr/local/share/openbox/styles/artwiz"; + otk::OtkAppWidget foo(&app); + + foo.resize(600, 500); + foo.setTexture(app.getStyle()->getTitleFocus()); +// foo.setUnfocusTexture(app.getStyle()->getTitleUnfocus()); + + foo.setBevelWidth(2); + foo.setDirection(otk::OtkWidget::Horizontal); + + otk::OtkFocusWidget left(&foo); + otk::OtkFocusWidget right(&foo); + + left.setDirection(otk::OtkWidget::Horizontal); + left.setStretchableVert(true); + left.setStretchableHorz(true); + left.setTexture(app.getStyle()->getTitleFocus()); + left.setUnfocusTexture(app.getStyle()->getTitleUnfocus()); + + right.setDirection(otk::OtkWidget::Vertical); + right.setBevelWidth(10); + right.setStretchableVert(true); + right.setWidth(300); + right.setTexture(app.getStyle()->getTitleFocus()); + right.setUnfocusTexture(app.getStyle()->getTitleUnfocus()); + + otk::OtkButton iconb(&left); + iconb.resize(40,20); + otk::OtkFocusWidget label(&left); + otk::OtkButton maxb(&left); + otk::OtkButton closeb(&left); - style_conf.setFile(sfile); - style_conf.load(); + // fixed size + iconb.setText("foo"); + iconb.press(Button1); - my_style->load(style_conf); + // fix width to 60 and let the height be calculated by its parent + //label.setHeight(20); + label.setStretchableVert(true); + label.setStretchableHorz(true); + label.setTexture(app.getStyle()->getLabelFocus()); + label.setUnfocusTexture(app.getStyle()->getLabelUnfocus()); - otk::OtkWidget foo(my_style); - otk::OtkWidget bar(&foo); - otk::OtkWidget baz(&foo); - otk::OtkWidget blef(&bar); + // fixed size + maxb.setText("bar"); - foo.setTexture(my_style->getButtonFocus()); - foo.setGeometry(0, 0, 100, 110); + // fixed size + closeb.setText("fuubar"); - bar.setTexture(my_style->getLabelFocus()); - bar.setGeometry(10, 10, 80, 40); + otk::OtkFocusWidget rblef(&right); + otk::OtkButton rbutt1(&right); + otk::OtkButton rbutt2(&right); - baz.setTexture(my_style->getLabelFocus()); - baz.setGeometry(10, 60, 80, 40); + rblef.setStretchableHorz(true); + rblef.setHeight(50); + rblef.setTexture(app.getStyle()->getHandleFocus()); + rblef.setUnfocusTexture(app.getStyle()->getHandleUnfocus()); + + rbutt1.setText("this is fucking tight"); + rbutt2.setText("heh, WOOP"); - blef.setTexture(my_style->getHandleFocus()); - blef.setGeometry(10, 10, 60, 20); + // 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; + app.exec(); return 0; }