X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fsimplescene.cpp;h=b8c90517082ece5db4e1159d6f25dfaf8aef7c7e;hp=f866f678280b2b4b2786aa2f5920fb9b816472fc;hb=3b159edbe4e80a2bc19c4c2fcd42cb996b9fbfe0;hpb=db498c7e634fa999cf4b4a8b67c49813009b1790 diff --git a/source/simplescene.cpp b/source/simplescene.cpp index f866f678..b8c90517 100644 --- a/source/simplescene.cpp +++ b/source/simplescene.cpp @@ -6,30 +6,53 @@ namespace GL { void SimpleScene::add(const Renderable &r) { - renderables.insert(&r); + // Add to cache as well if the cache is valid + if(renderables.insert(&r).second && !cache.empty()) + cache.push_back(&r); } void SimpleScene::remove(const Renderable &r) { renderables.erase(&r); + cache.clear(); +} + +void SimpleScene::populate_cache() const +{ + if(cache.empty() && !renderables.empty()) + { + cache.reserve(renderables.size()); + cache.insert(cache.end(), renderables.begin(), renderables.end()); + } } void SimpleScene::setup_frame() const { - for(RenderableSet::const_iterator i=renderables.begin(); i!=renderables.end(); ++i) + populate_cache(); + for(RenderableArray::const_iterator i=cache.begin(); i!=cache.end(); ++i) (*i)->setup_frame(); } void SimpleScene::finish_frame() const { - for(RenderableSet::const_iterator i=renderables.begin(); i!=renderables.end(); ++i) + for(RenderableArray::const_iterator i=cache.begin(); i!=cache.end(); ++i) (*i)->finish_frame(); } void SimpleScene::render(Renderer &renderer, const Tag &tag) const { - for(RenderableSet::const_iterator i=renderables.begin(); i!=renderables.end(); ++i) - renderer.render(**i, tag); + populate_cache(); + if(setup_frustum(renderer)) + { + for(RenderableArray::const_iterator i=cache.begin(); i!=cache.end(); ++i) + if(!frustum_cull(**i)) + renderer.render(**i, tag); + } + else + { + for(RenderableArray::const_iterator i=cache.begin(); i!=cache.end(); ++i) + renderer.render(**i, tag); + } } } // namespace GL