e80d4d017d9c3c0d58c4f874c6673e0f9cebf743
[blender-staging.git] / source / blender / editors / armature / armature_ops.c
1 /**
2  * $Id:
3  *
4  * ***** BEGIN GPL LICENSE BLOCK *****
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License
8  * as published by the Free Software Foundation; either version 2
9  * of the License, or (at your option) any later version. 
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software Foundation,
18  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
19  *
20  * The Original Code is Copyright (C) 2009 Blender Foundation.
21  * All rights reserved.
22  *
23  * 
24  * Contributor(s): Blender Foundation
25  *
26  * ***** END GPL LICENSE BLOCK *****
27  */
28
29 #include <stdlib.h>
30 #include <math.h>
31
32 #include "MEM_guardedalloc.h"
33
34 #include "DNA_object_types.h"
35 #include "DNA_scene_types.h"
36 #include "DNA_screen_types.h"
37 #include "DNA_space_types.h"
38 #include "DNA_userdef_types.h"
39 #include "DNA_view3d_types.h"
40 #include "DNA_windowmanager_types.h"
41
42 #include "BLI_arithb.h"
43 #include "BLI_blenlib.h"
44
45 #include "BKE_context.h"
46 #include "BKE_global.h"
47 #include "BKE_utildefines.h"
48
49 #include "RNA_access.h"
50 #include "RNA_define.h"
51
52 #include "WM_api.h"
53 #include "WM_types.h"
54
55 #include "ED_armature.h"
56 #include "ED_screen.h"
57 #include "ED_object.h"
58
59 #include "armature_intern.h"
60
61 /* ************************** quick tests **********************************/
62
63 /*  XXX This is a quick test operator to print names of all EditBones in context
64  *              that should be removed once tool coding starts...
65  */
66
67 static int armature_test_exec (bContext *C, wmOperator *op)
68 {
69         printf("EditMode Armature Test: \n");
70         
71         printf("\tSelected Bones \n");
72         CTX_DATA_BEGIN(C, EditBone*, ebone, selected_bones)
73         {
74                 printf("\t\tEditBone '%s' \n", ebone->name);
75         }
76         CTX_DATA_END;
77         
78         printf("\tEditable Bones \n");
79         CTX_DATA_BEGIN(C, EditBone*, ebone, selected_editable_bones) 
80         {
81                 printf("\t\tEditBone '%s' \n", ebone->name);
82         }
83         CTX_DATA_END;
84         
85         printf("\tActive Bone \n");
86         {
87                 EditBone *ebone= CTX_data_active_bone(C);
88                 if (ebone) printf("\t\tEditBone '%s' \n", ebone->name);
89                 else printf("\t\t<None> \n");
90         }
91         
92         return OPERATOR_FINISHED;
93 }
94
95 void ARMATURE_OT_test(wmOperatorType *ot)
96 {
97         /* identifiers */
98         ot->name= "Test Context";
99         ot->idname= "ARMATURE_OT_test";
100         
101         /* api callbacks */
102         ot->exec= armature_test_exec;
103 }
104
105 /* ************************** registration **********************************/
106
107 /* Both operators ARMATURE_OT_xxx and POSE_OT_xxx here */
108 void ED_operatortypes_armature(void)
109 {
110         /* EDIT ARMATURE */
111         WM_operatortype_append(ARMATURE_OT_bone_primitive_add);
112         
113         WM_operatortype_append(ARMATURE_OT_align_bones);
114         WM_operatortype_append(ARMATURE_OT_calculate_roll);
115         WM_operatortype_append(ARMATURE_OT_switch_direction);
116         WM_operatortype_append(ARMATURE_OT_subdivs);
117         WM_operatortype_append(ARMATURE_OT_subdivide_simple);
118         WM_operatortype_append(ARMATURE_OT_subdivide_multi);
119         
120         WM_operatortype_append(ARMATURE_OT_parent_set);
121         WM_operatortype_append(ARMATURE_OT_parent_clear);
122         
123         WM_operatortype_append(ARMATURE_OT_de_select_all);
124         WM_operatortype_append(ARMATURE_OT_selection_invert);
125         WM_operatortype_append(ARMATURE_OT_select_hierarchy);
126         WM_operatortype_append(ARMATURE_OT_select_connected);
127
128         WM_operatortype_append(ARMATURE_OT_delete_selected);
129         WM_operatortype_append(ARMATURE_OT_duplicate_selected);
130         WM_operatortype_append(ARMATURE_OT_extrude);
131         WM_operatortype_append(ARMATURE_OT_click_extrude);
132         
133         /* POSE */
134         WM_operatortype_append(POSE_OT_hide);
135         WM_operatortype_append(POSE_OT_reveal);
136         
137         WM_operatortype_append(POSE_OT_rot_clear);
138         WM_operatortype_append(POSE_OT_loc_clear);
139         WM_operatortype_append(POSE_OT_scale_clear);
140         
141         WM_operatortype_append(POSE_OT_de_select_all);
142         WM_operatortype_append(POSE_OT_selection_invert);
143
144         WM_operatortype_append(POSE_OT_select_parent);
145         WM_operatortype_append(POSE_OT_select_hierarchy);
146         WM_operatortype_append(POSE_OT_select_connected);
147         
148         WM_operatortype_append(ARMATURE_OT_test); // XXX temp test for context iterators... to be removed
149 }
150
151 void ED_keymap_armature(wmWindowManager *wm)
152 {
153         ListBase *keymap;
154         wmKeymapItem *kmi;
155         
156         /* Armature ------------------------ */
157         keymap= WM_keymap_listbase(wm, "Armature", 0, 0);
158         
159         /* only set in editmode armature, by space_view3d listener */
160 //      WM_keymap_add_item(keymap, "ARMATURE_OT_hide", HKEY, KM_PRESS, 0, 0);
161         WM_keymap_add_item(keymap, "ARMATURE_OT_align_bones", AKEY, KM_PRESS, KM_CTRL|KM_ALT, 0);
162         WM_keymap_add_item(keymap, "ARMATURE_OT_calculate_roll", NKEY, KM_PRESS, KM_CTRL, 0);
163         
164         WM_keymap_add_item(keymap, "ARMATURE_OT_switch_direction", FKEY, KM_PRESS, KM_ALT, 0);
165         
166         WM_keymap_add_item(keymap, "ARMATURE_OT_bone_primitive_add", AKEY, KM_PRESS, KM_SHIFT, 0);
167                 /* only the menu-version of subdivide is registered in keymaps for now */
168         WM_keymap_add_item(keymap, "ARMATURE_OT_subdivs", SKEY, KM_PRESS, KM_ALT, 0);
169         
170         WM_keymap_add_item(keymap, "ARMATURE_OT_set_parent", PKEY, KM_PRESS, KM_CTRL, 0);
171         WM_keymap_add_item(keymap, "ARMATURE_OT_clear_parent", PKEY, KM_PRESS, KM_ALT, 0);
172         
173         WM_keymap_add_item(keymap, "ARMATURE_OT_de_select_all", AKEY, KM_PRESS, 0, 0);
174         WM_keymap_add_item(keymap, "ARMATURE_OT_selection_invert", IKEY, KM_PRESS, KM_CTRL, 0);
175         
176         WM_keymap_add_item(keymap, "ARMATURE_OT_test", TKEY, KM_PRESS, 0, 0);  // XXX temp test for context iterators... to be removed
177
178         kmi= WM_keymap_add_item(keymap, "ARMATURE_OT_select_hierarchy", LEFTBRACKETKEY, KM_PRESS, 0, 0);
179         RNA_enum_set(kmi->ptr, "direction", BONE_SELECT_PARENT);
180         RNA_boolean_set(kmi->ptr, "add_to_sel", 0);
181         kmi= WM_keymap_add_item(keymap, "ARMATURE_OT_select_hierarchy", LEFTBRACKETKEY, KM_PRESS, KM_SHIFT, 0);
182         RNA_enum_set(kmi->ptr, "direction", BONE_SELECT_PARENT);
183         RNA_boolean_set(kmi->ptr, "add_to_sel", 1);
184         
185         kmi= WM_keymap_add_item(keymap, "ARMATURE_OT_select_hierarchy", RIGHTBRACKETKEY, KM_PRESS, 0, 0);
186         RNA_enum_set(kmi->ptr, "direction", BONE_SELECT_CHILD);
187         RNA_boolean_set(kmi->ptr, "add_to_sel", 0);
188         kmi= WM_keymap_add_item(keymap, "ARMATURE_OT_select_hierarchy", RIGHTBRACKETKEY, KM_PRESS, KM_SHIFT, 0);
189         RNA_enum_set(kmi->ptr, "direction", BONE_SELECT_CHILD);
190         RNA_boolean_set(kmi->ptr, "add_to_sel", 1);
191
192         WM_keymap_add_item(keymap, "ARMATURE_OT_select_connected", LKEY, KM_PRESS, 0, 0);
193         WM_keymap_add_item(keymap, "ARMATURE_OT_delete_selected", XKEY, KM_PRESS, 0, 0);
194         WM_keymap_add_item(keymap, "ARMATURE_OT_duplicate_selected", DKEY, KM_PRESS, KM_SHIFT, 0);
195         WM_keymap_add_item(keymap, "ARMATURE_OT_extrude", EKEY, KM_PRESS, 0, 0);
196         kmi= WM_keymap_add_item(keymap, "ARMATURE_OT_extrude", EKEY, KM_PRESS, KM_SHIFT, 0);
197         RNA_boolean_set(kmi->ptr, "forked", 1);
198         WM_keymap_add_item(keymap, "ARMATURE_OT_click_extrude", LEFTMOUSE, KM_PRESS, KM_CTRL, 0);
199         
200         /* Pose ------------------------ */
201         /* only set in posemode, by space_view3d listener */
202         keymap= WM_keymap_listbase(wm, "Pose", 0, 0);
203         
204         WM_keymap_add_item(keymap, "POSE_OT_hide", HKEY, KM_PRESS, 0, 0);
205         kmi= WM_keymap_add_item(keymap, "POSE_OT_hide", HKEY, KM_PRESS, KM_SHIFT, 0);
206         RNA_boolean_set(kmi->ptr, "unselected", 1);
207         WM_keymap_add_item(keymap, "POSE_OT_reveal", HKEY, KM_PRESS, KM_ALT, 0);
208         /*clear pose*/
209         WM_keymap_add_item(keymap, "POSE_OT_rot_clear", RKEY, KM_PRESS, KM_ALT, 0);
210         WM_keymap_add_item(keymap, "POSE_OT_loc_clear", GKEY, KM_PRESS, KM_ALT, 0);
211         WM_keymap_add_item(keymap, "POSE_OT_scale_clear", SKEY, KM_PRESS, KM_ALT, 0);
212         
213         WM_keymap_add_item(keymap, "POSE_OT_de_select_all", AKEY, KM_PRESS, 0, 0);
214         WM_keymap_add_item(keymap, "POSE_OT_selection_invert", IKEY, KM_PRESS, KM_CTRL, 0);
215
216         WM_keymap_add_item(keymap, "POSE_OT_select_parent", PKEY, KM_PRESS, KM_SHIFT, 0);
217
218         kmi= WM_keymap_add_item(keymap, "POSE_OT_select_hierarchy", LEFTBRACKETKEY, KM_PRESS, 0, 0);
219         RNA_enum_set(kmi->ptr, "direction", BONE_SELECT_PARENT);
220         RNA_boolean_set(kmi->ptr, "add_to_sel", 0);
221         kmi= WM_keymap_add_item(keymap, "POSE_OT_select_hierarchy", LEFTBRACKETKEY, KM_PRESS, KM_SHIFT, 0);
222         RNA_enum_set(kmi->ptr, "direction", BONE_SELECT_PARENT);
223         RNA_boolean_set(kmi->ptr, "add_to_sel", 1);
224         
225         kmi= WM_keymap_add_item(keymap, "POSE_OT_select_hierarchy", RIGHTBRACKETKEY, KM_PRESS, 0, 0);
226         RNA_enum_set(kmi->ptr, "direction", BONE_SELECT_CHILD);
227         RNA_boolean_set(kmi->ptr, "add_to_sel", 0);
228         kmi= WM_keymap_add_item(keymap, "POSE_OT_select_hierarchy", RIGHTBRACKETKEY, KM_PRESS, KM_SHIFT, 0);
229         RNA_enum_set(kmi->ptr, "direction", BONE_SELECT_CHILD);
230         RNA_boolean_set(kmi->ptr, "add_to_sel", 1);
231
232         WM_keymap_add_item(keymap, "POSE_OT_select_connected", LKEY, KM_PRESS, 0, 0);
233 }
234