X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpart.cpp;h=4726b4c007daed4e665d64b13cadf76e28e8fc2b;hb=601e9fbcfdb26b53aff4d44805bb596f0b73208a;hp=38e75d7c034d4526f08662ec732deb7d8493f83d;hpb=c1f038acb91eb3bfaa34dfd4729d19ed3f871a42;p=libs%2Fgltk.git diff --git a/source/part.cpp b/source/part.cpp index 38e75d7..4726b4c 100644 --- a/source/part.cpp +++ b/source/part.cpp @@ -1,5 +1,7 @@ +#include #include "geometry.h" #include "part.h" +#include "partcache.h" #include "resources.h" using namespace std; @@ -7,63 +9,89 @@ using namespace std; namespace Msp { namespace GLtk { -Part::Part(const Resources &r, const string &n): - res(r), - name(n), - fill_x(true), - fill_y(true) +Part::Part(const string &n): + name(n) { - for(unsigned i=0; i(0)); } const Graphic *Part::get_graphic(State state) const { if(state>N_STATES_) - throw InvalidParameterValue("Invalid state"); + throw invalid_argument("Part::get_graphic"); return graphic[state]; } -void Part::render(const Geometry &geom, State state) const +void Part::build(const Geometry &parent, State state, PartCache &cache) const { - const Graphic::Sides &shadow=graphic[state]->get_shadow(); - unsigned gw=(fill_x ? geom.w : graphic[state]->get_width())-shadow.left-shadow.right; - unsigned gh=(fill_y ? geom.h : graphic[state]->get_height())-shadow.top-shadow.bottom; - align.apply(geom, gw, gh); - graphic[state]->render(gw, gh); + if(!graphic[state] || !graphic[state]->get_texture()) + return; + + Geometry rgeom = geom; + align.apply(rgeom, parent, margin); + GL::MeshBuilder bld(cache.create_mesh(*this, *graphic[state]->get_texture())); + bld.matrix() *= GL::Matrix::translation(rgeom.x, rgeom.y, 0); + graphic[state]->build(rgeom.w, rgeom.h, bld); } -Part::Loader::Loader(Part &p): - part(p) +Part::Loader::Loader(Part &p, Resources &r): + DataFile::CollectionObjectLoader(p, &r) { add("graphic", &Loader::graphic); add("align", &Loader::align); add("fill", &Loader::fill); + add("margin", &Loader::margin); + add("size", &Loader::size); +} + +Part::Loader::~Loader() +{ + for(unsigned i=0; i(n); + for(int i=0; i