X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpart.cpp;h=a74c91141ca717c86262c8a634f8db75ff359226;hb=c435423919a20a87d100e1ee4cd1fc6ce223040c;hp=f5e4b79ef5c36a674f329fd9ca3dbc9a575c5e1c;hpb=c2635c5a3dca6a6cea5562fd387beb0662b18cf0;p=libs%2Fgltk.git diff --git a/source/part.cpp b/source/part.cpp index f5e4b79..a74c911 100644 --- a/source/part.cpp +++ b/source/part.cpp @@ -5,6 +5,7 @@ Copyright © 2007 Mikko Rasa, Mikkosoft Productions Distributed under the LGPL */ +#include #include "geometry.h" #include "part.h" #include "resources.h" @@ -15,11 +16,7 @@ namespace Msp { namespace GLtk { Part::Part(const string &n): - name(n), - width(1), - height(1), - fill_x(true), - fill_y(true) + name(n) { for(unsigned i=0; irender(gw, gh); + if(!graphic[state]) + return; + + Geometry rgeom=geom; + align.apply(rgeom, parent, margin); + GL::translate(rgeom.x, rgeom.y, 0); + graphic[state]->render(rgeom.w, rgeom.h); } @@ -49,6 +49,8 @@ Part::Loader::Loader(Part &p, Resources &r): add("graphic", &Loader::graphic); add("align", &Loader::align); add("fill", &Loader::fill); + add("margin", &Loader::margin); + add("size", &Loader::size); } Part::Loader::~Loader() @@ -58,8 +60,8 @@ Part::Loader::~Loader() if(part.graphic[i]) { const Sides &shadow=part.graphic[i]->get_shadow(); - part.width=max(part.width, part.graphic[i]->get_width()-shadow.left-shadow.right); - part.height=max(part.height, part.graphic[i]->get_height()-shadow.bottom-shadow.top); + part.geom.w=max(part.geom.w, part.graphic[i]->get_width()-shadow.left-shadow.right); + part.geom.h=max(part.geom.h, part.graphic[i]->get_height()-shadow.bottom-shadow.top); } else part.graphic[i]=part.graphic[NORMAL]; @@ -71,16 +73,27 @@ void Part::Loader::graphic(State s, const string &n) part.graphic[s]=res.get(n); } -void Part::Loader::align(int x, int y) +void Part::Loader::align(float x, float y) { part.align.x=x; part.align.y=y; } -void Part::Loader::fill(bool x, bool y) +void Part::Loader::fill(float w, float h) +{ + part.align.w=w; + part.align.h=h; +} + +void Part::Loader::margin() +{ + load_sub(part.margin); +} + +void Part::Loader::size(unsigned w, unsigned h) { - part.fill_x=x; - part.fill_y=y; + part.geom.w=w; + part.geom.h=h; } } // namespace GLtk