2015-02-23 21:06:10 +01:00
|
|
|
#ifndef OPENMW_COMPONENTS_NIFOSG_LOADER
|
|
|
|
#define OPENMW_COMPONENTS_NIFOSG_LOADER
|
|
|
|
|
|
|
|
#include <components/nif/niffile.hpp>
|
|
|
|
|
|
|
|
#include <components/nifcache/nifcache.hpp> // NIFFilePtr
|
|
|
|
|
2015-03-17 21:59:39 +01:00
|
|
|
#include <components/vfs/manager.hpp>
|
|
|
|
|
2015-03-23 16:17:40 +01:00
|
|
|
#include <osg/ref_ptr>
|
|
|
|
|
2015-02-23 21:06:10 +01:00
|
|
|
namespace osg
|
|
|
|
{
|
2015-03-23 01:57:03 +01:00
|
|
|
class Node;
|
2015-02-23 21:06:10 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
namespace NifOsg
|
|
|
|
{
|
2015-03-23 01:31:16 +01:00
|
|
|
typedef std::multimap<float,std::string> TextKeyMap;
|
|
|
|
|
2015-02-23 21:06:10 +01:00
|
|
|
/// The main class responsible for loading NIF files into an OSG-Scenegraph.
|
2015-03-23 17:49:06 +01:00
|
|
|
/// @par This scene graph is self-contained and can be cloned using osg::clone if desired. Particle emitters
|
|
|
|
/// and programs hold a pointer to their ParticleSystem, which would need to be manually updated when cloning.
|
2015-02-23 21:06:10 +01:00
|
|
|
class Loader
|
|
|
|
{
|
|
|
|
public:
|
2015-03-23 01:31:16 +01:00
|
|
|
// TODO: add auto-detection for skinning. We will still need a "force skeleton" parameter
|
|
|
|
// though, when assembling from several files, i.e. equipment parts
|
|
|
|
/// Create a scene graph for the given NIF. Assumes no skinning is used.
|
|
|
|
/// @param node The parent of the new root node for the created scene graph.
|
2015-03-23 16:17:40 +01:00
|
|
|
osg::ref_ptr<osg::Node> load(Nif::NIFFilePtr file, TextKeyMap* textKeys = NULL);
|
2015-03-23 01:31:16 +01:00
|
|
|
|
|
|
|
/// Create a scene graph for the given NIF. Assumes skinning will be used.
|
2015-03-23 16:17:40 +01:00
|
|
|
osg::ref_ptr<osg::Node> loadAsSkeleton(Nif::NIFFilePtr file, TextKeyMap* textKeys = NULL);
|
2015-02-23 21:06:10 +01:00
|
|
|
|
2015-03-23 01:31:16 +01:00
|
|
|
/// Load keyframe controllers from the given kf file onto the given scene graph.
|
|
|
|
/// @param sourceIndex The source index for this animation source, used for identifying
|
|
|
|
/// which animation source a keyframe controller came from.
|
2015-03-23 01:51:44 +01:00
|
|
|
void loadKf(Nif::NIFFilePtr kf, osg::Node* rootNode, int sourceIndex, TextKeyMap &textKeys);
|
2015-02-23 21:06:10 +01:00
|
|
|
|
2015-03-23 01:57:03 +01:00
|
|
|
/// Set whether or not nodes marked as "MRK" should be shown.
|
|
|
|
/// These should be hidden ingame, but visible in the editior.
|
|
|
|
/// Default: false.
|
|
|
|
static void setShowMarkers(bool show);
|
|
|
|
|
2015-03-20 00:39:24 +01:00
|
|
|
const VFS::Manager* resourceManager;
|
2015-02-23 21:06:10 +01:00
|
|
|
|
|
|
|
private:
|
|
|
|
|
2015-03-23 01:57:03 +01:00
|
|
|
static bool sShowMarkers;
|
2015-02-23 21:06:10 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|