X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpartcache.cpp;h=4747cb50b3e585fd45bb6a5be8fe864bd2937266;hb=2a665655a15f73d59083fd5cc7e5a58ae5f4d377;hp=e270dc4775eef4f005161304587fa3c58d17f915;hpb=1aa6cd9b865e366737dcc9d2d36c4f8faed5bc4f;p=libs%2Fgltk.git diff --git a/source/partcache.cpp b/source/partcache.cpp index e270dc4..4747cb5 100644 --- a/source/partcache.cpp +++ b/source/partcache.cpp @@ -1,9 +1,13 @@ +#include "part.h" #include "partcache.h" +using namespace std; + namespace Msp { namespace GLtk { CachedPart::CachedPart(): + part(0), texture(0), mesh(0) { } @@ -13,12 +17,66 @@ CachedPart::~CachedPart() delete mesh; } -void CachedPart::clear_mesh() + +void PartCache::begin_rebuild() +{ + next = parts.begin(); + current = parts.end(); +} + +void PartCache::insert_special(const Part &part) { - if(!mesh) - mesh = new GL::Mesh((GL::TEXCOORD2, GL::COLOR4_UBYTE, GL::VERTEX2)); + if(part.get_name().empty()) + throw invalid_argument("PartCache::insert_special"); + + for(current=next; current!=parts.end(); ++current) + if(current->part==&part) + { + parts.erase(next, current); + break; + } + + if(current==parts.end()) + current = parts.insert(next, CachedPart()); else - mesh->clear(); + *current = CachedPart(); + current->part = ∂ + + next = current; + ++next; +} + +GL::Mesh &PartCache::create_mesh(const Part &part, const GL::Texture2D &tex) +{ + if(current!=parts.end() && current->texture==&tex) + return *current->mesh; + + for(current=next; current!=parts.end(); ++current) + if(current->texture==&tex) + { + parts.erase(next, current); + break; + } + + if(current==parts.end()) + { + current = parts.insert(next, CachedPart()); + current->texture = &tex; + current->mesh = new GL::Mesh((GL::TEXCOORD2, GL::COLOR4_UBYTE, GL::VERTEX2)); + } + else + current->mesh->clear(); + current->part = ∂ + + next = current; + ++next; + + return *current->mesh; +} + +void PartCache::end_rebuild() +{ + parts.erase(next, parts.end()); } } // namespace GLtk