X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpart.cpp;h=72c8921b1c03663181645623ac8485386afe83e8;hb=HEAD;hp=7037d4b3384374568bc662a9edc1df3299776ba3;hpb=1aa6cd9b865e366737dcc9d2d36c4f8faed5bc4f;p=libs%2Fgltk.git diff --git a/source/part.cpp b/source/part.cpp index 7037d4b..aacc52a 100644 --- a/source/part.cpp +++ b/source/part.cpp @@ -11,10 +11,7 @@ namespace GLtk { Part::Part(const string &n): name(n) -{ - for(unsigned i=0; iget_texture()) return; - } - - cache.texture = graphic[state]->get_texture(); - cache.clear_mesh(); Geometry rgeom = geom; align.apply(rgeom, parent, margin); - GL::MeshBuilder bld(*cache.mesh); - bld.matrix() *= GL::Matrix::translation(rgeom.x, rgeom.y, 0); + GL::MeshBuilder bld(cache.create_mesh(*this, *graphic[state]->get_texture())); + bld.transform(GL::Matrix::translation(rgeom.x, rgeom.y, 0)); graphic[state]->build(rgeom.w, rgeom.h, bld); } @@ -53,7 +44,7 @@ Part::Loader::Loader(Part &p, Resources &r): add("size", &Loader::size); } -Part::Loader::~Loader() +void Part::Loader::finish() { for(unsigned i=0; i(n); + Graphic *grph = (n.empty() ? nullptr : &get_collection().get(n)); for(int i=0; i