remove unused rna includes
[blender.git] / source / blender / makesrna / intern / rna_lattice.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  * Contributor(s): Blender Foundation (2008).
21  *
22  * ***** END GPL LICENSE BLOCK *****
23  */
24
25 #include <stdlib.h>
26
27 #include "RNA_define.h"
28
29 #include "rna_internal.h"
30
31 #include "DNA_curve_types.h"
32 #include "DNA_key_types.h"
33 #include "DNA_lattice_types.h"
34 #include "DNA_meshdata_types.h"
35
36 #ifdef RNA_RUNTIME
37
38 #include "DNA_object_types.h"
39 #include "DNA_scene_types.h"
40
41 #include "BKE_depsgraph.h"
42 #include "BKE_lattice.h"
43 #include "BKE_main.h"
44
45 #include "WM_api.h"
46 #include "WM_types.h"
47
48 static void rna_LatticePoint_co_get(PointerRNA *ptr, float *values)
49 {
50         Lattice *lt= (Lattice*)ptr->id.data;
51         BPoint *bp= (BPoint*)ptr->data;
52         int a= bp - lt->def;
53         int x= a % lt->pntsu;
54         int y= (a/lt->pntsu) % lt->pntsv;
55         int z= (a/(lt->pntsu*lt->pntsv));
56
57         values[0]= lt->fu + x*lt->du;
58         values[1]= lt->fv + y*lt->dv;
59         values[2]= lt->fw + z*lt->dw;
60 }
61
62 static void rna_LatticePoint_groups_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
63 {
64         Lattice *lt= (Lattice*)ptr->id.data;
65
66         if(lt->dvert) {
67                 BPoint *bp= (BPoint*)ptr->data;
68                 MDeformVert *dvert= lt->dvert + (bp-lt->def);
69
70                 rna_iterator_array_begin(iter, (void*)dvert->dw, sizeof(MDeformWeight), dvert->totweight, 0, NULL);
71         }
72         else
73                 rna_iterator_array_begin(iter, NULL, 0, 0, 0, NULL);
74 }
75
76 static void rna_Lattice_points_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
77 {
78         Lattice *lt= (Lattice*)ptr->data;
79         int tot= lt->pntsu*lt->pntsv*lt->pntsw;
80
81         if(lt->editlatt && lt->editlatt->def)
82                 rna_iterator_array_begin(iter, (void*)lt->editlatt->def, sizeof(BPoint), tot, 0, NULL);
83         else if(lt->def)
84                 rna_iterator_array_begin(iter, (void*)lt->def, sizeof(BPoint), tot, 0, NULL);
85         else
86                 rna_iterator_array_begin(iter, NULL, 0, 0, 0, NULL);
87 }
88
89 static void rna_Lattice_update_data(Main *bmain, Scene *scene, PointerRNA *ptr)
90 {
91         ID *id= ptr->id.data;
92
93         DAG_id_flush_update(id, OB_RECALC_DATA);
94         WM_main_add_notifier(NC_GEOM|ND_DATA, id);
95 }
96
97 static void rna_Lattice_update_size(Main *bmain, Scene *scene, PointerRNA *ptr)
98 {
99         Lattice *lt= ptr->id.data;
100         Object *ob;
101         int newu, newv, neww;
102
103         /* we don't modify the actual pnts, but go through opnts instead */
104         newu= (lt->opntsu > 0)? lt->opntsu: lt->pntsu;
105         newv= (lt->opntsv > 0)? lt->opntsv: lt->pntsv;
106         neww= (lt->opntsw > 0)? lt->opntsw: lt->pntsw;
107
108         /* resizelattice needs an object, any object will have the same result */
109         for(ob=bmain->object.first; ob; ob= ob->id.next) {
110                 if(ob->data == lt) {
111                         resizelattice(lt, newu, newv, neww, ob);
112                         if(lt->editlatt)
113                                 resizelattice(lt->editlatt, newu, newv, neww, ob);
114                         break;
115                 }
116         }
117
118         /* otherwise without, means old points are not repositioned */
119         if(!ob) {
120                 resizelattice(lt, newu, newv, neww, NULL);
121                 if(lt->editlatt)
122                         resizelattice(lt->editlatt, newu, newv, neww, NULL);
123         }
124
125         rna_Lattice_update_data(bmain, scene, ptr);
126 }
127
128 static void rna_Lattice_outside_set(PointerRNA *ptr, int value)
129 {
130         Lattice *lt= ptr->data;
131
132         if(value) lt->flag |= LT_OUTSIDE;
133         else lt->flag &= ~LT_OUTSIDE;
134
135         outside_lattice(lt);
136
137         if(lt->editlatt) {
138                 if(value) lt->editlatt->flag |= LT_OUTSIDE;
139                 else lt->editlatt->flag &= ~LT_OUTSIDE;
140
141                 outside_lattice(lt->editlatt);
142         }
143 }
144
145 static void rna_Lattice_points_u_set(PointerRNA *ptr, int value)
146 {
147         ((Lattice*)ptr->data)->opntsu= CLAMPIS(value, 1, 64);
148 }
149
150 static void rna_Lattice_points_v_set(PointerRNA *ptr, int value)
151 {
152         ((Lattice*)ptr->data)->opntsv= CLAMPIS(value, 1, 64);
153 }
154
155 static void rna_Lattice_points_w_set(PointerRNA *ptr, int value)
156 {
157         ((Lattice*)ptr->data)->opntsw= CLAMPIS(value, 1, 64);
158 }
159
160 #else
161
162 static void rna_def_latticepoint(BlenderRNA *brna)
163 {
164         StructRNA *srna;
165         PropertyRNA *prop;
166
167         srna= RNA_def_struct(brna, "LatticePoint", NULL);
168         RNA_def_struct_sdna(srna, "BPoint");
169         RNA_def_struct_ui_text(srna, "LatticePoint", "Point in the lattice grid");
170
171         prop= RNA_def_property(srna, "co", PROP_FLOAT, PROP_TRANSLATION);
172         RNA_def_property_array(prop, 3);
173         RNA_def_property_clear_flag(prop, PROP_EDITABLE);
174         RNA_def_property_float_funcs(prop, "rna_LatticePoint_co_get", NULL, NULL);
175         RNA_def_property_ui_text(prop, "Location", "");
176
177         prop= RNA_def_property(srna, "deformed_co", PROP_FLOAT, PROP_TRANSLATION);
178         RNA_def_property_float_sdna(prop, NULL, "vec");
179         RNA_def_property_array(prop, 3);
180         RNA_def_property_ui_text(prop, "Deformed Location", "");
181         RNA_def_property_update(prop, 0, "rna_Lattice_update_data");
182
183         prop= RNA_def_property(srna, "groups", PROP_COLLECTION, PROP_NONE);
184         RNA_def_property_collection_funcs(prop, "rna_LatticePoint_groups_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", 0, 0, 0);
185         RNA_def_property_struct_type(prop, "VertexGroupElement");
186         RNA_def_property_ui_text(prop, "Groups", "Weights for the vertex groups this point is member of");
187 }
188
189 static void rna_def_lattice(BlenderRNA *brna)
190 {
191         StructRNA *srna;
192         PropertyRNA *prop;
193
194         static EnumPropertyItem prop_keyblock_type_items[] = {
195                 {KEY_LINEAR, "KEY_LINEAR", 0, "Linear", ""},
196                 {KEY_CARDINAL, "KEY_CARDINAL", 0, "Cardinal", ""},
197                 {KEY_BSPLINE, "KEY_BSPLINE", 0, "BSpline", ""},
198                 {0, NULL, 0, NULL, NULL}};
199
200         srna= RNA_def_struct(brna, "Lattice", "ID");
201         RNA_def_struct_ui_text(srna, "Lattice", "Lattice datablock defining a grid for deforming other objects");
202         RNA_def_struct_ui_icon(srna, ICON_LATTICE_DATA);
203
204         prop= RNA_def_property(srna, "points_u", PROP_INT, PROP_NONE);
205         RNA_def_property_int_sdna(prop, NULL, "pntsu");
206         RNA_def_property_int_funcs(prop, NULL, "rna_Lattice_points_u_set", NULL);
207         RNA_def_property_range(prop, 1, 64);
208         RNA_def_property_ui_text(prop, "U", "Points in U direction");
209         RNA_def_property_update(prop, 0, "rna_Lattice_update_size");
210
211         prop= RNA_def_property(srna, "points_v", PROP_INT, PROP_NONE);
212         RNA_def_property_int_sdna(prop, NULL, "pntsv");
213         RNA_def_property_int_funcs(prop, NULL, "rna_Lattice_points_v_set", NULL);
214         RNA_def_property_range(prop, 1, 64);
215         RNA_def_property_ui_text(prop, "V", "Points in V direction");
216         RNA_def_property_update(prop, 0, "rna_Lattice_update_size");
217
218         prop= RNA_def_property(srna, "points_w", PROP_INT, PROP_NONE);
219         RNA_def_property_int_sdna(prop, NULL, "pntsw");
220         RNA_def_property_int_funcs(prop, NULL, "rna_Lattice_points_w_set", NULL);
221         RNA_def_property_range(prop, 1, 64);
222         RNA_def_property_ui_text(prop, "W", "Points in W direction");
223         RNA_def_property_update(prop, 0, "rna_Lattice_update_size");
224
225         prop= RNA_def_property(srna, "interpolation_type_u", PROP_ENUM, PROP_NONE);
226         RNA_def_property_enum_sdna(prop, NULL, "typeu");
227         RNA_def_property_enum_items(prop, prop_keyblock_type_items);
228         RNA_def_property_ui_text(prop, "Interpolation Type U", "");
229         RNA_def_property_update(prop, 0, "rna_Lattice_update_data");
230
231         prop= RNA_def_property(srna, "interpolation_type_v", PROP_ENUM, PROP_NONE);
232         RNA_def_property_enum_sdna(prop, NULL, "typev");
233         RNA_def_property_enum_items(prop, prop_keyblock_type_items);
234         RNA_def_property_ui_text(prop, "Interpolation Type V", "");
235         RNA_def_property_update(prop, 0, "rna_Lattice_update_data");
236
237         prop= RNA_def_property(srna, "interpolation_type_w", PROP_ENUM, PROP_NONE);
238         RNA_def_property_enum_sdna(prop, NULL, "typew");
239         RNA_def_property_enum_items(prop, prop_keyblock_type_items);
240         RNA_def_property_ui_text(prop, "Interpolation Type W", "");
241         RNA_def_property_update(prop, 0, "rna_Lattice_update_data");
242
243         prop= RNA_def_property(srna, "outside", PROP_BOOLEAN, PROP_NONE);
244         RNA_def_property_boolean_sdna(prop, NULL, "flag", LT_OUTSIDE);
245         RNA_def_property_boolean_funcs(prop, NULL, "rna_Lattice_outside_set");
246         RNA_def_property_ui_text(prop, "Outside", "Only draw, and take into account, the outer vertices");
247         RNA_def_property_update(prop, 0, "rna_Lattice_update_data");
248
249         prop= RNA_def_property(srna, "shape_keys", PROP_POINTER, PROP_NONE);
250         RNA_def_property_pointer_sdna(prop, NULL, "key");
251         RNA_def_property_ui_text(prop, "Shape Keys", "");
252
253         prop= RNA_def_property(srna, "points", PROP_COLLECTION, PROP_NONE);
254         RNA_def_property_struct_type(prop, "LatticePoint");
255         RNA_def_property_collection_funcs(prop, "rna_Lattice_points_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", 0, 0, 0);
256         RNA_def_property_ui_text(prop, "Points", "Points of the lattice");
257 }
258
259 void RNA_def_lattice(BlenderRNA *brna)
260 {
261         rna_def_lattice(brna);
262         rna_def_latticepoint(brna);
263 }
264
265 #endif
266