merging 17300:17342
[blender.git] / source / blender / blenkernel / BKE_lattice.h
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) 2001-2002 by NaN Holding BV.
21  * All rights reserved.
22  *
23  * The Original Code is: all of this file.
24  *
25  * Contributor(s): none yet.
26  *
27  * ***** END GPL LICENSE BLOCK *****
28  * june-2001 ton
29  */
30
31 #ifndef BKE_LATTICE_H
32 #define BKE_LATTICE_H
33
34 struct Lattice;
35 struct Object;
36 struct DerivedMesh;
37 struct BPoint;
38 struct MDeformVert;
39
40 extern struct Lattice *editLatt;
41
42
43 void resizelattice(struct Lattice *lt, int u, int v, int w, struct Object *ltOb);
44 struct Lattice *add_lattice(char *name);
45 struct Lattice *copy_lattice(struct Lattice *lt);
46 void free_lattice(struct Lattice *lt);
47 void make_local_lattice(struct Lattice *lt);
48 void calc_lat_fudu(int flag, int res, float *fu, float *du);
49 void init_latt_deform(struct Object *oblatt, struct Object *ob);
50 void calc_latt_deform(float *co, float weight);
51 void end_latt_deform(void);
52 int object_deform_mball(struct Object *ob);
53 void outside_lattice(struct Lattice *lt);
54 void curve_deform_verts(struct Object *cuOb, struct Object *target, 
55                                                 struct DerivedMesh *dm, float (*vertexCos)[3], 
56                                                 int numVerts, char *vgroup, short defaxis);
57 void curve_deform_vector(struct Object *cuOb, struct Object *target, 
58                                                  float *orco, float *vec, float mat[][3], int no_rot_axis);
59
60 void lattice_deform_verts(struct Object *laOb, struct Object *target,
61                           struct DerivedMesh *dm, float (*vertexCos)[3],
62                           int numVerts, char *vgroup);
63 void armature_deform_verts(struct Object *armOb, struct Object *target,
64                            struct DerivedMesh *dm, float (*vertexCos)[3],
65                            float (*defMats)[3][3], int numVerts, int deformflag, 
66                                                    float (*prevCos)[3], const char *defgrp_name);
67 float (*lattice_getVertexCos(struct Object *ob, int *numVerts_r))[3];
68 void lattice_applyVertexCos(struct Object *ob, float (*vertexCos)[3]);
69 void lattice_calc_modifiers(struct Object *ob);
70
71 struct MDeformVert* lattice_get_deform_verts(struct Object *lattice);
72
73 #endif
74