X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=otk%2Ffocuswidget.cc;h=c3629bbbc348fa849f6c9672c80a635533581439;hb=0dcbf985c11c850b30b2983e1e20cd8cf033f054;hp=ffbaeb7e09bd995b4596eec63b99500bd06f18e4;hpb=a3d036f60ed2333622ee9b61dbddcdc8fbc497c3;p=chaz%2Fopenbox diff --git a/otk/focuswidget.cc b/otk/focuswidget.cc index ffbaeb7e..c3629bbb 100644 --- a/otk/focuswidget.cc +++ b/otk/focuswidget.cc @@ -1,79 +1,64 @@ -#include "focuswidget.hh" +// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*- -namespace otk { +#ifdef HAVE_CONFIG_H +# include "../config.h" +#endif -OtkFocusWidget::OtkFocusWidget(OtkWidget *parent, Direction direction) - : OtkWidget(parent, direction), _unfocus_texture(0), _focused(true) -{ - _focus_texture = parent->getTexture(); -} +#include "focuswidget.hh" -OtkFocusWidget::OtkFocusWidget(OtkApplication *app, Direction direction, - Cursor cursor, int bevel_width) - : OtkWidget(app, direction, cursor, bevel_width), - _unfocus_texture(0), _focused(true) -{ -} +namespace otk { -OtkFocusWidget::OtkFocusWidget(Style *style, Direction direction, - Cursor cursor, int bevel_width) - : OtkWidget(style, direction, cursor, bevel_width), - _unfocus_texture(0), _focused(true) +FocusWidget::FocusWidget(Widget *parent, Direction direction) + : Widget(parent, direction), _unfocus_texture(0), _unfocus_bcolor(0) { + _focused = true; + _focus_texture = parent->texture(); + _focus_bcolor = parent->borderColor(); } -OtkFocusWidget::~OtkFocusWidget() +FocusWidget::~FocusWidget() { } -void OtkFocusWidget::focus(void) +#include +void FocusWidget::focus(void) { if (_focused) return; - // XXX: what about OtkWidget::focus() - - assert(_focus_texture); - OtkWidget::setTexture(_focus_texture); - OtkWidget::update(); + Widget::focus(); - OtkWidget::OtkWidgetList children = OtkWidget::getChildren(); + if (_focus_bcolor) + Widget::setBorderColor(_focus_bcolor); - OtkWidget::OtkWidgetList::iterator it = children.begin(), - end = children.end(); - - OtkFocusWidget *tmp = 0; - for (; it != end; ++it) { - tmp = dynamic_cast(*it); - if (tmp) tmp->focus(); - } + Widget::setTexture(_focus_texture); + update(); } -void OtkFocusWidget::unfocus(void) +void FocusWidget::unfocus(void) { - if (! _focused) + if (!_focused) return; - assert(_unfocus_texture); - OtkWidget::setTexture(_unfocus_texture); - OtkWidget::update(); - - OtkWidget::OtkWidgetList children = OtkWidget::getChildren(); + Widget::unfocus(); - OtkWidget::OtkWidgetList::iterator it = children.begin(), - end = children.end(); + if (_unfocus_bcolor) + Widget::setBorderColor(_unfocus_bcolor); - OtkFocusWidget *tmp = 0; - for (; it != end; ++it) { - tmp = dynamic_cast(*it); - if (tmp) tmp->unfocus(); - } + Widget::setTexture(_unfocus_texture); + update(); } -void OtkFocusWidget::setTexture(BTexture *texture) +void FocusWidget::setTexture(Texture *texture) { - OtkWidget::setTexture(texture); + Widget::setTexture(texture); _focus_texture = texture; } +void FocusWidget::setBorderColor(const Color *color) +{ + Widget::setBorderColor(color); + _focus_bcolor = color; +} + }