X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Farrangement.cpp;h=9982691e4cb0a81a3fdedb6c891739ce1a198701;hb=1bc84ded58379ee24315db8784d9fb710a02e24e;hp=ec890efb7e08d55f8802c0c20f434e7a4e9bdfba;hpb=646af3dd91a6ca981572a5b69a0f0bd205d9af49;p=libs%2Fgltk.git diff --git a/source/arrangement.cpp b/source/arrangement.cpp index ec890ef..9982691 100644 --- a/source/arrangement.cpp +++ b/source/arrangement.cpp @@ -45,7 +45,32 @@ void Arrangement::add_constraint(Widget &wdg, Layout::ConstraintType type, Side void Arrangement::add_constraint(Widget &wdg, Layout::ConstraintType type, const Edge &edge) { for(list::const_iterator i=edge.widgets.begin(); i!=edge.widgets.end(); ++i) - layout.add_constraint(wdg, type, **i); + if(*i!=&wdg) + layout.add_constraint(wdg, type, **i); +} + +Layout::ConstraintType Arrangement::get_order_constraint(Side s, bool slack) +{ + switch(s) + { + case TOP: return (slack ? Layout::FAR_ABOVE : Layout::ABOVE); + case RIGHT: return (slack ? Layout::FAR_RIGHT_OF : Layout::RIGHT_OF); + case BOTTOM: return (slack ? Layout::FAR_BELOW : Layout::BELOW); + case LEFT: return (slack ? Layout::FAR_LEFT_OF : Layout::LEFT_OF); + default: throw invalid_argument("Arrangement::get_align_constraint"); + } +} + +Layout::ConstraintType Arrangement::get_align_constraint(Side s) +{ + switch(s) + { + case TOP: return Layout::ALIGN_TOP; + case RIGHT: return Layout::ALIGN_RIGHT; + case BOTTOM: return Layout::ALIGN_BOTTOM; + case LEFT: return Layout::ALIGN_LEFT; + default: throw invalid_argument("Arrangement::get_align_constraint"); + } } @@ -71,5 +96,17 @@ void Arrangement::Edge::add(Widget &wdg, bool algn) aligned = algn; } +void Arrangement::Edge::align() +{ + if(aligned || widgets.empty()) + return; + + list::iterator second = widgets.begin(); + ++second; + + widgets.erase(second, widgets.end()); + aligned = true; +} + } // namespace GLtk } // namespace Msp