From 6fa95e72c5a458008f59cd2e88e5e9e21f598690 Mon Sep 17 00:00:00 2001 From: scrawl Date: Sat, 2 Jul 2016 19:26:11 +0200 Subject: [PATCH] Pass the traversal number instead of the node visitor --- components/sceneutil/riggeometry.cpp | 4 ++-- components/sceneutil/skeleton.cpp | 6 +++--- components/sceneutil/skeleton.hpp | 2 +- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/components/sceneutil/riggeometry.cpp b/components/sceneutil/riggeometry.cpp index e0746801c..2dea6781e 100644 --- a/components/sceneutil/riggeometry.cpp +++ b/components/sceneutil/riggeometry.cpp @@ -241,7 +241,7 @@ void RigGeometry::update(osg::NodeVisitor* nv) return; mLastFrameNumber = nv->getTraversalNumber(); - mSkeleton->updateBoneMatrices(nv); + mSkeleton->updateBoneMatrices(nv->getTraversalNumber()); // skinning osg::Vec3Array* positionSrc = static_cast(mSourceGeometry->getVertexArray()); @@ -301,7 +301,7 @@ void RigGeometry::updateBounds(osg::NodeVisitor *nv) return; mBoundsFirstFrame = false; - mSkeleton->updateBoneMatrices(nv); + mSkeleton->updateBoneMatrices(nv->getTraversalNumber()); updateGeomToSkelMatrix(nv); diff --git a/components/sceneutil/skeleton.cpp b/components/sceneutil/skeleton.cpp index f311de246..08ac72e91 100644 --- a/components/sceneutil/skeleton.cpp +++ b/components/sceneutil/skeleton.cpp @@ -108,12 +108,12 @@ Bone* Skeleton::getBone(const std::string &name) return bone; } -void Skeleton::updateBoneMatrices(osg::NodeVisitor* nv) +void Skeleton::updateBoneMatrices(unsigned int traversalNumber) { - if (nv->getTraversalNumber() != mLastFrameNumber) + if (traversalNumber != mLastFrameNumber) mNeedToUpdateBoneMatrices = true; - mLastFrameNumber = nv->getTraversalNumber(); + mLastFrameNumber = traversalNumber; if (mLastFrameNumber % 2 == 0) mTraversedEvenFrame = true; diff --git a/components/sceneutil/skeleton.hpp b/components/sceneutil/skeleton.hpp index 9ca1dd49d..835ab6617 100644 --- a/components/sceneutil/skeleton.hpp +++ b/components/sceneutil/skeleton.hpp @@ -45,7 +45,7 @@ namespace SceneUtil 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(osg::NodeVisitor* nv); + 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.