Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexander Gavrilov <angavrilov@gmail.com>2018-12-21 12:09:49 +0300
committerAlexander Gavrilov <angavrilov@gmail.com>2018-12-21 12:10:23 +0300
commit8cbadde1a52f2550bd14bdca222a88cb1ec26547 (patch)
tree3d993d3bc34ac6be5e48ce1662215365d5ec437d /source/blender
parentcded90f989ee3acb1b8006a767d67dea361cb4e5 (diff)
Fix T59673: wrong B-Bone handle references when duplicating bones.
Also fix and improve symmetrize behavior.
Diffstat (limited to 'source/blender')
-rw-r--r--source/blender/editors/armature/armature_add.c35
1 files changed, 21 insertions, 14 deletions
diff --git a/source/blender/editors/armature/armature_add.c b/source/blender/editors/armature/armature_add.c
index 0b39fe22e47..fb0766d3bed 100644
--- a/source/blender/editors/armature/armature_add.c
+++ b/source/blender/editors/armature/armature_add.c
@@ -571,10 +571,10 @@ static int armature_duplicate_selected_exec(bContext *C, wmOperator *op)
/* Update custom handle links. */
if (ebone_iter->bbone_prev && ebone_iter->bbone_prev->temp.ebone) {
- ebone_iter->bbone_prev = ebone_iter->bbone_prev->temp.ebone;
+ ebone->bbone_prev = ebone_iter->bbone_prev->temp.ebone;
}
if (ebone_iter->bbone_next && ebone_iter->bbone_next->temp.ebone) {
- ebone_iter->bbone_next = ebone_iter->bbone_next->temp.ebone;
+ ebone->bbone_next = ebone_iter->bbone_next->temp.ebone;
}
/* Lets try to fix any constraint subtargets that might
@@ -627,6 +627,21 @@ void ARMATURE_OT_duplicate(wmOperatorType *ot)
"Flip Names", "Try to flip names of the bones, if possible, instead of adding a number extension");
}
+/* Get the duplicated or existing mirrored copy of the bone. */
+static EditBone *get_symmetrized_bone(bArmature *arm, EditBone *bone)
+{
+ if (bone == NULL) {
+ return NULL;
+ }
+ else if (bone->temp.ebone != NULL) {
+ return bone->temp.ebone;
+ }
+ else {
+ EditBone *mirror = ED_armature_ebone_get_mirrored(arm->edbo, bone);
+ return (mirror != NULL) ? mirror : bone;
+ }
+}
+
/**
* near duplicate of #armature_duplicate_selected_exec,
* except for parenting part (keep in sync)
@@ -757,17 +772,13 @@ static int armature_symmetrize_exec(bContext *C, wmOperator *op)
}
else {
/* the parent may have been duplicated, if not lookup the mirror parent */
- EditBone *ebone_parent = (
- ebone_iter->parent->temp.ebone ?
- ebone_iter->parent->temp.ebone :
- ED_armature_ebone_get_mirrored(arm->edbo, ebone_iter->parent));
+ EditBone *ebone_parent = get_symmetrized_bone(arm, ebone_iter->parent);
- if (ebone_parent == NULL) {
+ if (ebone_parent == ebone_iter->parent) {
/* If the mirror lookup failed, (but the current bone has a parent)
* then we can assume the parent has no L/R but is a center bone.
* So just use the same parent for both.
*/
- ebone_parent = ebone_iter->parent;
ebone->flag &= ~BONE_CONNECTED;
}
@@ -775,12 +786,8 @@ static int armature_symmetrize_exec(bContext *C, wmOperator *op)
}
/* Update custom handle links. */
- if (ebone_iter->bbone_prev && ebone_iter->bbone_prev->temp.ebone) {
- ebone_iter->bbone_prev = ebone_iter->bbone_prev->temp.ebone;
- }
- if (ebone_iter->bbone_next && ebone_iter->bbone_next->temp.ebone) {
- ebone_iter->bbone_next = ebone_iter->bbone_next->temp.ebone;
- }
+ ebone->bbone_prev = get_symmetrized_bone(arm, ebone_iter->bbone_prev);
+ ebone->bbone_next = get_symmetrized_bone(arm, ebone_iter->bbone_next);
/* Lets try to fix any constraint subtargets that might
* have been duplicated