adds a replacement for osg::NodeCallback (#3144)

* nodecallback.hpp

* lightmanager.hpp

* lightmanager.cpp

* lightmanager.hpp

* nodecallback.hpp

* nodecallback.hpp

* [ci skip]

* lightmanager.hpp

* nodecallback.hpp

* nodecallback.hpp

* lightmanager.cpp

* lightmanager.cpp

* nodecallback.hpp

* [ci skip]

* [ci skip]

* controller.cpp

* [ci skip]

* osgacontroller.cpp

* keyframe.hpp

* controller.hpp

* keyframe.hpp

* [ci skip]

* keyframe.hpp

* animation.hpp

* [ci skip]

* weaponanimation.cpp

* nodecallback.hpp
pull/3146/head
Bo Svensson 3 years ago committed by GitHub
parent 0e07fc38e5
commit aaf7b423d6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -245,7 +245,7 @@ protected:
// Keep track of controllers that we added to our scene graph. // Keep track of controllers that we added to our scene graph.
// We may need to rebuild these controllers when the active animation groups / sources change. // We may need to rebuild these controllers when the active animation groups / sources change.
std::vector<std::pair<osg::ref_ptr<osg::Node>, osg::ref_ptr<osg::NodeCallback>>> mActiveControllers; std::vector<std::pair<osg::ref_ptr<osg::Node>, osg::ref_ptr<osg::Callback>>> mActiveControllers;
std::shared_ptr<AnimationTime> mAnimationTimePtr[sNumBlendMasks]; std::shared_ptr<AnimationTime> mAnimationTimePtr[sNumBlendMasks];

@ -173,7 +173,7 @@ void WeaponAnimation::releaseArrow(MWWorld::Ptr actor, float attackStrength)
} }
void WeaponAnimation::addControllers(const std::map<std::string, osg::ref_ptr<osg::MatrixTransform> >& nodes, void WeaponAnimation::addControllers(const std::map<std::string, osg::ref_ptr<osg::MatrixTransform> >& nodes,
std::vector<std::pair<osg::ref_ptr<osg::Node>, osg::ref_ptr<osg::NodeCallback>>> &map, osg::Node* objectRoot) std::vector<std::pair<osg::ref_ptr<osg::Node>, osg::ref_ptr<osg::Callback>>> &map, osg::Node* objectRoot)
{ {
for (int i=0; i<2; ++i) for (int i=0; i<2; ++i)
{ {

@ -43,7 +43,7 @@ namespace MWRender
/// Add WeaponAnimation-related controllers to \a nodes and store the added controllers in \a map. /// Add WeaponAnimation-related controllers to \a nodes and store the added controllers in \a map.
void addControllers(const std::map<std::string, osg::ref_ptr<osg::MatrixTransform> >& nodes, void addControllers(const std::map<std::string, osg::ref_ptr<osg::MatrixTransform> >& nodes,
std::vector<std::pair<osg::ref_ptr<osg::Node>, osg::ref_ptr<osg::NodeCallback>>>& map, osg::Node* objectRoot); std::vector<std::pair<osg::ref_ptr<osg::Node>, osg::ref_ptr<osg::Callback>>>& map, osg::Node* objectRoot);
void deleteControllers(); void deleteControllers();

@ -72,6 +72,7 @@ KeyframeController::KeyframeController()
KeyframeController::KeyframeController(const KeyframeController &copy, const osg::CopyOp &copyop) KeyframeController::KeyframeController(const KeyframeController &copy, const osg::CopyOp &copyop)
: SceneUtil::KeyframeController(copy, copyop) : SceneUtil::KeyframeController(copy, copyop)
, SceneUtil::NodeCallback<KeyframeController>(copy, copyop)
, mRotations(copy.mRotations) , mRotations(copy.mRotations)
, mXRotations(copy.mXRotations) , mXRotations(copy.mXRotations)
, mYRotations(copy.mYRotations) , mYRotations(copy.mYRotations)

@ -7,6 +7,7 @@
#include <components/nif/data.hpp> #include <components/nif/data.hpp>
#include <components/sceneutil/keyframe.hpp> #include <components/sceneutil/keyframe.hpp>
#include <components/sceneutil/nodecallback.hpp>
#include <components/sceneutil/statesetupdater.hpp> #include <components/sceneutil/statesetupdater.hpp>
#include <set> #include <set>
@ -223,7 +224,7 @@ namespace NifOsg
std::vector<FloatInterpolator> mKeyFrames; std::vector<FloatInterpolator> mKeyFrames;
}; };
class KeyframeController : public SceneUtil::KeyframeController class KeyframeController : public SceneUtil::KeyframeController, public SceneUtil::NodeCallback<KeyframeController>
{ {
public: public:
// This is used if there's no interpolator but there is data (Morrowind meshes). // This is used if there's no interpolator but there is data (Morrowind meshes).
@ -241,7 +242,7 @@ namespace NifOsg
osg::Vec3f getTranslation(float time) const override; osg::Vec3f getTranslation(float time) const override;
void operator() (osg::Node*, osg::NodeVisitor*) override; void operator() (osg::Node*, osg::NodeVisitor*);
private: private:
QuaternionInterpolator mRotations; QuaternionInterpolator mRotations;

@ -3,7 +3,7 @@
#include <map> #include <map>
#include <osg/Node> #include <osg/Callback>
#include <components/sceneutil/controller.hpp> #include <components/sceneutil/controller.hpp>
#include <components/sceneutil/textkeymap.hpp> #include <components/sceneutil/textkeymap.hpp>
@ -11,20 +11,18 @@
namespace SceneUtil namespace SceneUtil
{ {
class KeyframeController : public osg::NodeCallback, public SceneUtil::Controller class KeyframeController : public SceneUtil::Controller, public virtual osg::Callback
{ {
public: public:
KeyframeController() {} KeyframeController() {}
KeyframeController(const KeyframeController& copy, const osg::CopyOp& copyop) KeyframeController(const KeyframeController& copy, const osg::CopyOp& copyop)
: osg::NodeCallback(copy, copyop) : osg::Callback(copy, copyop)
, SceneUtil::Controller(copy) , SceneUtil::Controller(copy)
{} {}
META_Object(SceneUtil, KeyframeController) META_Object(SceneUtil, KeyframeController)
virtual osg::Vec3f getTranslation(float time) const { return osg::Vec3f(); } virtual osg::Vec3f getTranslation(float time) const { return osg::Vec3f(); }
virtual void operator() (osg::Node* node, osg::NodeVisitor* nodeVisitor) override { traverse(node, nodeVisitor); }
}; };
/// Wrapper object containing an animation track as a ref-countable osg::Object. /// Wrapper object containing an animation track as a ref-countable osg::Object.

@ -605,19 +605,19 @@ namespace SceneUtil
// Set on a LightSource. Adds the light source to its light manager for the current frame. // Set on a LightSource. Adds the light source to its light manager for the current frame.
// This allows us to keep track of the current lights in the scene graph without tying creation & destruction to the manager. // This allows us to keep track of the current lights in the scene graph without tying creation & destruction to the manager.
class CollectLightCallback : public osg::NodeCallback class CollectLightCallback : public SceneUtil::NodeCallback<CollectLightCallback>
{ {
public: public:
CollectLightCallback() CollectLightCallback()
: mLightManager(nullptr) { } : mLightManager(nullptr) { }
CollectLightCallback(const CollectLightCallback& copy, const osg::CopyOp& copyop) CollectLightCallback(const CollectLightCallback& copy, const osg::CopyOp& copyop)
: osg::NodeCallback(copy, copyop) : SceneUtil::NodeCallback<CollectLightCallback>(copy, copyop)
, mLightManager(nullptr) { } , mLightManager(nullptr) { }
META_Object(SceneUtil, SceneUtil::CollectLightCallback) META_Object(SceneUtil, SceneUtil::CollectLightCallback)
void operator()(osg::Node* node, osg::NodeVisitor* nv) override void operator()(osg::Node* node, osg::NodeVisitor* nv)
{ {
if (!mLightManager) if (!mLightManager)
{ {
@ -637,19 +637,11 @@ namespace SceneUtil
}; };
// Set on a LightManager. Clears the data from the previous frame. // Set on a LightManager. Clears the data from the previous frame.
class LightManagerUpdateCallback : public osg::NodeCallback class LightManagerUpdateCallback : public SceneUtil::NodeCallback<LightManagerUpdateCallback>
{ {
public: public:
LightManagerUpdateCallback()
{ }
LightManagerUpdateCallback(const LightManagerUpdateCallback& copy, const osg::CopyOp& copyop)
: osg::NodeCallback(copy, copyop)
{ }
META_Object(SceneUtil, LightManagerUpdateCallback)
void operator()(osg::Node* node, osg::NodeVisitor* nv) override void operator()(osg::Node* node, osg::NodeVisitor* nv)
{ {
LightManager* lightManager = static_cast<LightManager*>(node); LightManager* lightManager = static_cast<LightManager*>(node);
lightManager->update(nv->getTraversalNumber()); lightManager->update(nv->getTraversalNumber());
@ -1285,12 +1277,10 @@ namespace SceneUtil
mLight[i] = new osg::Light(*copy.mLight[i].get(), copyop); mLight[i] = new osg::Light(*copy.mLight[i].get(), copyop);
} }
void LightListCallback::operator()(osg::Node *node, osg::NodeVisitor *nv) void LightListCallback::operator()(osg::Node *node, osgUtil::CullVisitor *cv)
{ {
osgUtil::CullVisitor* cv = static_cast<osgUtil::CullVisitor*>(nv);
bool pushedState = pushLightState(node, cv); bool pushedState = pushLightState(node, cv);
traverse(node, nv); traverse(node, cv);
if (pushedState) if (pushedState)
cv->popStateSet(); cv->popStateSet();
} }

@ -16,6 +16,7 @@
#include <components/shader/shadermanager.hpp> #include <components/shader/shadermanager.hpp>
#include <components/settings/settings.hpp> #include <components/settings/settings.hpp>
#include <components/sceneutil/nodecallback.hpp>
namespace osgUtil namespace osgUtil
{ {
@ -254,7 +255,7 @@ namespace SceneUtil
/// starting point is to attach a LightListCallback to each game object's base node. /// starting point is to attach a LightListCallback to each game object's base node.
/// @note Not thread safe for CullThreadPerCamera threading mode. /// @note Not thread safe for CullThreadPerCamera threading mode.
/// @note Due to lack of OSG support, the callback does not work on Drawables. /// @note Due to lack of OSG support, the callback does not work on Drawables.
class LightListCallback : public osg::NodeCallback class LightListCallback : public SceneUtil::NodeCallback<LightListCallback, osg::Node*, osgUtil::CullVisitor*>
{ {
public: public:
LightListCallback() LightListCallback()
@ -262,7 +263,7 @@ namespace SceneUtil
, mLastFrameNumber(0) , mLastFrameNumber(0)
{} {}
LightListCallback(const LightListCallback& copy, const osg::CopyOp& copyop) LightListCallback(const LightListCallback& copy, const osg::CopyOp& copyop)
: osg::Object(copy, copyop), osg::NodeCallback(copy, copyop) : osg::Object(copy, copyop), SceneUtil::NodeCallback<LightListCallback, osg::Node*, osgUtil::CullVisitor*>(copy, copyop)
, mLightManager(copy.mLightManager) , mLightManager(copy.mLightManager)
, mLastFrameNumber(0) , mLastFrameNumber(0)
, mIgnoredLightSources(copy.mIgnoredLightSources) , mIgnoredLightSources(copy.mIgnoredLightSources)
@ -270,7 +271,7 @@ namespace SceneUtil
META_Object(SceneUtil, LightListCallback) META_Object(SceneUtil, LightListCallback)
void operator()(osg::Node* node, osg::NodeVisitor* nv) override; void operator()(osg::Node* node, osgUtil::CullVisitor* nv);
bool pushLightState(osg::Node* node, osgUtil::CullVisitor* nv); bool pushLightState(osg::Node* node, osgUtil::CullVisitor* nv);

@ -0,0 +1,41 @@
#ifndef SCENEUTIL_NODECALLBACK_H
#define SCENEUTIL_NODECALLBACK_H
#include <osg/Callback>
namespace osg
{
class Node;
class NodeVisitor;
}
namespace SceneUtil
{
template <class Derived, typename NodeType=osg::Node*, typename VisitorType=osg::NodeVisitor*>
class NodeCallback : public virtual osg::Callback
{
public:
NodeCallback(){}
NodeCallback(const NodeCallback& nc,const osg::CopyOp& copyop):
osg::Callback(nc, copyop) {}
META_Object(SceneUtil, NodeCallback)
bool run(osg::Object* object, osg::Object* data) override
{
static_cast<Derived*>(this)->operator()((NodeType)object, (VisitorType)data->asNodeVisitor());
return true;
}
template <typename VT>
void traverse(NodeType object, VT data)
{
if (_nestedCallback.valid())
_nestedCallback->run(object, data);
else
data->traverse(*object);
}
};
}
#endif

@ -102,7 +102,7 @@ namespace SceneUtil
apply(static_cast<osg::Node&>(node)); apply(static_cast<osg::Node&>(node));
} }
OsgAnimationController::OsgAnimationController(const OsgAnimationController &copy, const osg::CopyOp &copyop) : SceneUtil::KeyframeController(copy, copyop) OsgAnimationController::OsgAnimationController(const OsgAnimationController &copy, const osg::CopyOp &copyop) : SceneUtil::KeyframeController(copy, copyop), SceneUtil::NodeCallback<OsgAnimationController>(copy, copyop)
, mEmulatedAnimations(copy.mEmulatedAnimations) , mEmulatedAnimations(copy.mEmulatedAnimations)
{ {
mLinker = nullptr; mLinker = nullptr;

@ -13,6 +13,7 @@
#include <osgAnimation/UpdateMatrixTransform> #include <osgAnimation/UpdateMatrixTransform>
#include <components/sceneutil/controller.hpp> #include <components/sceneutil/controller.hpp>
#include <components/sceneutil/nodecallback.hpp>
#include <components/sceneutil/keyframe.hpp> #include <components/sceneutil/keyframe.hpp>
#include <components/resource/animation.hpp> #include <components/resource/animation.hpp>
@ -44,7 +45,7 @@ namespace SceneUtil
Resource::Animation* mAnimation; Resource::Animation* mAnimation;
}; };
class OsgAnimationController : public SceneUtil::KeyframeController class OsgAnimationController : public SceneUtil::KeyframeController, public SceneUtil::NodeCallback<OsgAnimationController>
{ {
public: public:
/// @brief Handles the animation for osgAnimation formats /// @brief Handles the animation for osgAnimation formats
@ -61,7 +62,7 @@ namespace SceneUtil
void update(float time, const std::string& animationName); void update(float time, const std::string& animationName);
/// @brief Called every frame for osgAnimation /// @brief Called every frame for osgAnimation
void operator() (osg::Node*, osg::NodeVisitor*) override; void operator() (osg::Node*, osg::NodeVisitor*);
/// @brief Sets details of the animations /// @brief Sets details of the animations
void setEmulatedAnimations(const std::vector<EmulatedAnimation>& emulatedAnimations); void setEmulatedAnimations(const std::vector<EmulatedAnimation>& emulatedAnimations);

Loading…
Cancel
Save