X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Frender%2Fscene.h;h=d07a81da80b82fef2998eed732c4d3aca8bef8b3;hp=e4f5ecdfd070ff81b499696a8f643a5ce61adb00;hb=HEAD;hpb=f19366d32cc29287a2730cfba90893e407754081 diff --git a/source/render/scene.h b/source/render/scene.h index e4f5ecdf..e6115ae5 100644 --- a/source/render/scene.h +++ b/source/render/scene.h @@ -2,7 +2,7 @@ #define MSP_GL_SCENE_H_ #include -#include +#include #include #include "matrix.h" #include "renderable.h" @@ -11,9 +11,15 @@ namespace Msp { namespace GL { /** -Scenes are containers for other Renderables. This is a base class that can't -be instantiated. Examples of available Scene types are SimpleScene, -InstancedScene and OrderedScene. +Container for other renderables. Subclasses provide different ways of +rendering the contents. + +All types of Scenes perform frustum culling on the contents, skipping +renderables whose bounding sphere is fully outside the view volume. If a +bounding sphere cannot be determined, culling is not performed on that +renderable. + +SimpleScene is a good default choice if there are no specific requirements. */ class Scene: public Renderable { @@ -25,7 +31,8 @@ protected: private: ContentMap *content; - unsigned inst_counter; + + static unsigned inline_counter; public: Loader(Scene &s, Collection &c): Loader(s, c, 0) { } @@ -33,66 +40,37 @@ protected: private: Loader(Scene &, Collection &, ContentMap *); + void array(const std::string &); void object(const std::string &); void object_tagged(const std::string &, const std::string &); void scene(const std::string &); + void scene_inline(); }; public: - class GenericLoader: public DataFile::Loader + class GenericLoader: public DataFile::DynamicObjectLoader { - private: - template - struct CreateScene - { - void operator()(const std::string &, GenericLoader &) const; - }; - - DataFile::Collection &coll; - Scene *scene; - Loader *scene_loader; - - static ActionMap shared_actions; + friend class Scene; public: - GenericLoader(DataFile::Collection &); - ~GenericLoader(); - - Scene *get_scene() { Scene *s = scene; scene = 0; return s; } - private: - virtual void init_actions(); + GenericLoader(DataFile::Collection &c): DynamicObjectLoader(&c) { } - void type(const DataFile::Symbol &); - - friend class Scene; + protected: + virtual const TypeRegistry &get_type_registry() const { return get_scene_registry(); } }; -private: - typedef TypeRegistry SceneRegistry; - protected: - mutable Matrix culling_matrix; - mutable Vector4 frustum_edges[6]; - - Scene() { } -private: - Scene(const Scene &); - Scene &operator=(const Scene &); + Scene() = default; public: - virtual ~Scene() { } + virtual ~Scene() = default; virtual void add(Renderable &) = 0; virtual void remove(Renderable &) = 0; -protected: - bool setup_frustum(const Renderer &) const; - bool frustum_cull(const Renderable &) const; - -public: template static void register_type(const std::string &); private: - static SceneRegistry &get_scene_registry(); + static GenericLoader::TypeRegistry &get_scene_registry(); }; template @@ -101,18 +79,6 @@ void Scene::register_type(const std::string &kw) get_scene_registry().register_type(kw); } -template -void Scene::GenericLoader::CreateScene::operator()(const std::string &, GenericLoader &ldr) const -{ - if(ldr.scene) - throw std::logic_error("Scene type was already specified"); - - T *scene = new T; - ldr.scene = scene; - ldr.scene_loader = new typename T::Loader(*scene, ldr.coll); - ldr.add_auxiliary_loader(*ldr.scene_loader); -} - } // namespace GL } // namespace Msp