diff options
| author | Brad Payne (Vir Linden) <vir@lindenlab.com> | 2018-04-27 14:50:28 +0100 |
|---|---|---|
| committer | Brad Payne (Vir Linden) <vir@lindenlab.com> | 2018-04-27 14:50:28 +0100 |
| commit | 19ebe40974edc23b9ac00e80dc716e34cad5a65d (patch) | |
| tree | 006c35d933582cd9e8212052d6cd5090a97e7023 /indra/newview/llviewerobject.cpp | |
| parent | 96c1790d92b7c1c019b164e0e51338b83c33e873 (diff) | |
MAINT-8559 - consistent management of control skeleton state with animated objects
Diffstat (limited to 'indra/newview/llviewerobject.cpp')
| -rw-r--r-- | indra/newview/llviewerobject.cpp | 33 |
1 files changed, 17 insertions, 16 deletions
diff --git a/indra/newview/llviewerobject.cpp b/indra/newview/llviewerobject.cpp index 5908d160e2..bde38029d0 100644 --- a/indra/newview/llviewerobject.cpp +++ b/indra/newview/llviewerobject.cpp @@ -2969,24 +2969,25 @@ LLControlAvatar *LLViewerObject::getControlAvatar() const void LLViewerObject::updateControlAvatar() { LLViewerObject *root = getRootEdit(); - if (root->isAnimatedObject() && !root->getControlAvatar()) + bool any_rigged_mesh = root->isRiggedMesh(); + LLViewerObject::const_child_list_t& child_list = root->getChildren(); + for (LLViewerObject::const_child_list_t::const_iterator iter = child_list.begin(); + iter != child_list.end(); ++iter) { - bool any_rigged_mesh = root->isRiggedMesh(); - LLViewerObject::const_child_list_t& child_list = root->getChildren(); - for (LLViewerObject::const_child_list_t::const_iterator iter = child_list.begin(); - iter != child_list.end(); ++iter) - { - const LLViewerObject* child = *iter; - any_rigged_mesh = any_rigged_mesh || child->isRiggedMesh(); - } - if (any_rigged_mesh) - { - std::string vobj_name = llformat("Vol%p", root); - LL_DEBUGS("AnimatedObjects") << vobj_name << " calling linkControlAvatar()" << LL_ENDL; - root->linkControlAvatar(); - } + const LLViewerObject* child = *iter; + any_rigged_mesh = any_rigged_mesh || child->isRiggedMesh(); + } + + bool has_control_avatar = getControlAvatar(); + bool should_have_control_avatar = root->isAnimatedObject() && any_rigged_mesh; + + if (should_have_control_avatar && !has_control_avatar) + { + std::string vobj_name = llformat("Vol%p", root); + LL_DEBUGS("AnimatedObjects") << vobj_name << " calling linkControlAvatar()" << LL_ENDL; + root->linkControlAvatar(); } - if (!root->isAnimatedObject() && root->getControlAvatar()) + if (!should_have_control_avatar && has_control_avatar) { std::string vobj_name = llformat("Vol%p", root); LL_DEBUGS("AnimatedObjects") << vobj_name << " calling unlinkControlAvatar()" << LL_ENDL; |
