#ifndef OPENMW_COMPONENTS_RESOURCE_SCENEMANAGER_H #define OPENMW_COMPONENTS_RESOURCE_SCENEMANAGER_H #include #include #include #include #include namespace Resource { class TextureManager; } namespace VFS { class Manager; } namespace NifOsg { class KeyframeHolder; } namespace Resource { /// @brief Handles loading and caching of scenes, e.g. NIF files class SceneManager { public: SceneManager(const VFS::Manager* vfs, Resource::TextureManager* textureManager); ~SceneManager(); /// Get a read-only copy of this scene "template" osg::ref_ptr getTemplate(const std::string& name); /// Create an instance of the given scene template osg::ref_ptr createInstance(const std::string& name); /// Create an instance of the given scene template and immediately attach it to a parent node osg::ref_ptr createInstance(const std::string& name, osg::Group* parentNode); /// Attach the given scene instance to the given parent node /// @note You should have the parentNode in its intended position before calling this method, /// so that world space particles of the \a instance get transformed correctly. /// @note Assumes the given instance was not attached to any parents before. void attachTo(osg::Node* instance, osg::Group* parentNode) const; /// Get a read-only copy of the given keyframe file. osg::ref_ptr getKeyframes(const std::string& name); /// Manually release created OpenGL objects for the given graphics context. This may be required /// in cases where multiple contexts are used over the lifetime of the application. void releaseGLObjects(osg::State* state); const VFS::Manager* getVFS() const; Resource::TextureManager* getTextureManager(); private: const VFS::Manager* mVFS; Resource::TextureManager* mTextureManager; // observer_ptr? typedef std::map > Index; Index mIndex; typedef std::map > KeyframeIndex; KeyframeIndex mKeyframeIndex; SceneManager(const SceneManager&); void operator = (const SceneManager&); }; } #endif