From ee6fe52ea54f09d4e40f787740a4dd5a6b69caa2 Mon Sep 17 00:00:00 2001 From: Ashton Larkin Date: Wed, 28 Apr 2021 15:31:30 -0400 Subject: [PATCH] Backport #188: Fix crash when using BVH animations (#199) Signed-off-by: Ashton Larkin --- .../include/ignition/common/SkeletonAnimation.hh | 9 +++++++++ graphics/src/Skeleton.cc | 16 +++++++++++----- graphics/src/SkeletonAnimation.cc | 13 +++++++++++++ 3 files changed, 33 insertions(+), 5 deletions(-) diff --git a/graphics/include/ignition/common/SkeletonAnimation.hh b/graphics/include/ignition/common/SkeletonAnimation.hh index 1a703679f..be9990c2d 100644 --- a/graphics/include/ignition/common/SkeletonAnimation.hh +++ b/graphics/include/ignition/common/SkeletonAnimation.hh @@ -47,6 +47,15 @@ namespace ignition /// the animations public: ~SkeletonAnimation(); + // NOTE: this is not needed starting in ign-common4 since ign-common4 uses + // the IGN_UTILS_IMPL_PTR instead of a raw impl pointer. So, this + // method should not be included in forward ports from ign-common3 to + // ign-common4 + /// \brief Assignment operator + /// \param[in] _other The new SkeletonAnimation + /// \return A reference to this instance + public: SkeletonAnimation &operator=(const SkeletonAnimation &_other); + /// \brief Changes the name /// \param[in] _name the new name public: void SetName(const std::string& _name); diff --git a/graphics/src/Skeleton.cc b/graphics/src/Skeleton.cc index e34a1f5ff..87e6ca70a 100644 --- a/graphics/src/Skeleton.cc +++ b/graphics/src/Skeleton.cc @@ -30,7 +30,7 @@ class ignition::common::SkeletonPrivate RawNodeWeights; /// \brief the root node - public: SkeletonNode *root; + public: SkeletonNode *root{nullptr}; /// \brief The dictionary of nodes, indexed by name public: SkeletonNodeMap nodes; @@ -68,7 +68,6 @@ class ignition::common::SkeletonPrivate Skeleton::Skeleton() : data(new SkeletonPrivate) { - this->data->root = nullptr; } ////////////////////////////////////////////////// @@ -82,10 +81,14 @@ Skeleton::Skeleton(SkeletonNode *_root) ////////////////////////////////////////////////// Skeleton::~Skeleton() { - for (auto& kv : this->data->nodes) + for (auto &kv : this->data->nodes) delete kv.second; - for (auto& a : this->data->anims) + this->data->nodes.clear(); + + for (auto &a : this->data->anims) delete a; + this->data->anims.clear(); + delete this->data; this->data = NULL; } @@ -463,7 +466,10 @@ bool Skeleton::AddBvhAnimation(const std::string &_bvhFile, double _scale) * math::Matrix4d(skinNode->Transform().Rotation()); } - this->data->anims.push_back(skel->Animation(0u)); + // Copy pointer from temp skeleton before it's deleted + auto newAnim = new SkeletonAnimation(skel->Animation(0u)->Name()); + *newAnim = *skel->Animation(0u); + this->data->anims.push_back(newAnim); this->data->mapAnimSkin.push_back(skelMap); this->data->alignTranslate.push_back(translations); this->data->alignRotate.push_back(rotations); diff --git a/graphics/src/SkeletonAnimation.cc b/graphics/src/SkeletonAnimation.cc index b73d8b53e..dc1603825 100644 --- a/graphics/src/SkeletonAnimation.cc +++ b/graphics/src/SkeletonAnimation.cc @@ -50,6 +50,19 @@ SkeletonAnimation::~SkeletonAnimation() this->data = NULL; } +////////////////////////////////////////////////// +SkeletonAnimation &SkeletonAnimation::operator=(const SkeletonAnimation &_other) +{ + if (this == &_other) + return *this; + + this->data->name = _other.data->name; + this->data->length = _other.data->length; + this->data->animations = _other.data->animations; + + return *this; +} + ////////////////////////////////////////////////// void SkeletonAnimation::SetName(const std::string &_name) {