]> git.tdb.fi Git - libs/gl.git/blobdiff - source/scene.cpp
Inherit Loaders from the ObjectLoader classes
[libs/gl.git] / source / scene.cpp
index 20399daff01256e35de5bc87dedeec852dd49131..c28192d407fe529ae2e258700d32243cee654e32 100644 (file)
@@ -5,6 +5,8 @@ Copyright © 2007  Mikko Rasa, Mikkosoft Productions
 Distributed under the LGPL
 */
 
+#include "object.h"
+#include "objectinstance.h"
 #include "scene.h"
 
 using namespace std;
@@ -14,19 +16,35 @@ namespace GL {
 
 void Scene::add(const Renderable &r)
 {
-       renderables.insert(&r);
+       if(const ObjectInstance *oi=dynamic_cast<const ObjectInstance *>(&r))
+               objects[&oi->get_object()].insert(oi);
+       else
+               renderables.insert(&r);
 }
 
 void Scene::remove(const Renderable &r)
 {
-       renderables.erase(&r);
+       if(const ObjectInstance *oi=dynamic_cast<const ObjectInstance *>(&r))
+       {
+               map<const Object *, set<const ObjectInstance *> >::iterator i=objects.find(&oi->get_object());
+               if(i!=objects.end())
+               {
+                       i->second.erase(oi);
+                       if(i->second.empty())
+                               objects.erase(i);
+               }
+       }
+       else
+               renderables.erase(&r);
 }
 
 void Scene::render(const Tag &tag) const
 {
+       for(map<const Object *, set<const ObjectInstance *> >::const_iterator i=objects.begin(); i!=objects.end(); ++i)
+               i->first->render(i->second.begin(), i->second.end(), tag);
+
        for(set<const Renderable *>::const_iterator i=renderables.begin(); i!=renderables.end(); ++i)
-               if((*i)->has_pass(tag))
-                       (*i)->render(tag);
+               (*i)->render(tag);
 }
 
 } // namespace GL