]> git.tdb.fi Git - libs/gltk.git/blobdiff - source/lineararrangement.cpp
Change Root::render to use the passed in Renderer
[libs/gltk.git] / source / lineararrangement.cpp
index 7769db2d64e47af8384237cc4b1eff8e80f6fc21..fb2e71c180dac87aa81c41ec3fce0d6c80b06a4b 100644 (file)
@@ -9,7 +9,9 @@ LinearArrangement::LinearArrangement(Layout &l, Side p):
        opposite(static_cast<Side>((primary+2)%4)),
        first(true),
        split_here(false),
-       gravity(opposite)
+       gravity(opposite),
+       internal_aligned(false),
+       next_spacing(-1)
 { }
 
 void LinearArrangement::split()
@@ -34,12 +36,17 @@ void LinearArrangement::expand()
        gravity = primary;
 }
 
+void LinearArrangement::spacing(unsigned s)
+{
+       next_spacing = s;
+}
+
 void LinearArrangement::process_widget(Widget &wdg, Side side, bool aligned)
 {
        if(side==opposite)
        {
                bool snug = (internal_aligned && aligned && !split_here);
-               add_constraint(wdg, get_order_constraint(primary, !snug), primary);
+               add_constraint(wdg, get_order_constraint(primary, !snug), primary, next_spacing);
                if(first)
                        edges[side].add(wdg, (aligned && gravity==opposite));
        }
@@ -62,6 +69,7 @@ void LinearArrangement::finish_slot()
        next.clear();
        split_here = false;
        first = false;
+       next_spacing = -1;
 }
 
 
@@ -69,6 +77,7 @@ LinearArrangement::Loader::Loader(LinearArrangement &c):
        DataFile::ObjectLoader<LinearArrangement>(c)
 {
        add("expand", &Loader::expand);
+       add("spacing", &Loader::spacing);
        add("split", &Loader::split);
 }
 
@@ -77,6 +86,11 @@ void LinearArrangement::Loader::expand()
        obj.expand();
 }
 
+void LinearArrangement::Loader::spacing(unsigned s)
+{
+       obj.spacing(s);
+}
+
 void LinearArrangement::Loader::split()
 {
        obj.split();