1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-25 00:53:52 +00:00
openmw-tes3mp/components/sceneutil/skeleton.hpp

82 lines
2.4 KiB
C++
Raw Normal View History

#ifndef OPENMW_COMPONENTS_NIFOSG_SKELETON_H
#define OPENMW_COMPONENTS_NIFOSG_SKELETON_H
#include <osg/Group>
#include <memory>
2015-04-21 18:30:48 +00:00
namespace SceneUtil
{
2015-04-21 18:42:50 +00:00
/// @brief Defines a Bone hierarchy, used for updating of skeleton-space bone matrices.
/// @note To prevent unnecessary updates, only bones that are used for skinning will be added to this hierarchy.
class Bone
{
public:
Bone();
~Bone();
2015-04-22 15:34:39 +00:00
osg::Matrixf mMatrixInSkeletonSpace;
osg::MatrixTransform* mNode;
std::vector<Bone*> mChildren;
2015-04-21 18:42:50 +00:00
/// Update the skeleton-space matrix of this bone and all its children.
void update(const osg::Matrixf* parentMatrixInSkeletonSpace);
private:
Bone(const Bone&);
void operator=(const Bone&);
};
2015-04-21 18:42:50 +00:00
/// @brief Handles the bone matrices for any number of child RigGeometries.
/// @par Bones should be created as osg::MatrixTransform children of the skeleton.
/// To be a referenced by a RigGeometry, a bone needs to have a unique name.
class Skeleton : public osg::Group
{
public:
Skeleton();
Skeleton(const Skeleton& copy, const osg::CopyOp& copyop);
2015-12-06 14:27:43 +00:00
META_Node(SceneUtil, Skeleton)
2015-04-21 18:42:50 +00:00
/// Retrieve a bone by name.
Bone* getBone(const std::string& name);
/// Request an update of bone matrices. May be a no-op if already updated in this frame.
void updateBoneMatrices(unsigned int traversalNumber);
/// Set the skinning active flag. Inactive skeletons will not have their child rigs updated.
/// You should set this flag to false if you know that bones are not currently moving.
void setActive(bool active);
bool getActive() const;
/// If a new RigGeometry is added after the Skeleton has already been rendered, you must call markDirty().
void markDirty();
void traverse(osg::NodeVisitor& nv);
private:
// The root bone is not a "real" bone, it has no corresponding node in the scene graph.
// As far as the scene graph goes we support multiple root bones.
std::auto_ptr<Bone> mRootBone;
typedef std::map<std::string, std::pair<osg::NodePath, osg::MatrixTransform*> > BoneCache;
BoneCache mBoneCache;
bool mBoneCacheInit;
bool mNeedToUpdateBoneMatrices;
2015-04-21 18:22:32 +00:00
bool mActive;
2015-04-21 18:22:32 +00:00
unsigned int mLastFrameNumber;
bool mTraversedEvenFrame;
bool mTraversedOddFrame;
};
}
#endif