X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Finstancescene.cpp;h=b533bae5fac75e843bf23604004e7169676a0513;hp=e3e63767243a1a88ba1ea98655bb480b6ad4584b;hb=7a2427020ec6ead73258aeb326dfb7e0121520f9;hpb=9addd3d476245415244e59333a36a8fc0eae42bf diff --git a/source/instancescene.cpp b/source/instancescene.cpp index e3e63767..b533bae5 100644 --- a/source/instancescene.cpp +++ b/source/instancescene.cpp @@ -1,48 +1,56 @@ -/* $Id$ - -This file is part of libmspgl -Copyright © 2007-2008, 2010 Mikko Rasa, Mikkosoft Productions -Distributed under the LGPL -*/ - #include "object.h" #include "objectinstance.h" #include "instancescene.h" +#include "renderer.h" namespace Msp { namespace GL { -void InstanceScene::add(const Renderable &r) +void InstanceScene::add(Renderable &r) { - if(const ObjectInstance *oi = dynamic_cast(&r)) - objects[&oi->get_object()].insert(oi); - else - renderables.insert(&r); + renderables[r.get_instance_key()].insert(&r); } -void InstanceScene::remove(const Renderable &r) +void InstanceScene::remove(Renderable &r) { - if(const ObjectInstance *oi = dynamic_cast(&r)) + InstanceMap::iterator i = renderables.find(r.get_instance_key()); + if(i!=renderables.end()) { - ObjectMap::iterator i = objects.find(&oi->get_object()); - if(i!=objects.end()) - { - i->second.erase(oi); - if(i->second.empty()) - objects.erase(i); - } + i->second.erase(&r); + if(i->second.empty()) + renderables.erase(i); } - else - renderables.erase(&r); } -void InstanceScene::render(const Tag &tag) const +void InstanceScene::setup_frame(Renderer &renderer) +{ + for(InstanceMap::const_iterator i=renderables.begin(); i!=renderables.end(); ++i) + for(RenderableSet::const_iterator j=i->second.begin(); j!=i->second.end(); ++j) + (*j)->setup_frame(renderer); +} + +void InstanceScene::finish_frame() { - for(ObjectMap::const_iterator i=objects.begin(); i!=objects.end(); ++i) - i->first->render(i->second.begin(), i->second.end(), tag); + for(InstanceMap::const_iterator i=renderables.begin(); i!=renderables.end(); ++i) + for(RenderableSet::const_iterator j=i->second.begin(); j!=i->second.end(); ++j) + (*j)->finish_frame(); +} - for(RenderableSet::const_iterator i=renderables.begin(); i!=renderables.end(); ++i) - (*i)->render(tag); +void InstanceScene::render(Renderer &renderer, const Tag &tag) const +{ + if(setup_frustum(renderer)) + { + for(InstanceMap::const_iterator i=renderables.begin(); i!=renderables.end(); ++i) + for(RenderableSet::const_iterator j=i->second.begin(); j!=i->second.end(); ++j) + if(!frustum_cull(**j)) + renderer.render(**j, tag); + } + else + { + for(InstanceMap::const_iterator i=renderables.begin(); i!=renderables.end(); ++i) + for(RenderableSet::const_iterator j=i->second.begin(); j!=i->second.end(); ++j) + renderer.render(**j, tag); + } } } // namespace GL