openmw-tes3coop/components/resource/scenemanager.hpp

96 lines
3.1 KiB
C++
Raw Permalink Normal View History

2015-03-26 17:02:51 +00:00
#ifndef OPENMW_COMPONENTS_RESOURCE_SCENEMANAGER_H
#define OPENMW_COMPONENTS_RESOURCE_SCENEMANAGER_H
#include <string>
#include <map>
#include <osg/ref_ptr>
#include <osg/Node>
namespace Resource
{
class TextureManager;
}
2015-03-26 17:02:51 +00:00
namespace VFS
{
class Manager;
}
namespace NifOsg
{
class KeyframeHolder;
}
namespace osgUtil
{
class IncrementalCompileOperation;
}
2015-03-26 17:02:51 +00:00
namespace Resource
{
/// @brief Handles loading and caching of scenes, e.g. NIF files
class SceneManager
{
public:
SceneManager(const VFS::Manager* vfs, Resource::TextureManager* textureManager);
2015-05-08 15:52:35 +00:00
~SceneManager();
2015-03-26 17:02:51 +00:00
/// Get a read-only copy of this scene "template"
/// @note If the given filename does not exist or fails to load, an error marker mesh will be used instead.
/// If even the error marker mesh can not be found, an exception is thrown.
2015-03-26 17:02:51 +00:00
osg::ref_ptr<const osg::Node> getTemplate(const std::string& name);
/// Create an instance of the given scene template
/// @see getTemplate
osg::ref_ptr<osg::Node> createInstance(const std::string& name);
/// Create an instance of the given scene template and immediately attach it to a parent node
/// @see getTemplate
osg::ref_ptr<osg::Node> 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;
2015-03-26 17:02:51 +00:00
/// Get a read-only copy of the given keyframe file.
osg::ref_ptr<const NifOsg::KeyframeHolder> 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);
/// Set up an IncrementalCompileOperation for background compiling of loaded scenes.
void setIncrementalCompileOperation(osgUtil::IncrementalCompileOperation* ico);
2015-06-01 14:25:15 +00:00
/// @note If you used SceneManager::attachTo, this was called automatically.
void notifyAttached(osg::Node* node) const;
const VFS::Manager* getVFS() const;
Resource::TextureManager* getTextureManager();
2015-03-26 17:02:51 +00:00
private:
const VFS::Manager* mVFS;
Resource::TextureManager* mTextureManager;
2015-03-26 17:02:51 +00:00
osg::ref_ptr<osgUtil::IncrementalCompileOperation> mIncrementalCompileOperation;
2015-03-26 17:02:51 +00:00
// observer_ptr?
typedef std::map<std::string, osg::ref_ptr<const osg::Node> > Index;
Index mIndex;
typedef std::map<std::string, osg::ref_ptr<const NifOsg::KeyframeHolder> > KeyframeIndex;
KeyframeIndex mKeyframeIndex;
2015-05-08 15:52:35 +00:00
SceneManager(const SceneManager&);
void operator = (const SceneManager&);
2015-03-26 17:02:51 +00:00
};
}
#endif