X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Frender%2Forderedscene.cpp;h=bf1a62481310d4b5fe9e556ee24cdb27b9d8b25a;hb=77a534371433054384d213922a2e8c55f8a69ad6;hp=4386d3e79058f2ac7559f2f30ee1bcc92bce60d4;hpb=233dff2a6c552e08da832496aecd88ef4f8948f1;p=libs%2Fgl.git diff --git a/source/render/orderedscene.cpp b/source/render/orderedscene.cpp index 4386d3e7..bf1a6248 100644 --- a/source/render/orderedscene.cpp +++ b/source/render/orderedscene.cpp @@ -1,4 +1,4 @@ -#include +#include #include "orderedscene.h" #include "renderer.h" @@ -12,53 +12,52 @@ void OrderedScene::add(Renderable &r) void OrderedScene::remove(Renderable &r) { - RenderableList::iterator end = std::remove(renderables.begin(), renderables.end(), &r); + auto end = std::remove(renderables.begin(), renderables.end(), &r); renderables.erase(end, renderables.end()); } void OrderedScene::prepend(Renderable &r) { - renderables.push_front(&r); + renderables.insert(renderables.begin(), &r); } void OrderedScene::insert(unsigned index, Renderable &r) { - RenderableList::iterator i = renderables.begin(); + auto i = renderables.begin(); for(; (i!=renderables.end() && index); ++i, --index) ; renderables.insert(i, &r); } void OrderedScene::insert_after(Renderable &after, Renderable &r) { - RenderableList::iterator i = renderables.begin(); - for(; (i!=renderables.end() && *i!=&after); ++i) ; + auto i = find(renderables, &after); renderables.insert(i, &r); } void OrderedScene::setup_frame(Renderer &renderer) { - for(RenderableList::const_iterator i=renderables.begin(); i!=renderables.end(); ++i) - (*i)->setup_frame(renderer); + for(Renderable *r: renderables) + r->setup_frame(renderer); } void OrderedScene::finish_frame() { - for(RenderableList::const_iterator i=renderables.begin(); i!=renderables.end(); ++i) - (*i)->finish_frame(); + for(Renderable *r: renderables) + r->finish_frame(); } void OrderedScene::render(Renderer &renderer, Tag tag) const { if(setup_frustum(renderer)) { - for(RenderableList::const_iterator i=renderables.begin(); i!=renderables.end(); ++i) - if(!frustum_cull(**i)) - renderer.render(**i, tag); + for(Renderable *r: renderables) + if(!frustum_cull(*r)) + renderer.render(*r, tag); } else { - for(RenderableList::const_iterator i=renderables.begin(); i!=renderables.end(); ++i) - renderer.render(**i, tag); + for(Renderable *r: renderables) + renderer.render(*r, tag); } }