| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							|  |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-18 08:08:12 +11:00
										 |  |  | /** \file
 | 
					
						
							|  |  |  |  * \ingroup edarmature | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "DNA_armature_types.h"
 | 
					
						
							|  |  |  | #include "DNA_object_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "MEM_guardedalloc.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "BLI_blenlib.h"
 | 
					
						
							|  |  |  | #include "BLI_math.h"
 | 
					
						
							| 
									
										
										
										
											2017-01-16 20:34:13 +01:00
										 |  |  | #include "BLI_string_utils.h"
 | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "BKE_armature.h"
 | 
					
						
							|  |  |  | #include "BKE_context.h"
 | 
					
						
							|  |  |  | #include "BKE_deform.h"
 | 
					
						
							|  |  |  | #include "BKE_global.h"
 | 
					
						
							|  |  |  | #include "BKE_idprop.h"
 | 
					
						
							|  |  |  | #include "BKE_main.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-08 10:14:53 +02:00
										 |  |  | #include "DEG_depsgraph.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | #include "ED_armature.h"
 | 
					
						
							|  |  |  | #include "ED_util.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "armature_intern.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* *************************************************************** */ | 
					
						
							|  |  |  | /* Validation */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Sync selection to parent for connected children */ | 
					
						
							| 
									
										
										
										
											2018-04-15 11:45:51 +02:00
										 |  |  | void ED_armature_edit_sync_selection(ListBase *edbo) | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   EditBone *ebo; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (ebo = edbo->first; ebo; ebo = ebo->next) { | 
					
						
							|  |  |  |     /* if bone is not selectable, we shouldn't alter this setting... */ | 
					
						
							|  |  |  |     if ((ebo->flag & BONE_UNSELECTABLE) == 0) { | 
					
						
							|  |  |  |       if ((ebo->flag & BONE_CONNECTED) && (ebo->parent)) { | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |         if (ebo->parent->flag & BONE_TIPSEL) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           ebo->flag |= BONE_ROOTSEL; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |         } | 
					
						
							|  |  |  |         else { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           ebo->flag &= ~BONE_ROOTSEL; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |       if ((ebo->flag & BONE_TIPSEL) && (ebo->flag & BONE_ROOTSEL)) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         ebo->flag |= BONE_SELECTED; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |       } | 
					
						
							|  |  |  |       else { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         ebo->flag &= ~BONE_SELECTED; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-15 11:45:51 +02:00
										 |  |  | void ED_armature_edit_validate_active(struct bArmature *arm) | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   EditBone *ebone = arm->act_edbone; | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (ebone) { | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     if (ebone->flag & BONE_HIDDEN_A) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       arm->act_edbone = NULL; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-17 14:17:16 -03:00
										 |  |  | /* Update the layers_used variable after bones are moved between layer
 | 
					
						
							|  |  |  |  * NOTE: Used to be done in drawing code in 2.7, but that won't work with | 
					
						
							|  |  |  |  *       Copy-on-Write, as drawing uses evaluated copies. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void ED_armature_edit_refresh_layer_used(bArmature *arm) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   arm->layer_used = 0; | 
					
						
							|  |  |  |   for (EditBone *ebo = arm->edbo->first; ebo; ebo = ebo->next) { | 
					
						
							|  |  |  |     arm->layer_used |= ebo->layer; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | /* *************************************************************** */ | 
					
						
							|  |  |  | /* Bone Operations */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* XXX bone_looper is only to be used when we want to access settings
 | 
					
						
							|  |  |  |  * (i.e. editability/visibility/selected) that context doesn't offer */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | int bone_looper(Object *ob, Bone *bone, void *data, int (*bone_func)(Object *, Bone *, void *)) | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* We want to apply the function bone_func to every bone
 | 
					
						
							|  |  |  |    * in an armature -- feed bone_looper the first bone and | 
					
						
							|  |  |  |    * a pointer to the bone_func and watch it go!. The int count | 
					
						
							|  |  |  |    * can be useful for counting bones with a certain property | 
					
						
							|  |  |  |    * (e.g. skinnable) | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   int count = 0; | 
					
						
							| 
									
										
										
										
											2018-06-04 09:31:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (bone) { | 
					
						
							|  |  |  |     /* only do bone_func if the bone is non null */ | 
					
						
							|  |  |  |     count += bone_func(ob, bone, data); | 
					
						
							| 
									
										
										
										
											2018-06-04 09:31:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     /* try to execute bone_func for the first child */ | 
					
						
							|  |  |  |     count += bone_looper(ob, bone->childbase.first, data, bone_func); | 
					
						
							| 
									
										
										
										
											2018-06-04 09:31:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     /* try to execute bone_func for the next bone at this
 | 
					
						
							|  |  |  |      * depth of the recursion. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     count += bone_looper(ob, bone->next, data, bone_func); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-06-04 09:31:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   return count; | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* *************************************************************** */ | 
					
						
							|  |  |  | /* Bone Removal */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void bone_free(bArmature *arm, EditBone *bone) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   if (arm->act_edbone == bone) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     arm->act_edbone = NULL; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (bone->prop) { | 
					
						
							|  |  |  |     IDP_FreeProperty(bone->prop); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Clear references from other edit bones. */ | 
					
						
							|  |  |  |   for (EditBone *ebone = arm->edbo->first; ebone; ebone = ebone->next) { | 
					
						
							|  |  |  |     if (ebone->bbone_next == bone) { | 
					
						
							|  |  |  |       ebone->bbone_next = NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (ebone->bbone_prev == bone) { | 
					
						
							|  |  |  |       ebone->bbone_prev = NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-08-05 18:48:05 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   BLI_freelinkN(arm->edbo, bone); | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-22 07:50:58 +01:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * \param clear_connected: When false caller is responsible for keeping the flag in a valid state. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-04-15 11:45:51 +02:00
										 |  |  | void ED_armature_ebone_remove_ex(bArmature *arm, EditBone *exBone, bool clear_connected) | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   EditBone *curBone; | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Find any bones that refer to this bone */ | 
					
						
							|  |  |  |   for (curBone = arm->edbo->first; curBone; curBone = curBone->next) { | 
					
						
							|  |  |  |     if (curBone->parent == exBone) { | 
					
						
							|  |  |  |       curBone->parent = exBone->parent; | 
					
						
							|  |  |  |       if (clear_connected) { | 
					
						
							|  |  |  |         curBone->flag &= ~BONE_CONNECTED; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   bone_free(arm, exBone); | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-15 11:45:51 +02:00
										 |  |  | void ED_armature_ebone_remove(bArmature *arm, EditBone *exBone) | 
					
						
							| 
									
										
										
										
											2018-03-22 07:50:58 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   ED_armature_ebone_remove_ex(arm, exBone, true); | 
					
						
							| 
									
										
										
										
											2018-03-22 07:50:58 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-11 16:23:33 +00:00
										 |  |  | bool ED_armature_ebone_is_child_recursive(EditBone *ebone_parent, EditBone *ebone_child) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   for (ebone_child = ebone_child->parent; ebone_child; ebone_child = ebone_child->parent) { | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     if (ebone_child == ebone_parent) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       return true; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							|  |  |  |   return false; | 
					
						
							| 
									
										
										
										
											2013-03-11 16:23:33 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-22 08:36:48 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Finds the first parent shared by \a ebone_child | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-12-12 12:50:58 +11:00
										 |  |  |  * \param ebone_child: Children bones to search | 
					
						
							|  |  |  |  * \param ebone_child_tot: Size of the ebone_child array | 
					
						
							| 
									
										
										
										
											2013-11-22 08:36:48 +11:00
										 |  |  |  * \return The shared parent or NULL. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | EditBone *ED_armature_ebone_find_shared_parent(EditBone *ebone_child[], | 
					
						
							|  |  |  |                                                const unsigned int ebone_child_tot) | 
					
						
							| 
									
										
										
										
											2013-11-22 08:36:48 +11:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   unsigned int i; | 
					
						
							|  |  |  |   EditBone *ebone_iter; | 
					
						
							| 
									
										
										
										
											2013-11-22 08:36:48 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define EBONE_TEMP_UINT(ebone) (*((unsigned int *)(&((ebone)->temp))))
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* clear all */ | 
					
						
							|  |  |  |   for (i = 0; i < ebone_child_tot; i++) { | 
					
						
							|  |  |  |     for (ebone_iter = ebone_child[i]; ebone_iter; ebone_iter = ebone_iter->parent) { | 
					
						
							|  |  |  |       EBONE_TEMP_UINT(ebone_iter) = 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* accumulate */ | 
					
						
							|  |  |  |   for (i = 0; i < ebone_child_tot; i++) { | 
					
						
							|  |  |  |     for (ebone_iter = ebone_child[i]->parent; ebone_iter; ebone_iter = ebone_iter->parent) { | 
					
						
							|  |  |  |       EBONE_TEMP_UINT(ebone_iter) += 1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* only need search the first chain */ | 
					
						
							|  |  |  |   for (ebone_iter = ebone_child[0]->parent; ebone_iter; ebone_iter = ebone_iter->parent) { | 
					
						
							|  |  |  |     if (EBONE_TEMP_UINT(ebone_iter) == ebone_child_tot) { | 
					
						
							|  |  |  |       return ebone_iter; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-11-22 08:36:48 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  | #undef EBONE_TEMP_UINT
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   return NULL; | 
					
						
							| 
									
										
										
										
											2013-11-22 08:36:48 +11:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-07-25 12:07:55 +00:00
										 |  |  | void ED_armature_ebone_to_mat3(EditBone *ebone, float mat[3][3]) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-12-27 09:51:37 -03:00
										 |  |  |   float delta[3], roll; | 
					
						
							| 
									
										
										
										
											2013-07-25 12:07:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Find the current bone matrix */ | 
					
						
							|  |  |  |   sub_v3_v3v3(delta, ebone->tail, ebone->head); | 
					
						
							| 
									
										
										
										
											2019-12-27 09:51:37 -03:00
										 |  |  |   roll = ebone->roll; | 
					
						
							|  |  |  |   if (!normalize_v3(delta)) { | 
					
						
							|  |  |  |     /* Use the orientation of the parent bone if any. */ | 
					
						
							|  |  |  |     const EditBone *ebone_parent = ebone->parent; | 
					
						
							|  |  |  |     if (ebone_parent) { | 
					
						
							|  |  |  |       sub_v3_v3v3(delta, ebone_parent->tail, ebone_parent->head); | 
					
						
							|  |  |  |       normalize_v3(delta); | 
					
						
							|  |  |  |       roll = ebone_parent->roll; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   vec_roll_to_mat3_normalized(delta, roll, mat); | 
					
						
							| 
									
										
										
										
											2013-07-25 12:07:55 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ED_armature_ebone_to_mat4(EditBone *ebone, float mat[4][4]) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   float m3[3][3]; | 
					
						
							| 
									
										
										
										
											2013-07-25 12:07:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   ED_armature_ebone_to_mat3(ebone, m3); | 
					
						
							| 
									
										
										
										
											2013-07-25 12:07:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   copy_m4_m3(mat, m3); | 
					
						
							|  |  |  |   copy_v3_v3(mat[3], ebone->head); | 
					
						
							| 
									
										
										
										
											2013-07-25 12:07:55 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-05 20:56:38 +02:00
										 |  |  | void ED_armature_ebone_from_mat3(EditBone *ebone, float mat[3][3]) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   float vec[3], roll; | 
					
						
							|  |  |  |   const float len = len_v3v3(ebone->head, ebone->tail); | 
					
						
							| 
									
										
										
										
											2014-05-05 20:56:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   mat3_to_vec_roll(mat, vec, &roll); | 
					
						
							| 
									
										
										
										
											2014-05-05 20:56:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   madd_v3_v3v3fl(ebone->tail, ebone->head, vec, len); | 
					
						
							|  |  |  |   ebone->roll = roll; | 
					
						
							| 
									
										
										
										
											2014-05-05 20:56:38 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ED_armature_ebone_from_mat4(EditBone *ebone, float mat[4][4]) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   float mat3[3][3]; | 
					
						
							| 
									
										
										
										
											2014-05-05 20:56:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   copy_m3_m4(mat3, mat); | 
					
						
							|  |  |  |   /* We want normalized matrix here, to be consistent with ebone_to_mat. */ | 
					
						
							|  |  |  |   BLI_ASSERT_UNIT_M3(mat3); | 
					
						
							| 
									
										
										
										
											2014-05-05 20:56:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   sub_v3_v3(ebone->tail, ebone->head); | 
					
						
							|  |  |  |   copy_v3_v3(ebone->head, mat[3]); | 
					
						
							|  |  |  |   add_v3_v3(ebone->tail, mat[3]); | 
					
						
							|  |  |  |   ED_armature_ebone_from_mat3(ebone, mat3); | 
					
						
							| 
									
										
										
										
											2014-05-05 20:56:38 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-17 04:30:36 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Return a pointer to the bone of the given name | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-04-15 11:45:51 +02:00
										 |  |  | EditBone *ED_armature_ebone_find_name(const ListBase *edbo, const char *name) | 
					
						
							| 
									
										
										
										
											2013-11-17 04:30:36 +11:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   return BLI_findstring(edbo, name, offsetof(EditBone, name)); | 
					
						
							| 
									
										
										
										
											2013-11-17 04:30:36 +11:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | /* *************************************************************** */ | 
					
						
							|  |  |  | /* Mirroring */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-17 04:30:36 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * \see #BKE_pose_channel_get_mirrored (pose-mode, matching function) | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-04-15 11:45:51 +02:00
										 |  |  | EditBone *ED_armature_ebone_get_mirrored(const ListBase *edbo, EditBone *ebo) | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   char name_flip[MAXBONENAME]; | 
					
						
							| 
									
										
										
										
											2013-11-17 04:30:36 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   if (ebo == NULL) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     return NULL; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-06-04 09:31:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   BLI_string_flip_side_name(name_flip, ebo->name, false, sizeof(name_flip)); | 
					
						
							| 
									
										
										
										
											2018-06-04 09:31:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (!STREQ(name_flip, ebo->name)) { | 
					
						
							|  |  |  |     return ED_armature_ebone_find_name(edbo, name_flip); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-06-04 09:31:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   return NULL; | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ------------------------------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* helper function for tools to work on mirrored parts.
 | 
					
						
							|  |  |  |  * it leaves mirrored bones selected then too, which is a good indication of what happened */ | 
					
						
							| 
									
										
										
										
											2015-06-13 03:20:07 +10:00
										 |  |  | void armature_select_mirrored_ex(bArmature *arm, const int flag) | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   BLI_assert((flag & ~(BONE_SELECTED | BONE_ROOTSEL | BONE_TIPSEL)) == 0); | 
					
						
							|  |  |  |   /* Select mirrored bones */ | 
					
						
							|  |  |  |   if (arm->flag & ARM_MIRROR_EDIT) { | 
					
						
							|  |  |  |     EditBone *curBone, *ebone_mirr; | 
					
						
							| 
									
										
										
										
											2018-06-04 09:31:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     for (curBone = arm->edbo->first; curBone; curBone = curBone->next) { | 
					
						
							|  |  |  |       if (arm->layer & curBone->layer) { | 
					
						
							|  |  |  |         if (curBone->flag & flag) { | 
					
						
							|  |  |  |           ebone_mirr = ED_armature_ebone_get_mirrored(arm->edbo, curBone); | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |           if (ebone_mirr) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             ebone_mirr->flag |= (curBone->flag & flag); | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-13 03:20:07 +10:00
										 |  |  | void armature_select_mirrored(bArmature *arm) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   armature_select_mirrored_ex(arm, BONE_SELECTED); | 
					
						
							| 
									
										
										
										
											2015-06-13 03:20:07 +10:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | void armature_tag_select_mirrored(bArmature *arm) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   EditBone *curBone; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* always untag */ | 
					
						
							|  |  |  |   for (curBone = arm->edbo->first; curBone; curBone = curBone->next) { | 
					
						
							|  |  |  |     curBone->flag &= ~BONE_DONE; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Select mirrored bones */ | 
					
						
							|  |  |  |   if (arm->flag & ARM_MIRROR_EDIT) { | 
					
						
							|  |  |  |     for (curBone = arm->edbo->first; curBone; curBone = curBone->next) { | 
					
						
							|  |  |  |       if (arm->layer & curBone->layer) { | 
					
						
							|  |  |  |         if (curBone->flag & (BONE_SELECTED | BONE_ROOTSEL | BONE_TIPSEL)) { | 
					
						
							|  |  |  |           EditBone *ebone_mirr = ED_armature_ebone_get_mirrored(arm->edbo, curBone); | 
					
						
							|  |  |  |           if (ebone_mirr && (ebone_mirr->flag & BONE_SELECTED) == 0) { | 
					
						
							|  |  |  |             ebone_mirr->flag |= BONE_DONE; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (curBone = arm->edbo->first; curBone; curBone = curBone->next) { | 
					
						
							|  |  |  |       if (curBone->flag & BONE_DONE) { | 
					
						
							|  |  |  |         EditBone *ebone_mirr = ED_armature_ebone_get_mirrored(arm->edbo, curBone); | 
					
						
							|  |  |  |         curBone->flag |= ebone_mirr->flag & (BONE_SELECTED | BONE_ROOTSEL | BONE_TIPSEL); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* only works when tagged */ | 
					
						
							|  |  |  | void armature_tag_unselect(bArmature *arm) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   EditBone *curBone; | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   for (curBone = arm->edbo->first; curBone; curBone = curBone->next) { | 
					
						
							|  |  |  |     if (curBone->flag & BONE_DONE) { | 
					
						
							|  |  |  |       curBone->flag &= ~(BONE_SELECTED | BONE_ROOTSEL | BONE_TIPSEL | BONE_DONE); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ------------------------------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-11 09:41:18 -03:00
										 |  |  | void ED_armature_ebone_transform_mirror_update(bArmature *arm, EditBone *ebo, bool check_select) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-08-22 04:36:04 +10:00
										 |  |  |   /* TODO When this function is called by property updates,
 | 
					
						
							|  |  |  |    * cancelling the value change will not restore mirrored bone correctly. */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Currently check_select==true when this function is called from a transform operator,
 | 
					
						
							|  |  |  |    * eg. from 3d viewport. */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-11 09:41:18 -03:00
										 |  |  |   /* no layer check, correct mirror is more important */ | 
					
						
							|  |  |  |   if (!check_select || ebo->flag & (BONE_TIPSEL | BONE_ROOTSEL)) { | 
					
						
							|  |  |  |     EditBone *eboflip = ED_armature_ebone_get_mirrored(arm->edbo, ebo); | 
					
						
							|  |  |  |     if (eboflip) { | 
					
						
							| 
									
										
										
										
											2019-08-21 09:59:11 +02:00
										 |  |  |       /* We assume X-axis flipping for now. */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Always mirror roll, since it can be changed by moving either head or tail. */ | 
					
						
							|  |  |  |       eboflip->roll = -ebo->roll; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (!check_select || ebo->flag & BONE_TIPSEL) { | 
					
						
							|  |  |  |         /* Mirror tail properties. */ | 
					
						
							| 
									
										
										
										
											2019-06-11 09:41:18 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |         eboflip->tail[0] = -ebo->tail[0]; | 
					
						
							|  |  |  |         eboflip->tail[1] = ebo->tail[1]; | 
					
						
							|  |  |  |         eboflip->tail[2] = ebo->tail[2]; | 
					
						
							|  |  |  |         eboflip->rad_tail = ebo->rad_tail; | 
					
						
							|  |  |  |         eboflip->curve_out_x = -ebo->curve_out_x; | 
					
						
							| 
									
										
										
										
											2019-08-21 09:59:11 +02:00
										 |  |  |         eboflip->curve_out_y = ebo->curve_out_y; | 
					
						
							|  |  |  |         eboflip->scale_out_x = ebo->scale_out_x; | 
					
						
							|  |  |  |         eboflip->scale_out_y = ebo->scale_out_y; | 
					
						
							|  |  |  |         eboflip->ease2 = ebo->ease2; | 
					
						
							| 
									
										
										
										
											2019-06-11 09:41:18 -03:00
										 |  |  |         eboflip->roll2 = -ebo->roll2; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-21 09:59:11 +02:00
										 |  |  |         /* Also move connected children, in case children's name aren't mirrored properly. */ | 
					
						
							|  |  |  |         EditBone *children; | 
					
						
							| 
									
										
										
										
											2019-06-11 09:41:18 -03:00
										 |  |  |         for (children = arm->edbo->first; children; children = children->next) { | 
					
						
							|  |  |  |           if (children->parent == eboflip && children->flag & BONE_CONNECTED) { | 
					
						
							|  |  |  |             copy_v3_v3(children->head, eboflip->tail); | 
					
						
							|  |  |  |             children->rad_head = ebo->rad_tail; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-08-21 09:59:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-11 09:41:18 -03:00
										 |  |  |       if (!check_select || ebo->flag & BONE_ROOTSEL) { | 
					
						
							| 
									
										
										
										
											2019-08-21 09:59:11 +02:00
										 |  |  |         /* Mirror head properties. */ | 
					
						
							| 
									
										
										
										
											2019-06-11 09:41:18 -03:00
										 |  |  |         eboflip->head[0] = -ebo->head[0]; | 
					
						
							|  |  |  |         eboflip->head[1] = ebo->head[1]; | 
					
						
							|  |  |  |         eboflip->head[2] = ebo->head[2]; | 
					
						
							|  |  |  |         eboflip->rad_head = ebo->rad_head; | 
					
						
							| 
									
										
										
										
											2019-08-21 09:59:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-11 09:41:18 -03:00
										 |  |  |         eboflip->curve_in_x = -ebo->curve_in_x; | 
					
						
							| 
									
										
										
										
											2019-08-21 09:59:11 +02:00
										 |  |  |         eboflip->curve_in_y = ebo->curve_in_y; | 
					
						
							|  |  |  |         eboflip->scale_in_x = ebo->scale_in_x; | 
					
						
							|  |  |  |         eboflip->scale_in_y = ebo->scale_in_y; | 
					
						
							|  |  |  |         eboflip->ease1 = ebo->ease1; | 
					
						
							| 
									
										
										
										
											2019-06-11 09:41:18 -03:00
										 |  |  |         eboflip->roll1 = -ebo->roll1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-21 09:59:11 +02:00
										 |  |  |         /* Also move connected parent, in case parent's name isn't mirrored properly. */ | 
					
						
							| 
									
										
										
										
											2019-06-11 09:41:18 -03:00
										 |  |  |         if (eboflip->parent && eboflip->flag & BONE_CONNECTED) { | 
					
						
							|  |  |  |           EditBone *parent = eboflip->parent; | 
					
						
							|  |  |  |           copy_v3_v3(parent->tail, eboflip->head); | 
					
						
							|  |  |  |           parent->rad_tail = ebo->rad_head; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-08-21 09:59:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-11 09:41:18 -03:00
										 |  |  |       if (!check_select || ebo->flag & BONE_SELECTED) { | 
					
						
							| 
									
										
										
										
											2019-08-21 09:59:11 +02:00
										 |  |  |         /* Mirror bone body properties (both head and tail are selected). */ | 
					
						
							| 
									
										
										
										
											2019-08-22 04:36:04 +10:00
										 |  |  |         /* TODO: These values can also be changed from pose mode,
 | 
					
						
							|  |  |  |          * so only mirroring them in edit mode is not ideal. */ | 
					
						
							| 
									
										
										
										
											2019-06-11 09:41:18 -03:00
										 |  |  |         eboflip->dist = ebo->dist; | 
					
						
							| 
									
										
										
										
											2019-08-21 09:59:11 +02:00
										 |  |  |         eboflip->weight = ebo->weight; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         eboflip->segments = ebo->segments; | 
					
						
							| 
									
										
										
										
											2019-06-11 09:41:18 -03:00
										 |  |  |         eboflip->xwidth = ebo->xwidth; | 
					
						
							|  |  |  |         eboflip->zwidth = ebo->zwidth; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | /* if editbone (partial) selected, copy data */ | 
					
						
							|  |  |  | /* context; editmode armature, with mirror editing enabled */ | 
					
						
							| 
									
										
										
										
											2018-04-15 11:45:51 +02:00
										 |  |  | void ED_armature_edit_transform_mirror_update(Object *obedit) | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   bArmature *arm = obedit->data; | 
					
						
							| 
									
										
										
										
											2019-06-12 08:16:58 +10:00
										 |  |  |   for (EditBone *ebo = arm->edbo->first; ebo; ebo = ebo->next) { | 
					
						
							| 
									
										
										
										
											2019-06-11 09:41:18 -03:00
										 |  |  |     ED_armature_ebone_transform_mirror_update(arm, ebo, true); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* *************************************************************** */ | 
					
						
							|  |  |  | /* Armature EditMode Conversions */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* converts Bones to EditBone list, used for tools as well */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | static EditBone *make_boneList_rec(ListBase *edbo, | 
					
						
							|  |  |  |                                    ListBase *bones, | 
					
						
							|  |  |  |                                    EditBone *parent, | 
					
						
							|  |  |  |                                    Bone *actBone) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   EditBone *eBone; | 
					
						
							|  |  |  |   EditBone *eBoneAct = NULL; | 
					
						
							|  |  |  |   EditBone *eBoneTest = NULL; | 
					
						
							|  |  |  |   Bone *curBone; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (curBone = bones->first; curBone; curBone = curBone->next) { | 
					
						
							|  |  |  |     eBone = MEM_callocN(sizeof(EditBone), "make_editbone"); | 
					
						
							|  |  |  |     eBone->temp.bone = curBone; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Copy relevant data from bone to eBone
 | 
					
						
							|  |  |  |      * Keep selection logic in sync with ED_armature_edit_sync_selection. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     eBone->parent = parent; | 
					
						
							|  |  |  |     BLI_strncpy(eBone->name, curBone->name, sizeof(eBone->name)); | 
					
						
							|  |  |  |     eBone->flag = curBone->flag; | 
					
						
							| 
									
										
											  
											
												Armature: add Inherit Scale options to remove shear or average the scale.
As an inherent property of matrix-based transformation math, non-
uniform scaling of a parent bone induces shear into the transform
matrix of any rotated child. Such matrices cannot be cleanly
decomposed into a combination of location/rotation/scale, which
causes issues for rigging and animation tools.
Blender bones have options to exclude rotation and/or scale from the
inherited transformation, but don't have any support for removing the
often undesired shear component. That goal requires replacing simple
parenting with a combination of multiple bones and constraints. The
same is true about the goal of inheriting some scale, but completely
avoiding shear.
This patch replaces the old Inherit Scale checkbox with a enum that
supports multiple options:
* Full: inherit all effects of scale, like with enabled Inherit Scale.
* Fix Shear: removes shear from the final inherited transformation.
  The cleanup math is specifically designed to preserve the main
  axis of the bone, its length and total volume, and minimally
  affect roll on average. It however will not prevent reappearance
  of shear due to local rotation of the child or its children.
* Average: inherit uniform scale that represents the parent volume.
  This is the simplest foolproof solution that will inherit some
  scale without ever causing shear.
* None: completely remove scale and shear.
* None (Legacy): old disabled Inherit Scale checkbox.
  This mode does not handle parent shear in any way, so the child
  is likely to end up having both scale and shear. It is retained
  for backward compatibility.
Since many rigging-related addons access the use_inherit_scale
property from Python, it is retained as a backward compatibility
stub that provides the old functionality.
As a side effect of reworking the code, this also fixes a matrix
multiplication order bug in the Inherit Rotation code, which caused
the parent local scale to be applied in world space. In rigger
opinion this option is useless in production rigs, so this fix
should not be a problem.
Reviewers: brecht
Differential Revision: https://developer.blender.org/D5588
											
										 
											2019-09-04 10:10:27 +03:00
										 |  |  |     eBone->inherit_scale_mode = curBone->inherit_scale_mode; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* fix selection flags */ | 
					
						
							|  |  |  |     if (eBone->flag & BONE_SELECTED) { | 
					
						
							|  |  |  |       /* if the bone is selected the copy its root selection to the parents tip */ | 
					
						
							|  |  |  |       eBone->flag |= BONE_TIPSEL; | 
					
						
							|  |  |  |       if (eBone->parent && (eBone->flag & BONE_CONNECTED)) { | 
					
						
							|  |  |  |         eBone->parent->flag |= BONE_TIPSEL; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-29 19:29:41 +10:00
										 |  |  |       /* For connected bones, take care when changing the selection when we have a
 | 
					
						
							|  |  |  |        * connected parent, this flag is a copy of '(eBone->parent->flag & BONE_TIPSEL)'. */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       eBone->flag |= BONE_ROOTSEL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       /* if the bone is not selected, but connected to its parent
 | 
					
						
							|  |  |  |        * always use the parents tip selection state */ | 
					
						
							|  |  |  |       if (eBone->parent && (eBone->flag & BONE_CONNECTED)) { | 
					
						
							|  |  |  |         eBone->flag &= ~BONE_ROOTSEL; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     copy_v3_v3(eBone->head, curBone->arm_head); | 
					
						
							|  |  |  |     copy_v3_v3(eBone->tail, curBone->arm_tail); | 
					
						
							|  |  |  |     eBone->roll = curBone->arm_roll; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* rest of stuff copy */ | 
					
						
							|  |  |  |     eBone->length = curBone->length; | 
					
						
							|  |  |  |     eBone->dist = curBone->dist; | 
					
						
							|  |  |  |     eBone->weight = curBone->weight; | 
					
						
							|  |  |  |     eBone->xwidth = curBone->xwidth; | 
					
						
							|  |  |  |     eBone->zwidth = curBone->zwidth; | 
					
						
							|  |  |  |     eBone->rad_head = curBone->rad_head; | 
					
						
							|  |  |  |     eBone->rad_tail = curBone->rad_tail; | 
					
						
							|  |  |  |     eBone->segments = curBone->segments; | 
					
						
							|  |  |  |     eBone->layer = curBone->layer; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Bendy-Bone parameters */ | 
					
						
							|  |  |  |     eBone->roll1 = curBone->roll1; | 
					
						
							|  |  |  |     eBone->roll2 = curBone->roll2; | 
					
						
							| 
									
										
										
										
											2019-04-23 13:15:30 +03:00
										 |  |  |     eBone->curve_in_x = curBone->curve_in_x; | 
					
						
							|  |  |  |     eBone->curve_in_y = curBone->curve_in_y; | 
					
						
							|  |  |  |     eBone->curve_out_x = curBone->curve_out_x; | 
					
						
							|  |  |  |     eBone->curve_out_y = curBone->curve_out_y; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     eBone->ease1 = curBone->ease1; | 
					
						
							|  |  |  |     eBone->ease2 = curBone->ease2; | 
					
						
							| 
									
										
										
										
											2019-04-20 18:06:31 +03:00
										 |  |  |     eBone->scale_in_x = curBone->scale_in_x; | 
					
						
							|  |  |  |     eBone->scale_in_y = curBone->scale_in_y; | 
					
						
							|  |  |  |     eBone->scale_out_x = curBone->scale_out_x; | 
					
						
							|  |  |  |     eBone->scale_out_y = curBone->scale_out_y; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     eBone->bbone_prev_type = curBone->bbone_prev_type; | 
					
						
							|  |  |  |     eBone->bbone_next_type = curBone->bbone_next_type; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     if (curBone->prop) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       eBone->prop = IDP_CopyProperty(curBone->prop); | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     BLI_addtail(edbo, eBone); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-29 16:33:51 +11:00
										 |  |  |     /* Add children if necessary. */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     if (curBone->childbase.first) { | 
					
						
							|  |  |  |       eBoneTest = make_boneList_rec(edbo, &curBone->childbase, eBone, actBone); | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |       if (eBoneTest) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         eBoneAct = eBoneTest; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     if (curBone == actBone) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       eBoneAct = eBone; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return eBoneAct; | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-05 18:48:05 +03:00
										 |  |  | static EditBone *find_ebone_link(ListBase *edbo, Bone *link) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (link != NULL) { | 
					
						
							|  |  |  |     for (EditBone *ebone = edbo->first; ebone; ebone = ebone->next) { | 
					
						
							|  |  |  |       if (ebone->temp.bone == link) { | 
					
						
							|  |  |  |         return ebone; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-08-05 18:48:05 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   return NULL; | 
					
						
							| 
									
										
										
										
											2018-08-05 18:48:05 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | EditBone *make_boneList(ListBase *edbo, ListBase *bones, struct Bone *actBone) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   BLI_assert(!edbo->first && !edbo->last); | 
					
						
							| 
									
										
										
										
											2018-08-05 18:48:05 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   EditBone *active = make_boneList_rec(edbo, bones, NULL, actBone); | 
					
						
							| 
									
										
										
										
											2018-08-05 18:48:05 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   for (EditBone *ebone = edbo->first; ebone; ebone = ebone->next) { | 
					
						
							|  |  |  |     Bone *bone = ebone->temp.bone; | 
					
						
							| 
									
										
										
										
											2018-08-05 18:48:05 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     /* Convert custom B-Bone handle links. */ | 
					
						
							|  |  |  |     ebone->bbone_prev = find_ebone_link(edbo, bone->bbone_prev); | 
					
						
							|  |  |  |     ebone->bbone_next = find_ebone_link(edbo, bone->bbone_next); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-08-05 18:48:05 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   return active; | 
					
						
							| 
									
										
										
										
											2018-08-05 18:48:05 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-14 10:48:42 +02:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * This function: | 
					
						
							|  |  |  |  * - Sets local head/tail rest locations using parent bone's arm_mat. | 
					
						
							| 
									
										
										
										
											2019-04-22 00:18:34 +10:00
										 |  |  |  * - Calls #BKE_armature_where_is_bone() which uses parent's transform (arm_mat) | 
					
						
							|  |  |  |  *   to define this bone's transform. | 
					
						
							| 
									
										
										
										
											2019-04-14 10:48:42 +02:00
										 |  |  |  * - Fixes (converts) EditBone roll into Bone roll. | 
					
						
							| 
									
										
										
										
											2019-04-22 00:18:34 +10:00
										 |  |  |  * - Calls again #BKE_armature_where_is_bone(), | 
					
						
							|  |  |  |  *   since roll fiddling may have changed things for our bone. | 
					
						
							| 
									
										
										
										
											2019-04-14 10:48:42 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \note The order is crucial here, we can only handle child | 
					
						
							|  |  |  |  * if all its parents in chain have already been handled (this is ensured by recursive process). | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-09-04 16:38:24 +02:00
										 |  |  | static void armature_finalize_restpose(ListBase *bonelist, ListBase *editbonelist) | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   Bone *curBone; | 
					
						
							|  |  |  |   EditBone *ebone; | 
					
						
							| 
									
										
										
										
											2015-09-04 16:38:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   for (curBone = bonelist->first; curBone; curBone = curBone->next) { | 
					
						
							|  |  |  |     /* Set bone's local head/tail.
 | 
					
						
							| 
									
										
										
										
											2019-04-22 00:18:34 +10:00
										 |  |  |      * Note that it's important to use final parent's restpose (arm_mat) here, | 
					
						
							|  |  |  |      * instead of setting those values from editbone's matrix (see T46010). */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     if (curBone->parent) { | 
					
						
							|  |  |  |       float parmat_inv[4][4]; | 
					
						
							| 
									
										
										
										
											2015-09-04 16:38:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       invert_m4_m4(parmat_inv, curBone->parent->arm_mat); | 
					
						
							| 
									
										
										
										
											2015-09-04 16:38:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       /* Get the new head and tail */ | 
					
						
							|  |  |  |       sub_v3_v3v3(curBone->head, curBone->arm_head, curBone->parent->arm_tail); | 
					
						
							|  |  |  |       sub_v3_v3v3(curBone->tail, curBone->arm_tail, curBone->parent->arm_tail); | 
					
						
							| 
									
										
										
										
											2015-09-04 16:38:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       mul_mat3_m4_v3(parmat_inv, curBone->head); | 
					
						
							|  |  |  |       mul_mat3_m4_v3(parmat_inv, curBone->tail); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       copy_v3_v3(curBone->head, curBone->arm_head); | 
					
						
							|  |  |  |       copy_v3_v3(curBone->tail, curBone->arm_tail); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-09-04 16:38:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     /* Set local matrix and arm_mat (restpose).
 | 
					
						
							|  |  |  |      * Do not recurse into children here, armature_finalize_restpose() is already recursive. */ | 
					
						
							|  |  |  |     BKE_armature_where_is_bone(curBone, curBone->parent, false); | 
					
						
							| 
									
										
										
										
											2015-09-04 16:38:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     /* Find the associated editbone */ | 
					
						
							|  |  |  |     for (ebone = editbonelist->first; ebone; ebone = ebone->next) { | 
					
						
							|  |  |  |       if (ebone->temp.bone == curBone) { | 
					
						
							|  |  |  |         float premat[3][3]; | 
					
						
							|  |  |  |         float postmat[3][3]; | 
					
						
							|  |  |  |         float difmat[3][3]; | 
					
						
							|  |  |  |         float imat[3][3]; | 
					
						
							| 
									
										
										
										
											2015-09-04 16:38:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         /* Get the ebone premat and its inverse. */ | 
					
						
							|  |  |  |         ED_armature_ebone_to_mat3(ebone, premat); | 
					
						
							|  |  |  |         invert_m3_m3(imat, premat); | 
					
						
							| 
									
										
										
										
											2015-09-04 16:38:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         /* Get the bone postmat. */ | 
					
						
							|  |  |  |         copy_m3_m4(postmat, curBone->arm_mat); | 
					
						
							| 
									
										
										
										
											2015-09-04 16:38:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         mul_m3_m3m3(difmat, imat, postmat); | 
					
						
							| 
									
										
										
										
											2015-09-04 16:38:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         printf("Bone %s\n", curBone->name); | 
					
						
							|  |  |  |         print_m4("premat", premat); | 
					
						
							|  |  |  |         print_m4("postmat", postmat); | 
					
						
							|  |  |  |         print_m4("difmat", difmat); | 
					
						
							| 
									
										
										
										
											2019-04-17 08:24:14 +02:00
										 |  |  |         printf("Roll = %f\n", RAD2DEGF(-atan2(difmat[2][0], difmat[2][2]))); | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-09-04 16:38:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         curBone->roll = -atan2f(difmat[2][0], difmat[2][2]); | 
					
						
							| 
									
										
										
										
											2015-09-04 16:38:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-06 11:40:37 +11:00
										 |  |  |         /* And set rest-position again. */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         BKE_armature_where_is_bone(curBone, curBone->parent, false); | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-09-04 16:38:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     /* Recurse into children... */ | 
					
						
							|  |  |  |     armature_finalize_restpose(&curBone->childbase, editbonelist); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* put EditMode back in Object */ | 
					
						
							| 
									
										
										
										
											2018-06-06 15:50:24 +02:00
										 |  |  | void ED_armature_from_edit(Main *bmain, bArmature *arm) | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   EditBone *eBone, *neBone; | 
					
						
							|  |  |  |   Bone *newBone; | 
					
						
							|  |  |  |   Object *obt; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* armature bones */ | 
					
						
							| 
									
										
										
										
											2019-05-14 21:48:22 +03:00
										 |  |  |   BKE_armature_bone_hash_free(arm); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   BKE_armature_bonelist_free(&arm->bonebase); | 
					
						
							|  |  |  |   arm->act_bone = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* remove zero sized bones, this gives unstable restposes */ | 
					
						
							|  |  |  |   for (eBone = arm->edbo->first; eBone; eBone = neBone) { | 
					
						
							|  |  |  |     float len_sq = len_squared_v3v3(eBone->head, eBone->tail); | 
					
						
							|  |  |  |     neBone = eBone->next; | 
					
						
							| 
									
										
										
										
											2020-03-06 17:18:10 +01:00
										 |  |  |     /* TODO(sergey): How to ensure this is a constexpr? */ | 
					
						
							|  |  |  |     if (len_sq <= square_f(0.000001f)) { /* FLT_EPSILON is too large? */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       EditBone *fBone; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Find any bones that refer to this bone */ | 
					
						
							|  |  |  |       for (fBone = arm->edbo->first; fBone; fBone = fBone->next) { | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |         if (fBone->parent == eBone) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           fBone->parent = eBone->parent; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |       if (G.debug & G_DEBUG) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         printf("Warning: removed zero sized bone: %s\n", eBone->name); | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       bone_free(arm, eBone); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-29 16:33:51 +11:00
										 |  |  |   /* Copy the bones from the edit-data into the armature. */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   for (eBone = arm->edbo->first; eBone; eBone = eBone->next) { | 
					
						
							|  |  |  |     newBone = MEM_callocN(sizeof(Bone), "bone"); | 
					
						
							|  |  |  |     eBone->temp.bone = newBone; /* Associate the real Bones with the EditBones */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     BLI_strncpy(newBone->name, eBone->name, sizeof(newBone->name)); | 
					
						
							|  |  |  |     copy_v3_v3(newBone->arm_head, eBone->head); | 
					
						
							|  |  |  |     copy_v3_v3(newBone->arm_tail, eBone->tail); | 
					
						
							|  |  |  |     newBone->arm_roll = eBone->roll; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     newBone->flag = eBone->flag; | 
					
						
							| 
									
										
											  
											
												Armature: add Inherit Scale options to remove shear or average the scale.
As an inherent property of matrix-based transformation math, non-
uniform scaling of a parent bone induces shear into the transform
matrix of any rotated child. Such matrices cannot be cleanly
decomposed into a combination of location/rotation/scale, which
causes issues for rigging and animation tools.
Blender bones have options to exclude rotation and/or scale from the
inherited transformation, but don't have any support for removing the
often undesired shear component. That goal requires replacing simple
parenting with a combination of multiple bones and constraints. The
same is true about the goal of inheriting some scale, but completely
avoiding shear.
This patch replaces the old Inherit Scale checkbox with a enum that
supports multiple options:
* Full: inherit all effects of scale, like with enabled Inherit Scale.
* Fix Shear: removes shear from the final inherited transformation.
  The cleanup math is specifically designed to preserve the main
  axis of the bone, its length and total volume, and minimally
  affect roll on average. It however will not prevent reappearance
  of shear due to local rotation of the child or its children.
* Average: inherit uniform scale that represents the parent volume.
  This is the simplest foolproof solution that will inherit some
  scale without ever causing shear.
* None: completely remove scale and shear.
* None (Legacy): old disabled Inherit Scale checkbox.
  This mode does not handle parent shear in any way, so the child
  is likely to end up having both scale and shear. It is retained
  for backward compatibility.
Since many rigging-related addons access the use_inherit_scale
property from Python, it is retained as a backward compatibility
stub that provides the old functionality.
As a side effect of reworking the code, this also fixes a matrix
multiplication order bug in the Inherit Rotation code, which caused
the parent local scale to be applied in world space. In rigger
opinion this option is useless in production rigs, so this fix
should not be a problem.
Reviewers: brecht
Differential Revision: https://developer.blender.org/D5588
											
										 
											2019-09-04 10:10:27 +03:00
										 |  |  |     newBone->inherit_scale_mode = eBone->inherit_scale_mode; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (eBone == arm->act_edbone) { | 
					
						
							|  |  |  |       /* don't change active selection, this messes up separate which uses
 | 
					
						
							|  |  |  |        * editmode toggle and can separate active bone which is de-selected originally */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* important, editbones can be active with only 1 point selected */ | 
					
						
							|  |  |  |       /* newBone->flag |= BONE_SELECTED; */ | 
					
						
							|  |  |  |       arm->act_bone = newBone; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     newBone->roll = 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     newBone->weight = eBone->weight; | 
					
						
							|  |  |  |     newBone->dist = eBone->dist; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     newBone->xwidth = eBone->xwidth; | 
					
						
							|  |  |  |     newBone->zwidth = eBone->zwidth; | 
					
						
							|  |  |  |     newBone->rad_head = eBone->rad_head; | 
					
						
							|  |  |  |     newBone->rad_tail = eBone->rad_tail; | 
					
						
							|  |  |  |     newBone->segments = eBone->segments; | 
					
						
							|  |  |  |     newBone->layer = eBone->layer; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Bendy-Bone parameters */ | 
					
						
							|  |  |  |     newBone->roll1 = eBone->roll1; | 
					
						
							|  |  |  |     newBone->roll2 = eBone->roll2; | 
					
						
							| 
									
										
										
										
											2019-04-23 13:15:30 +03:00
										 |  |  |     newBone->curve_in_x = eBone->curve_in_x; | 
					
						
							|  |  |  |     newBone->curve_in_y = eBone->curve_in_y; | 
					
						
							|  |  |  |     newBone->curve_out_x = eBone->curve_out_x; | 
					
						
							|  |  |  |     newBone->curve_out_y = eBone->curve_out_y; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     newBone->ease1 = eBone->ease1; | 
					
						
							|  |  |  |     newBone->ease2 = eBone->ease2; | 
					
						
							| 
									
										
										
										
											2019-04-20 18:06:31 +03:00
										 |  |  |     newBone->scale_in_x = eBone->scale_in_x; | 
					
						
							|  |  |  |     newBone->scale_in_y = eBone->scale_in_y; | 
					
						
							|  |  |  |     newBone->scale_out_x = eBone->scale_out_x; | 
					
						
							|  |  |  |     newBone->scale_out_y = eBone->scale_out_y; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     newBone->bbone_prev_type = eBone->bbone_prev_type; | 
					
						
							|  |  |  |     newBone->bbone_next_type = eBone->bbone_next_type; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     if (eBone->prop) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       newBone->prop = IDP_CopyProperty(eBone->prop); | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Fix parenting in a separate pass to ensure ebone->bone connections are valid at this point.
 | 
					
						
							|  |  |  |    * Do not set bone->head/tail here anymore, | 
					
						
							|  |  |  |    * using EditBone data for that is not OK since our later fiddling with parent's arm_mat | 
					
						
							|  |  |  |    * (for roll conversion) may have some small but visible impact on locations (T46010). */ | 
					
						
							|  |  |  |   for (eBone = arm->edbo->first; eBone; eBone = eBone->next) { | 
					
						
							|  |  |  |     newBone = eBone->temp.bone; | 
					
						
							|  |  |  |     if (eBone->parent) { | 
					
						
							|  |  |  |       newBone->parent = eBone->parent->temp.bone; | 
					
						
							|  |  |  |       BLI_addtail(&newBone->parent->childbase, newBone); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     /*  ...otherwise add this bone to the armature's bonebase */ | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       BLI_addtail(&arm->bonebase, newBone); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Also transfer B-Bone custom handles. */ | 
					
						
							|  |  |  |     if (eBone->bbone_prev) { | 
					
						
							|  |  |  |       newBone->bbone_prev = eBone->bbone_prev->temp.bone; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (eBone->bbone_next) { | 
					
						
							|  |  |  |       newBone->bbone_next = eBone->bbone_next->temp.bone; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Finalize definition of restpose data (roll, bone_mat, arm_mat, head/tail...). */ | 
					
						
							|  |  |  |   armature_finalize_restpose(&arm->bonebase, arm->edbo); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-14 21:48:22 +03:00
										 |  |  |   BKE_armature_bone_hash_make(arm); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* so all users of this armature should get rebuilt */ | 
					
						
							|  |  |  |   for (obt = bmain->objects.first; obt; obt = obt->id.next) { | 
					
						
							|  |  |  |     if (obt->data == arm) { | 
					
						
							|  |  |  |       BKE_pose_rebuild(bmain, obt, arm, true); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   DEG_id_tag_update(&arm->id, 0); | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-17 22:13:15 +11:00
										 |  |  | void ED_armature_edit_free(struct bArmature *arm) | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   EditBone *eBone; | 
					
						
							| 
									
										
										
										
											2018-06-04 09:31:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-29 16:33:51 +11:00
										 |  |  |   /* Clear the edit-bones list. */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (arm->edbo) { | 
					
						
							|  |  |  |     if (arm->edbo->first) { | 
					
						
							|  |  |  |       for (eBone = arm->edbo->first; eBone; eBone = eBone->next) { | 
					
						
							|  |  |  |         if (eBone->prop) { | 
					
						
							|  |  |  |           IDP_FreeProperty(eBone->prop); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-06-04 09:31:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       BLI_freelistN(arm->edbo); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     MEM_freeN(arm->edbo); | 
					
						
							|  |  |  |     arm->edbo = NULL; | 
					
						
							|  |  |  |     arm->act_edbone = NULL; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Put armature in EditMode */ | 
					
						
							| 
									
										
										
										
											2013-12-17 22:13:15 +11:00
										 |  |  | void ED_armature_to_edit(bArmature *arm) | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   ED_armature_edit_free(arm); | 
					
						
							|  |  |  |   arm->edbo = MEM_callocN(sizeof(ListBase), "edbo armature"); | 
					
						
							|  |  |  |   arm->act_edbone = make_boneList(arm->edbo, &arm->bonebase, arm->act_bone); | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* *************************************************************** */ | 
					
						
							| 
									
										
										
										
											2018-03-19 17:10:07 +01:00
										 |  |  | /* Used by Undo for Armature EditMode*/ | 
					
						
							| 
									
										
											  
											
												Code Maintenance - Splitting up Armature/Pose Editing Files
This commit splits editarmature.c and poseobject.c into several files, such that
certain types of functionality are (mostly) self-contained within particular
files (instead of being mixed in with other functionality in a large file).
In particular, this was done so that:
1) Armature EditMode tools are now in the armature_*.c files only, and Pose Mode
tools in pose_*.c files only.
     - In one or two cases, this hasn't been possible as the two modes rely on
much of the same shared infrastructure.
2) The "clear loc/rot/scale" operators and pose show/hide are no longer housed
in editarmature.c
3) Selection operators, Transform operators, structural (add/delete) operators,
and supporting utilities for the modes (enter/exit/roll-calculations) are not
all interleaved in an ad-hoc manner
Notes:
* I've tried to ensure that the history of the new files has been maintained by
doing
   svn copy {editarmature.c/poseobject.c} {armature_*.c/pose_*.c}
   Unfortunately, this means that the diffs are a bit messy.
* There should be no functional/logic changes here. Just code moving around and
cosmetic comment tweaks where needed.
* #includes have largely been untouched for now, but could be cleaned up later
* CMake changes untested, but should work in theory.
											
										 
											2013-02-27 23:34:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-07-11 11:38:28 +00:00
										 |  |  | /* free's bones and their properties */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-19 17:10:07 +01:00
										 |  |  | void ED_armature_ebone_listbase_free(ListBase *lb) | 
					
						
							| 
									
										
										
										
											2013-07-11 11:38:28 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   EditBone *ebone, *ebone_next; | 
					
						
							| 
									
										
										
										
											2013-07-11 11:38:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   for (ebone = lb->first; ebone; ebone = ebone_next) { | 
					
						
							|  |  |  |     ebone_next = ebone->next; | 
					
						
							| 
									
										
										
										
											2013-07-11 11:38:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     if (ebone->prop) { | 
					
						
							|  |  |  |       IDP_FreeProperty(ebone->prop); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-07-11 11:38:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     MEM_freeN(ebone); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-07-11 11:38:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   BLI_listbase_clear(lb); | 
					
						
							| 
									
										
										
										
											2013-07-11 11:38:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-19 17:10:07 +01:00
										 |  |  | void ED_armature_ebone_listbase_copy(ListBase *lb_dst, ListBase *lb_src) | 
					
						
							| 
									
										
										
										
											2013-07-11 11:38:28 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   EditBone *ebone_src; | 
					
						
							|  |  |  |   EditBone *ebone_dst; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   BLI_assert(BLI_listbase_is_empty(lb_dst)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (ebone_src = lb_src->first; ebone_src; ebone_src = ebone_src->next) { | 
					
						
							|  |  |  |     ebone_dst = MEM_dupallocN(ebone_src); | 
					
						
							|  |  |  |     if (ebone_dst->prop) { | 
					
						
							|  |  |  |       ebone_dst->prop = IDP_CopyProperty(ebone_dst->prop); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     ebone_src->temp.ebone = ebone_dst; | 
					
						
							|  |  |  |     BLI_addtail(lb_dst, ebone_dst); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* set pointers */ | 
					
						
							|  |  |  |   for (ebone_dst = lb_dst->first; ebone_dst; ebone_dst = ebone_dst->next) { | 
					
						
							|  |  |  |     if (ebone_dst->parent) { | 
					
						
							|  |  |  |       ebone_dst->parent = ebone_dst->parent->temp.ebone; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (ebone_dst->bbone_next) { | 
					
						
							|  |  |  |       ebone_dst->bbone_next = ebone_dst->bbone_next->temp.ebone; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (ebone_dst->bbone_prev) { | 
					
						
							|  |  |  |       ebone_dst->bbone_prev = ebone_dst->bbone_prev->temp.ebone; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-07-11 11:38:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-28 04:34:28 +11:00
										 |  |  | void ED_armature_ebone_listbase_temp_clear(ListBase *lb) | 
					
						
							| 
									
										
										
										
											2013-07-11 11:38:28 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   EditBone *ebone; | 
					
						
							|  |  |  |   /* be sure they don't hang ever */ | 
					
						
							|  |  |  |   for (ebone = lb->first; ebone; ebone = ebone->next) { | 
					
						
							|  |  |  |     ebone->temp.p = NULL; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-07-11 11:38:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-07-16 01:49:20 +00:00
										 |  |  | /* *************************************************************** */ | 
					
						
							|  |  |  | /* Low level selection functions which hide connected-parent
 | 
					
						
							|  |  |  |  * flag behavior which gets tricky to handle in selection operators. | 
					
						
							|  |  |  |  * (no flushing in ED_armature_ebone_select.*, that should be explicit) */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int ED_armature_ebone_selectflag_get(const EditBone *ebone) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (ebone->parent && (ebone->flag & BONE_CONNECTED)) { | 
					
						
							|  |  |  |     return ((ebone->flag & (BONE_SELECTED | BONE_TIPSEL)) | | 
					
						
							|  |  |  |             ((ebone->parent->flag & BONE_TIPSEL) ? BONE_ROOTSEL : 0)); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     return (ebone->flag & (BONE_SELECTED | BONE_ROOTSEL | BONE_TIPSEL)); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-07-16 01:49:20 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ED_armature_ebone_selectflag_set(EditBone *ebone, int flag) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   flag = flag & (BONE_SELECTED | BONE_ROOTSEL | BONE_TIPSEL); | 
					
						
							| 
									
										
										
										
											2013-07-16 01:49:20 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (ebone->parent && (ebone->flag & BONE_CONNECTED)) { | 
					
						
							|  |  |  |     ebone->flag &= ~(BONE_SELECTED | BONE_ROOTSEL | BONE_TIPSEL); | 
					
						
							|  |  |  |     ebone->parent->flag &= ~BONE_TIPSEL; | 
					
						
							| 
									
										
										
										
											2013-07-16 01:49:20 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     ebone->flag |= flag; | 
					
						
							|  |  |  |     ebone->parent->flag |= (flag & BONE_ROOTSEL) ? BONE_TIPSEL : 0; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     ebone->flag &= ~(BONE_SELECTED | BONE_ROOTSEL | BONE_TIPSEL); | 
					
						
							|  |  |  |     ebone->flag |= flag; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-07-16 01:49:20 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ED_armature_ebone_selectflag_enable(EditBone *ebone, int flag) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   BLI_assert((flag & (BONE_SELECTED | BONE_ROOTSEL | BONE_TIPSEL)) != 0); | 
					
						
							|  |  |  |   ED_armature_ebone_selectflag_set(ebone, ebone->flag | flag); | 
					
						
							| 
									
										
										
										
											2013-07-16 01:49:20 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ED_armature_ebone_selectflag_disable(EditBone *ebone, int flag) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   BLI_assert((flag & (BONE_SELECTED | BONE_ROOTSEL | BONE_TIPSEL)) != 0); | 
					
						
							|  |  |  |   ED_armature_ebone_selectflag_set(ebone, ebone->flag & ~flag); | 
					
						
							| 
									
										
										
										
											2013-07-16 01:49:20 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* could be used in more places */ | 
					
						
							|  |  |  | void ED_armature_ebone_select_set(EditBone *ebone, bool select) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   int flag; | 
					
						
							|  |  |  |   if (select) { | 
					
						
							|  |  |  |     BLI_assert((ebone->flag & BONE_UNSELECTABLE) == 0); | 
					
						
							|  |  |  |     flag = (BONE_SELECTED | BONE_TIPSEL | BONE_ROOTSEL); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     flag = 0; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   ED_armature_ebone_selectflag_set(ebone, flag); | 
					
						
							| 
									
										
										
										
											2013-07-16 01:49:20 +00:00
										 |  |  | } |