X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpart.cpp;h=72c8921b1c03663181645623ac8485386afe83e8;hb=202abf876bc54c0f82c1afcd26b3b79fd1cd4815;hp=a92e7208ca6883015cd978eb5c9218700538faec;hpb=ed9873ba7ee862ad76937f579fe371c1a27d5715;p=libs%2Fgltk.git diff --git a/source/part.cpp b/source/part.cpp index a92e720..72c8921 100644 --- a/source/part.cpp +++ b/source/part.cpp @@ -1,13 +1,7 @@ -/* $Id$ - -This file is part of libmspgltk -Copyright © 2007 Mikko Rasa, Mikkosoft Productions -Distributed under the LGPL -*/ - -#include +#include #include "geometry.h" #include "part.h" +#include "partcache.h" #include "resources.h" using namespace std; @@ -16,83 +10,88 @@ namespace Msp { namespace GLtk { Part::Part(const string &n): - name(n), - fill_x(true), - fill_y(true) + 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 &parent, State state) const +void Part::build(const Geometry &parent, State state, PartCache &cache) const { - if(!graphic[state]) + if(!graphic[state] || !graphic[state]->get_texture()) return; - Geometry rgeom=geom; - if(fill_x) - rgeom.w=parent.w-margin.left-margin.right; - if(fill_y) - rgeom.h=parent.h-margin.bottom-margin.top; + Geometry rgeom = geom; align.apply(rgeom, parent, margin); - GL::translate(rgeom.x, rgeom.y, 0); - graphic[state]->render(rgeom.w, rgeom.h); + 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, Resources &r): - part(p), - res(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; iget_shadow(); - 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); + const Graphic &grph = *obj.graphic[i]; + const Sides &shadow = grph.get_shadow(); + obj.geom.w = max(obj.geom.w, grph.get_width()-shadow.left-shadow.right); + obj.geom.h = max(obj.geom.h, grph.get_height()-shadow.bottom-shadow.top); } - else - part.graphic[i]=part.graphic[NORMAL]; - } +} + +void Part::Loader::graphic_normal(const string &n) +{ + graphic(NORMAL, n); } void Part::Loader::graphic(State s, const string &n) { - part.graphic[s]=res.get(n); + Graphic *grph = (n.empty() ? 0 : &get_collection().get(n)); + for(int i=0; i