[#24594] Edge weighting while making subsurf
[blender.git] / source / blender / editors / mesh / mesh_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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, 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
33 #include "DNA_object_types.h"
34 #include "DNA_scene_types.h"
35
36 #include "BLI_math.h"
37 #include "BLI_blenlib.h"
38 #include "BLI_editVert.h"
39
40 #include "BKE_context.h"
41
42 #include "RNA_access.h"
43
44 #include "WM_api.h"
45 #include "WM_types.h"
46
47 #include "ED_object.h"
48 #include "ED_screen.h"
49 #include "ED_view3d.h"
50
51
52 #include "mesh_intern.h"
53
54 /**************************** registration **********************************/
55
56 void ED_operatortypes_mesh(void)
57 {
58         WM_operatortype_append(MESH_OT_select_all);
59         WM_operatortype_append(MESH_OT_select_more);
60         WM_operatortype_append(MESH_OT_select_less);
61         WM_operatortype_append(MESH_OT_select_inverse);
62         WM_operatortype_append(MESH_OT_select_non_manifold);
63         WM_operatortype_append(MESH_OT_select_linked);
64         WM_operatortype_append(MESH_OT_select_linked_pick);
65         WM_operatortype_append(MESH_OT_select_random);
66         WM_operatortype_append(MESH_OT_hide);
67         WM_operatortype_append(MESH_OT_reveal);
68         WM_operatortype_append(MESH_OT_select_by_number_vertices);
69         WM_operatortype_append(MESH_OT_select_mirror);
70         WM_operatortype_append(MESH_OT_normals_make_consistent);
71         WM_operatortype_append(MESH_OT_merge);
72         WM_operatortype_append(MESH_OT_subdivide);
73         WM_operatortype_append(MESH_OT_faces_select_linked_flat);
74         WM_operatortype_append(MESH_OT_edges_select_sharp);
75         WM_operatortype_append(MESH_OT_primitive_plane_add);
76         WM_operatortype_append(MESH_OT_primitive_cube_add);
77         WM_operatortype_append(MESH_OT_primitive_circle_add);
78         WM_operatortype_append(MESH_OT_primitive_cylinder_add);
79         WM_operatortype_append(MESH_OT_primitive_cone_add);
80         WM_operatortype_append(MESH_OT_primitive_grid_add);
81         WM_operatortype_append(MESH_OT_primitive_monkey_add);
82         WM_operatortype_append(MESH_OT_primitive_uv_sphere_add);
83         WM_operatortype_append(MESH_OT_primitive_ico_sphere_add);
84         WM_operatortype_append(MESH_OT_fgon_clear);
85         WM_operatortype_append(MESH_OT_fgon_make);
86         WM_operatortype_append(MESH_OT_duplicate);
87         WM_operatortype_append(MESH_OT_remove_doubles);
88         WM_operatortype_append(MESH_OT_extrude);
89         WM_operatortype_append(MESH_OT_spin);
90         WM_operatortype_append(MESH_OT_screw);
91         
92         WM_operatortype_append(MESH_OT_split);
93         WM_operatortype_append(MESH_OT_extrude_repeat);
94         WM_operatortype_append(MESH_OT_edge_rotate);
95         WM_operatortype_append(MESH_OT_select_vertex_path);
96         WM_operatortype_append(MESH_OT_loop_to_region);
97         WM_operatortype_append(MESH_OT_region_to_loop);
98         WM_operatortype_append(MESH_OT_select_axis);
99         
100         WM_operatortype_append(MESH_OT_uvs_rotate);
101         WM_operatortype_append(MESH_OT_uvs_mirror);
102         WM_operatortype_append(MESH_OT_colors_rotate);
103         WM_operatortype_append(MESH_OT_colors_mirror);
104         
105         WM_operatortype_append(MESH_OT_fill);
106         WM_operatortype_append(MESH_OT_beautify_fill);
107         WM_operatortype_append(MESH_OT_quads_convert_to_tris);
108         WM_operatortype_append(MESH_OT_tris_convert_to_quads);
109         WM_operatortype_append(MESH_OT_edge_flip);
110         WM_operatortype_append(MESH_OT_faces_shade_smooth);
111         WM_operatortype_append(MESH_OT_faces_shade_flat);
112         WM_operatortype_append(MESH_OT_sort_faces);
113
114         WM_operatortype_append(MESH_OT_delete);
115
116         WM_operatortype_append(MESH_OT_separate);
117         WM_operatortype_append(MESH_OT_dupli_extrude_cursor);
118         WM_operatortype_append(MESH_OT_loop_select);
119         WM_operatortype_append(MESH_OT_edge_face_add);
120         WM_operatortype_append(MESH_OT_select_shortest_path);
121         WM_operatortype_append(MESH_OT_select_similar);
122         WM_operatortype_append(MESH_OT_loop_multi_select);
123         WM_operatortype_append(MESH_OT_mark_seam);
124         WM_operatortype_append(MESH_OT_mark_sharp);
125         WM_operatortype_append(MESH_OT_vertices_smooth);
126         WM_operatortype_append(MESH_OT_noise);
127         WM_operatortype_append(MESH_OT_flip_normals);
128         WM_operatortype_append(MESH_OT_knife_cut);
129         WM_operatortype_append(MESH_OT_rip);
130         WM_operatortype_append(MESH_OT_blend_from_shape);
131         WM_operatortype_append(MESH_OT_shape_propagate_to_all);
132         
133         WM_operatortype_append(MESH_OT_uv_texture_add);
134         WM_operatortype_append(MESH_OT_uv_texture_remove);
135         WM_operatortype_append(MESH_OT_vertex_color_add);
136         WM_operatortype_append(MESH_OT_vertex_color_remove);
137         WM_operatortype_append(MESH_OT_sticky_add);
138         WM_operatortype_append(MESH_OT_sticky_remove);
139         WM_operatortype_append(MESH_OT_drop_named_image);
140
141         WM_operatortype_append(MESH_OT_edgering_select);
142         WM_operatortype_append(MESH_OT_loopcut);
143
144         WM_operatortype_append(MESH_OT_solidify);
145         WM_operatortype_append(MESH_OT_select_nth);
146 }
147
148 int ED_operator_editmesh_face_select(bContext *C)
149 {
150         Object *obedit= CTX_data_edit_object(C);
151         if(obedit && obedit->type==OB_MESH) {
152                 EditMesh *em = ((Mesh *)obedit->data)->edit_mesh;
153                 if (em && em->selectmode & SCE_SELECT_FACE) {
154                         return 1;
155                 }
156         }
157         return 0;
158 }
159
160 void ED_operatormacros_mesh(void)
161 {
162         wmOperatorType *ot;
163         wmOperatorTypeMacro *otmacro;
164         
165         ot= WM_operatortype_append_macro("MESH_OT_loopcut_slide", "Loop Cut and Slide", OPTYPE_UNDO|OPTYPE_REGISTER);
166         ot->description = "Cut mesh loop and slide it";
167         WM_operatortype_macro_define(ot, "MESH_OT_loopcut");
168         WM_operatortype_macro_define(ot, "TRANSFORM_OT_edge_slide");
169
170         ot= WM_operatortype_append_macro("MESH_OT_duplicate_move", "Add Duplicate", OPTYPE_UNDO|OPTYPE_REGISTER);
171         ot->description = "Duplicate mesh and move";
172         WM_operatortype_macro_define(ot, "MESH_OT_duplicate");
173         otmacro= WM_operatortype_macro_define(ot, "TRANSFORM_OT_translate");
174         RNA_enum_set(otmacro->ptr, "proportional", 0);
175         RNA_boolean_set(otmacro->ptr, "mirror", 0);
176
177         ot= WM_operatortype_append_macro("MESH_OT_rip_move", "Rip", OPTYPE_UNDO|OPTYPE_REGISTER);
178         ot->description = "Rip polygons and move the result";
179         WM_operatortype_macro_define(ot, "MESH_OT_rip");
180         otmacro= WM_operatortype_macro_define(ot, "TRANSFORM_OT_translate");
181         RNA_enum_set(otmacro->ptr, "proportional", 0);
182         RNA_boolean_set(otmacro->ptr, "mirror", 0);
183
184         ot= WM_operatortype_append_macro("MESH_OT_extrude_region_move", "Extrude Region and Move", OPTYPE_UNDO|OPTYPE_REGISTER);
185         ot->description = "Extrude region and move result";
186         otmacro= WM_operatortype_macro_define(ot, "MESH_OT_extrude");
187         RNA_enum_set(otmacro->ptr, "type", 1);
188         otmacro= WM_operatortype_macro_define(ot, "TRANSFORM_OT_translate");
189         RNA_enum_set(otmacro->ptr, "proportional", 0);
190         RNA_boolean_set(otmacro->ptr, "mirror", 0);
191
192         ot= WM_operatortype_append_macro("MESH_OT_extrude_faces_move", "Extrude Individual Faces and Move", OPTYPE_UNDO|OPTYPE_REGISTER);
193         ot->description = "Extrude faces and move result";
194         otmacro= WM_operatortype_macro_define(ot, "MESH_OT_extrude");
195         RNA_enum_set(otmacro->ptr, "type", 2);
196         otmacro= WM_operatortype_macro_define(ot, "TRANSFORM_OT_shrink_fatten");
197         RNA_enum_set(otmacro->ptr, "proportional", 0);
198         RNA_boolean_set(otmacro->ptr, "mirror", 0);
199
200         ot= WM_operatortype_append_macro("MESH_OT_extrude_edges_move", "Extrude Only Edges and Move", OPTYPE_UNDO|OPTYPE_REGISTER);
201         ot->description = "Extrude edges and move result";
202         otmacro= WM_operatortype_macro_define(ot, "MESH_OT_extrude");
203         RNA_enum_set(otmacro->ptr, "type", 3);
204         otmacro= WM_operatortype_macro_define(ot, "TRANSFORM_OT_translate");
205         RNA_enum_set(otmacro->ptr, "proportional", 0);
206         RNA_boolean_set(otmacro->ptr, "mirror", 0);
207
208         ot= WM_operatortype_append_macro("MESH_OT_extrude_vertices_move", "Extrude Only Vertices and Move", OPTYPE_UNDO|OPTYPE_REGISTER);
209         ot->description = "Extrude vertices and move result";
210         otmacro= WM_operatortype_macro_define(ot, "MESH_OT_extrude");
211         RNA_enum_set(otmacro->ptr, "type", 4);
212         otmacro= WM_operatortype_macro_define(ot, "TRANSFORM_OT_translate");
213         RNA_enum_set(otmacro->ptr, "proportional", 0);
214         RNA_boolean_set(otmacro->ptr, "mirror", 0);
215 }
216
217 /* note mesh keymap also for other space? */
218 void ED_keymap_mesh(wmKeyConfig *keyconf)
219 {       
220         wmKeyMap *keymap;
221         wmKeyMapItem *kmi;
222         
223         keymap= WM_keymap_find(keyconf, "Mesh", 0, 0);
224         keymap->poll= ED_operator_editmesh;
225         
226         WM_keymap_add_item(keymap, "MESH_OT_loopcut_slide", RKEY, KM_PRESS, KM_CTRL, 0);
227
228         /* selecting */
229         /* standard mouse selection goes via space_view3d */
230         WM_keymap_add_item(keymap, "MESH_OT_loop_select", SELECTMOUSE, KM_PRESS, KM_ALT, 0);
231         kmi= WM_keymap_add_item(keymap, "MESH_OT_loop_select", SELECTMOUSE, KM_PRESS, KM_SHIFT|KM_ALT, 0);
232         RNA_boolean_set(kmi->ptr, "extend", 1);
233
234         kmi= WM_keymap_add_item(keymap, "MESH_OT_edgering_select", SELECTMOUSE, KM_PRESS, KM_ALT|KM_CTRL, 0);
235         kmi= WM_keymap_add_item(keymap, "MESH_OT_edgering_select", SELECTMOUSE, KM_PRESS, KM_SHIFT|KM_ALT|KM_CTRL, 0);
236         RNA_boolean_set(kmi->ptr, "extend", 1);
237
238         WM_keymap_add_item(keymap, "MESH_OT_select_shortest_path", SELECTMOUSE, KM_PRESS, KM_CTRL, 0);
239
240         WM_keymap_add_item(keymap, "MESH_OT_select_all", AKEY, KM_PRESS, 0, 0);
241         WM_keymap_add_item(keymap, "MESH_OT_select_more", PADPLUSKEY, KM_PRESS, KM_CTRL, 0);
242         WM_keymap_add_item(keymap, "MESH_OT_select_less", PADMINUS, KM_PRESS, KM_CTRL, 0);
243         WM_keymap_add_item(keymap, "MESH_OT_select_inverse", IKEY, KM_PRESS, KM_CTRL, 0);
244         WM_keymap_add_item(keymap, "MESH_OT_select_non_manifold", MKEY, KM_PRESS, (KM_CTRL|KM_SHIFT|KM_ALT), 0);
245         
246         WM_keymap_add_item(keymap, "MESH_OT_select_linked", LKEY, KM_PRESS, KM_CTRL, 0);
247         WM_keymap_add_item(keymap, "MESH_OT_select_linked_pick", LKEY, KM_PRESS, 0, 0);
248         RNA_boolean_set(WM_keymap_add_item(keymap, "MESH_OT_select_linked_pick", LKEY, KM_PRESS, KM_SHIFT, 0)->ptr, "deselect", 1);
249         
250         RNA_float_set(WM_keymap_add_item(keymap, "MESH_OT_faces_select_linked_flat", FKEY, KM_PRESS, (KM_CTRL|KM_SHIFT|KM_ALT), 0)->ptr,"sharpness",135.0);
251
252         WM_keymap_add_item(keymap, "MESH_OT_select_similar", GKEY, KM_PRESS, KM_SHIFT, 0);
253         
254         /* selection mode */
255         WM_keymap_add_menu(keymap, "VIEW3D_MT_edit_mesh_select_mode", TABKEY, KM_PRESS, KM_CTRL, 0);
256         
257         /* hide */
258         WM_keymap_add_item(keymap, "MESH_OT_hide", HKEY, KM_PRESS, 0, 0);
259         RNA_boolean_set(WM_keymap_add_item(keymap, "MESH_OT_hide", HKEY, KM_PRESS, KM_SHIFT, 0)->ptr, "unselected", 1);
260         WM_keymap_add_item(keymap, "MESH_OT_reveal", HKEY, KM_PRESS, KM_ALT, 0);
261
262         /* tools */
263         WM_keymap_add_item(keymap, "MESH_OT_normals_make_consistent", NKEY, KM_PRESS, KM_CTRL, 0);
264         RNA_boolean_set(WM_keymap_add_item(keymap, "MESH_OT_normals_make_consistent", NKEY, KM_PRESS, KM_SHIFT|KM_CTRL, 0)->ptr, "inside", 1);
265         
266         WM_keymap_add_item(keymap, "VIEW3D_OT_edit_mesh_extrude_move_normal", EKEY, KM_PRESS, 0, 0); /* python operator */
267         WM_keymap_add_menu(keymap, "VIEW3D_MT_edit_mesh_extrude", EKEY, KM_PRESS, KM_ALT, 0);
268         
269         WM_keymap_add_item(keymap, "TRANSFORM_OT_edge_crease", EKEY, KM_PRESS, KM_SHIFT, 0);
270         
271         WM_keymap_add_item(keymap, "MESH_OT_spin", RKEY, KM_PRESS, KM_ALT, 0);
272         
273         WM_keymap_add_item(keymap, "MESH_OT_fill", FKEY, KM_PRESS, KM_ALT, 0);
274         WM_keymap_add_item(keymap, "MESH_OT_beautify_fill", FKEY, KM_PRESS, KM_SHIFT|KM_ALT, 0);
275         WM_keymap_add_item(keymap, "MESH_OT_sort_faces", FKEY, KM_PRESS, KM_ALT|KM_CTRL, 0);
276         WM_keymap_add_item(keymap, "MESH_OT_quads_convert_to_tris", TKEY, KM_PRESS, KM_CTRL, 0);
277         WM_keymap_add_item(keymap, "MESH_OT_tris_convert_to_quads", JKEY, KM_PRESS, KM_ALT, 0);
278         WM_keymap_add_item(keymap, "MESH_OT_edge_flip", FKEY, KM_PRESS, KM_SHIFT|KM_CTRL, 0);
279
280         WM_keymap_add_item(keymap, "MESH_OT_rip_move",VKEY, KM_PRESS, 0, 0);
281         WM_keymap_add_item(keymap, "MESH_OT_merge", MKEY, KM_PRESS, KM_ALT, 0);
282
283         WM_keymap_add_item(keymap, "TRANSFORM_OT_shrink_fatten", SKEY, KM_PRESS, KM_ALT, 0);
284
285         /* add/remove */
286         WM_keymap_add_item(keymap, "MESH_OT_edge_face_add", FKEY, KM_PRESS, 0, 0);
287 //      WM_keymap_add_item(keymap, "MESH_OT_skin", FKEY, KM_PRESS, KM_CTRL|KM_ALT, 0); /* python, removed */
288         WM_keymap_add_item(keymap, "MESH_OT_duplicate_move", DKEY, KM_PRESS, KM_SHIFT, 0);
289         
290         WM_keymap_add_menu(keymap, "INFO_MT_mesh_add", AKEY, KM_PRESS, KM_SHIFT, 0);
291         
292         WM_keymap_add_item(keymap, "MESH_OT_separate", PKEY, KM_PRESS, 0, 0);
293         WM_keymap_add_item(keymap, "MESH_OT_split", YKEY, KM_PRESS, 0, 0);
294
295         /* use KM_CLICK because same key is used for tweaks */
296         WM_keymap_add_item(keymap, "MESH_OT_dupli_extrude_cursor", ACTIONMOUSE, KM_CLICK, KM_CTRL, 0);
297         RNA_boolean_set(WM_keymap_add_item(keymap, "MESH_OT_dupli_extrude_cursor", ACTIONMOUSE, KM_CLICK, KM_SHIFT|KM_CTRL, 0)->ptr, "rotate_source", 0);
298
299         WM_keymap_add_item(keymap, "MESH_OT_delete", XKEY, KM_PRESS, 0, 0);
300         WM_keymap_add_item(keymap, "MESH_OT_delete", DELKEY, KM_PRESS, 0, 0);
301         
302         WM_keymap_add_item(keymap, "MESH_OT_knife_cut", LEFTMOUSE, KM_PRESS, 0, KKEY);
303         RNA_enum_set(WM_keymap_add_item(keymap, "MESH_OT_knife_cut", LEFTMOUSE, KM_PRESS, KM_SHIFT, KKEY)->ptr, "type", 2/*KNIFE_MIDPOINT*/);
304         
305         WM_keymap_add_item(keymap, "OBJECT_OT_vertex_parent_set", PKEY, KM_PRESS, KM_CTRL, 0);
306
307         /* menus */
308         WM_keymap_add_menu(keymap, "VIEW3D_MT_edit_mesh_specials", WKEY, KM_PRESS, 0, 0);
309         WM_keymap_add_menu(keymap, "VIEW3D_MT_edit_mesh_faces", FKEY, KM_PRESS, KM_CTRL, 0);
310         WM_keymap_add_menu(keymap, "VIEW3D_MT_edit_mesh_edges", EKEY, KM_PRESS, KM_CTRL, 0);
311         WM_keymap_add_menu(keymap, "VIEW3D_MT_edit_mesh_vertices", VKEY, KM_PRESS, KM_CTRL, 0);
312         WM_keymap_add_menu(keymap, "VIEW3D_MT_hook", HKEY, KM_PRESS, KM_CTRL, 0);
313         WM_keymap_add_menu(keymap, "VIEW3D_MT_uv_map", UKEY, KM_PRESS, 0, 0);
314         WM_keymap_add_menu(keymap, "VIEW3D_MT_vertex_group", GKEY, KM_PRESS, KM_CTRL, 0);
315         
316         ED_object_generic_keymap(keyconf, keymap, 3);
317 }
318