namespace otk {
-OtkFocusWidget::OtkFocusWidget(OtkWidget *parent, Direction direction)
- : OtkWidget(parent, direction), _unfocus_texture(0), _focused(true)
+FocusWidget::FocusWidget(Widget *parent, Direction direction)
+ : Widget(parent, direction), _unfocus_texture(0), _unfocus_bcolor(0)
{
- _focus_texture = parent->getTexture();
+ _focused = true;
+ _focus_texture = parent->texture();
+ _focus_bcolor = parent->borderColor();
}
-OtkFocusWidget::~OtkFocusWidget()
+FocusWidget::~FocusWidget()
{
}
-void OtkFocusWidget::focus(void)
+
+void FocusWidget::focus(void)
{
if (_focused)
return;
- // XXX: what about OtkWidget::focus()
+ Widget::focus();
- assert(_focus_texture);
- OtkWidget::setTexture(_focus_texture);
- OtkWidget::update();
+ if (_focus_bcolor)
+ Widget::setBorderColor(_focus_bcolor);
- OtkBaseWidgetList::iterator it = _children.begin(), end = _children.end();
- OtkFocusWidget *tmp = 0;
- for (; it != end; ++it) {
- tmp = dynamic_cast<OtkFocusWidget*>(*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();
+ Widget::unfocus();
+
+ if (_unfocus_bcolor)
+ Widget::setBorderColor(_unfocus_bcolor);
- OtkBaseWidgetList::iterator it = _children.begin(), end = _children.end();
- OtkFocusWidget *tmp = 0;
- for (; it != end; ++it) {
- tmp = dynamic_cast<OtkFocusWidget*>(*it);
- if (tmp) tmp->unfocus();
- }
+ Widget::setTexture(_unfocus_texture);
+ update();
}
-void OtkFocusWidget::setTexture(BTexture *texture)
+void FocusWidget::setTexture(RenderTexture *texture)
{
- OtkWidget::setTexture(texture);
+ Widget::setTexture(texture);
_focus_texture = texture;
}
+void FocusWidget::setBorderColor(const RenderColor *color)
+{
+ Widget::setBorderColor(color);
+ _focus_bcolor = color;
+}
+
}