X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fgeometry.cpp;h=8163022ccdc981220280c938864427afb66c4630;hb=0af3c2393bd00f39db3bfaf5b78a7a44f0fd5ff1;hp=81efcd05bad2e69d22325eb3e7df851f638d3644;hpb=ed9873ba7ee862ad76937f579fe371c1a27d5715;p=libs%2Fgltk.git diff --git a/source/geometry.cpp b/source/geometry.cpp index 81efcd0..8163022 100644 --- a/source/geometry.cpp +++ b/source/geometry.cpp @@ -15,6 +15,11 @@ bool Geometry::is_inside(int x_, int y_) const return (x_>=x && x_(w) && y_>=y && y_(h)); } +bool Geometry::is_inside_relative(int x_, int y_) const +{ + return (x_>=0 && x_(w) && y_>=0 && y_(h)); +} + Sides::Sides(): top(0), @@ -36,14 +41,36 @@ Sides::Loader::Loader(Sides &s): void Alignment::apply(Geometry &geom, const Geometry &parent) const { - geom.x+=static_cast((parent.w-geom.w)*x); - geom.y+=static_cast((parent.h-geom.h)*y); + if(parent.w>geom.w) + { + 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); + } } void Alignment::apply(Geometry &geom, const Geometry &parent, const Sides &margin) const { - geom.x+=static_cast(margin.left+(parent.w-margin.left-margin.right-geom.w)*x); - geom.y+=static_cast(margin.bottom+(parent.h-margin.bottom-margin.top-geom.h)*y); + unsigned pw = parent.w-margin.left-margin.right; + unsigned ph = parent.h-margin.bottom-margin.top; + + 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); + } } } // namespace GLtk