X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgeometry.cpp;h=0cb78ffcc392d636a45a7e7469d4ea5690601bbb;hb=c8291177b545ec81930603a5915234a60296db51;hp=0e46743b626ecf9edfffaa3b2b2de00bd0d2d25b;hpb=3db68f2604b657e79f1b2b317c19c41c2d5a985b;p=libs%2Fgltk.git diff --git a/source/geometry.cpp b/source/geometry.cpp index 0e46743..0cb78ff 100644 --- a/source/geometry.cpp +++ b/source/geometry.cpp @@ -1,10 +1,3 @@ -/* $Id$ - -This file is part of libmspgltk -Copyright © 2007 Mikko Rasa, Mikkosoft Productions -Distributed under the LGPL -*/ - #include "geometry.h" namespace Msp { @@ -28,49 +21,83 @@ Sides::Sides(): left(0) { } +Sides::Sides(unsigned s): + top(s), + right(s), + bottom(s), + left(s) +{ } + +Sides::Sides(unsigned v, unsigned h): + top(v), + right(h), + bottom(v), + left(h) +{ } + +Sides::Sides(unsigned t, unsigned h, unsigned b): + top(t), + right(h), + bottom(b), + left(h) +{ } + +Sides::Sides(unsigned t, unsigned r, unsigned b, unsigned l): + top(t), + right(r), + bottom(b), + left(l) +{ } + Sides::Loader::Loader(Sides &s): - sides(s) + DataFile::ObjectLoader(s) { + add("horizontal", &Loader::horizontal); + add("vertical", &Loader::vertical); add("top", &Sides::top); add("right", &Sides::right); add("bottom", &Sides::bottom); add("left", &Sides::left); } +void Sides::Loader::horizontal(unsigned h) +{ + obj.right = h; + obj.left = h; +} + +void Sides::Loader::vertical(unsigned v) +{ + obj.top = v; + obj.bottom = v; +} + void Alignment::apply(Geometry &geom, const Geometry &parent) const { if(parent.w>geom.w) { - geom.w+=static_cast((parent.w-geom.w)*w); - geom.x+=static_cast((parent.w-geom.w)*x); + geom.w += static_cast((parent.w-geom.w)*w); + geom.x += static_cast((parent.w-geom.w)*x); } if(parent.h>geom.h) { - geom.h+=static_cast((parent.h-geom.h)*h); - geom.y+=static_cast((parent.h-geom.h)*y); + geom.h += static_cast((parent.h-geom.h)*h); + geom.y += static_cast((parent.h-geom.h)*y); } } void Alignment::apply(Geometry &geom, const Geometry &parent, const Sides &margin) const { - unsigned pw=parent.w-margin.left-margin.right; - unsigned ph=parent.h-margin.bottom-margin.top; + Geometry content = parent; + content.w -= margin.left+margin.right; + content.h -= margin.bottom+margin.top; - geom.x+=margin.left; - geom.y+=margin.bottom; + geom.x += margin.left; + geom.y += margin.bottom; - if(pw>geom.w) - { - geom.w+=static_cast((pw-geom.w)*w); - geom.x+=static_cast((pw-geom.w)*x); - } - if(ph>geom.h) - { - geom.h+=static_cast((ph-geom.h)*h); - geom.y+=static_cast((ph-geom.h)*y); - } + apply(geom, content); } } // namespace GLtk