X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fscene.h;h=639a467fa849cb526c19ac31744b957f820af7ea;hp=a04fbc01f9a304c5969759fd6afc6380af52b8fe;hb=aa9873652630db493b5bd9faee4117e9c30ef226;hpb=0a20dd14a0d1fd027a7d411b4d427bd4252342cc diff --git a/source/scene.h b/source/scene.h index a04fbc01..639a467f 100644 --- a/source/scene.h +++ b/source/scene.h @@ -1,7 +1,7 @@ #ifndef MSP_GL_SCENE_H_ #define MSP_GL_SCENE_H_ -#include +#include #include #include "matrix.h" #include "renderable.h" @@ -21,14 +21,24 @@ public: class Loader: public DataFile::CollectionObjectLoader { public: - Loader(Scene &, Collection &); + typedef std::map ContentMap; private: + ContentMap *content; + + public: + Loader(Scene &, Collection &); + Loader(Scene &, Collection &, ContentMap &); + private: + void init(); + void object(const std::string &); + void object_tagged(const std::string &, const std::string &); }; protected: - std::list owned_data; + // XXX If a loaded renderable is removed from the scene it needs to be removed from here as well + std::vector owned_data; mutable Matrix culling_matrix; mutable Vector4 frustum_edges[6]; @@ -39,11 +49,8 @@ private: public: virtual ~Scene(); - virtual void add(const Renderable &) = 0; - virtual void remove(const Renderable &) = 0; - - using Renderable::render; - virtual void render(const Tag & = Tag()) const; + virtual void add(Renderable &) = 0; + virtual void remove(Renderable &) = 0; protected: bool setup_frustum(const Renderer &) const;