X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;ds=sidebyside;f=otk%2Fwidget.cc;h=691c0968e81eb6f408424ea7b8ecdf64153fd44c;hb=9f1facd3a167508906f1a2911d2ed7f0010967bb;hp=d375a918af89c7f8ede5ca11e2fd57fd8dada75c;hpb=bcb7dddf94266030a89d87e2cae9e3ec730a8760;p=chaz%2Fopenbox diff --git a/otk/widget.cc b/otk/widget.cc index d375a918..691c0968 100644 --- a/otk/widget.cc +++ b/otk/widget.cc @@ -247,7 +247,10 @@ void OtkWidget::adjustHorz(void) for (it = _children.begin(); it != end; ++it) { tmp = *it; - if (tmp->isStretchableHorz() && _fixed_width) + if (tmp->isStretchableVert()) + tmp->setHeight(_rect.height() > _bevel_width * 2 ? + _rect.height() - _bevel_width * 2 : _bevel_width); + if (tmp->isStretchableHorz()) stretchable.push_back(tmp); else width += tmp->_rect.width() + _bevel_width; @@ -262,10 +265,9 @@ void OtkWidget::adjustHorz(void) int str_width = _rect.width() - width / stretchable.size(); - for (; str_it != str_end; ++str_it) { - (*str_it)->setWidth(str_width - _bevel_width); - //(*str_it)->update(); - } + for (; str_it != str_end; ++str_it) + (*str_it)->setWidth(str_width > _bevel_width ? str_width - _bevel_width + : _bevel_width); } OtkWidget *prev_widget = 0; @@ -302,7 +304,10 @@ void OtkWidget::adjustVert(void) for (it = _children.begin(); it != end; ++it) { tmp = *it; - if (tmp->isStretchableVert() && _fixed_height) + if (tmp->isStretchableHorz()) + tmp->setWidth(_rect.width() > _bevel_width * 2 ? + _rect.width() - _bevel_width * 2 : _bevel_width); + if (tmp->isStretchableVert()) stretchable.push_back(tmp); else height += tmp->_rect.height() + _bevel_width; @@ -317,10 +322,9 @@ void OtkWidget::adjustVert(void) int str_height = _rect.height() - height / stretchable.size(); - for (; str_it != str_end; ++str_it) { - (*str_it)->setHeight(str_height - _bevel_width); - //(*str_it)->update(); - } + for (; str_it != str_end; ++str_it) + (*str_it)->setHeight(str_height > _bevel_width ? + str_height - _bevel_width : _bevel_width); } OtkWidget *prev_widget = 0; @@ -345,16 +349,16 @@ void OtkWidget::adjustVert(void) void OtkWidget::update(void) { - OtkWidgetList::iterator it = _children.begin(), end = _children.end(); - for (; it != end; ++it) - (*it)->update(); - if (_dirty) { adjust(); render(); XClearWindow(OBDisplay::display, _window); } + OtkWidgetList::iterator it = _children.begin(), end = _children.end(); + for (; it != end; ++it) + (*it)->update(); + _dirty = false; } @@ -414,9 +418,10 @@ bool OtkWidget::configure(const XConfigureEvent &e) _ignore_config--; } else { std::cout << "configure\n"; - if (!(e.width == width() && e.height == height())) + if (!(e.width == _rect.width() && e.height == _rect.height())) { _dirty = true; - _rect.setRect(e.x, e.y, e.width, e.height); + _rect.setSize(e.width, e.height); + } update(); } return true;