sim: Remove "continue physics" code
[blender.git] / source / blender / blenkernel / intern / object_deform.c
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * ***** END GPL LICENSE BLOCK *****
19  */
20
21 /** \file blender/blenkernel/intern/object_deform.c
22  *  \ingroup bke
23  */
24
25 #include <stdlib.h>
26 #include <string.h>
27
28 #include "MEM_guardedalloc.h"
29
30 #include "BLI_utildefines.h"
31 #include "BLI_ghash.h"
32
33 #include "BKE_action.h"
34 #include "BKE_object_deform.h"  /* own include */
35 #include "BKE_object.h"
36 #include "BKE_modifier.h"
37
38 #include "DNA_armature_types.h"
39 #include "DNA_modifier_types.h"
40 #include "DNA_object_types.h"
41
42 /* --- functions for getting vgroup aligned maps --- */
43
44 /**
45  * gets the status of "flag" for each bDeformGroup
46  * in ob->defbase and returns an array containing them
47  */
48 char *BKE_objdef_lock_flags_get(Object *ob, const int defbase_tot)
49 {
50         char is_locked = FALSE;
51         int i;
52         //int defbase_tot = BLI_countlist(&ob->defbase);
53         char *lock_flags = MEM_mallocN(defbase_tot * sizeof(char), "defflags");
54         bDeformGroup *defgroup;
55
56         for (i = 0, defgroup = ob->defbase.first; i < defbase_tot && defgroup; defgroup = defgroup->next, i++) {
57                 lock_flags[i] = ((defgroup->flag & DG_LOCK_WEIGHT) != 0);
58                 is_locked |= lock_flags[i];
59         }
60         if (is_locked) {
61                 return lock_flags;
62         }
63
64         MEM_freeN(lock_flags);
65         return NULL;
66 }
67
68 char *BKE_objdef_validmap_get(Object *ob, const int defbase_tot)
69 {
70         bDeformGroup *dg;
71         ModifierData *md;
72         char *vgroup_validmap;
73         GHash *gh;
74         int i, step1 = 1;
75         //int defbase_tot = BLI_countlist(&ob->defbase);
76
77         if (ob->defbase.first == NULL) {
78                 return NULL;
79         }
80
81         gh = BLI_ghash_str_new("BKE_objdef_validmap_get gh");
82
83         /* add all names to a hash table */
84         for (dg = ob->defbase.first; dg; dg = dg->next) {
85                 BLI_ghash_insert(gh, dg->name, NULL);
86         }
87
88         BLI_assert(BLI_ghash_size(gh) == defbase_tot);
89
90         /* now loop through the armature modifiers and identify deform bones */
91         for (md = ob->modifiers.first; md; md = !md->next && step1 ? (step1 = 0), modifiers_getVirtualModifierList(ob) : md->next) {
92                 if (!(md->mode & (eModifierMode_Realtime | eModifierMode_Virtual)))
93                         continue;
94
95                 if (md->type == eModifierType_Armature) {
96                         ArmatureModifierData *amd = (ArmatureModifierData *) md;
97
98                         if (amd->object && amd->object->pose) {
99                                 bPose *pose = amd->object->pose;
100                                 bPoseChannel *chan;
101
102                                 for (chan = pose->chanbase.first; chan; chan = chan->next) {
103                                         if (chan->bone->flag & BONE_NO_DEFORM)
104                                                 continue;
105
106                                         if (BLI_ghash_remove(gh, chan->name, NULL, NULL)) {
107                                                 BLI_ghash_insert(gh, chan->name, SET_INT_IN_POINTER(1));
108                                         }
109                                 }
110                         }
111                 }
112         }
113
114         vgroup_validmap = MEM_mallocN(defbase_tot, "wpaint valid map");
115
116         /* add all names to a hash table */
117         for (dg = ob->defbase.first, i = 0; dg; dg = dg->next, i++) {
118                 vgroup_validmap[i] = (BLI_ghash_lookup(gh, dg->name) != NULL);
119         }
120
121         BLI_assert(i == BLI_ghash_size(gh));
122
123         BLI_ghash_free(gh, NULL, NULL);
124
125         return vgroup_validmap;
126 }
127
128 /* Returns total selected vgroups,
129  * wpi.defbase_sel is assumed malloc'd, all values are set */
130 char *BKE_objdef_selected_get(Object *ob, int defbase_tot, int *r_dg_flags_sel_tot)
131 {
132         char *dg_selection = MEM_mallocN(defbase_tot * sizeof(char), __func__);
133         bDeformGroup *defgroup;
134         unsigned int i;
135         Object *armob = BKE_object_pose_armature_get(ob);
136         (*r_dg_flags_sel_tot) = 0;
137
138         if (armob) {
139                 bPose *pose = armob->pose;
140                 for (i = 0, defgroup = ob->defbase.first; i < defbase_tot && defgroup; defgroup = defgroup->next, i++) {
141                         bPoseChannel *pchan = BKE_pose_channel_find_name(pose, defgroup->name);
142                         if (pchan && (pchan->bone->flag & BONE_SELECTED)) {
143                                 dg_selection[i] = TRUE;
144                                 (*r_dg_flags_sel_tot) += 1;
145                         }
146                         else {
147                                 dg_selection[i] = FALSE;
148                         }
149                 }
150         }
151         else {
152                 memset(dg_selection, FALSE, sizeof(char) * defbase_tot);
153         }
154
155         return dg_selection;
156 }