commit before doing some hefty shapekey change, will break compilation
[blender-staging.git] / source / blender / blenkernel / BKE_curve.h
1 /**
2  * blenlib/BKE_curve.h (mar-2001 nzc)
3  *      
4  * $Id$ 
5  *
6  * ***** BEGIN GPL LICENSE BLOCK *****
7  *
8  * This program is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU General Public License
10  * as published by the Free Software Foundation; either version 2
11  * of the License, or (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software Foundation,
20  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
21  *
22  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
23  * All rights reserved.
24  *
25  * The Original Code is: all of this file.
26  *
27  * Contributor(s): none yet.
28  *
29  * ***** END GPL LICENSE BLOCK *****
30  */
31 #ifndef BKE_CURVE_H
32 #define BKE_CURVE_H
33
34 struct Curve;
35 struct ListBase;
36 struct Object;
37 struct Scene;
38 struct Nurb;
39 struct ListBase;
40 struct BezTriple;
41 struct BevList;
42
43 #define KNOTSU(nu)          ( (nu)->orderu+ (nu)->pntsu+ (((nu)->flagu & CU_CYCLIC) ? (nu->orderu-1) : 0) )
44 #define KNOTSV(nu)          ( (nu)->orderv+ (nu)->pntsv+ (((nu)->flagv & CU_CYCLIC) ? (nu->orderv-1) : 0) )
45
46 /* Non cyclic nurbs have 1 less segment */
47 #define SEGMENTSU(nu)       ( ((nu)->flagu & CU_CYCLIC) ? (nu)->pntsu : (nu)->pntsu-1 )
48 #define SEGMENTSV(nu)       ( ((nu)->flagv & CU_CYCLIC) ? (nu)->pntsv : (nu)->pntsv-1 )
49
50 #define CU_DO_TILT(cu, nu) (((nu->flag & CU_2D) && (cu->flag & CU_3D)==0) ? 0 : 1)
51 #define CU_DO_RADIUS(cu, nu) ((CU_DO_TILT(cu, nu) || cu->bevobj || cu->ext1!=0.0 || cu->ext2!=0.0) ? 1:0)
52
53
54 void unlink_curve( struct Curve *cu);
55 void free_curve( struct Curve *cu);
56 void BKE_free_editfont(struct Curve *cu);
57 struct Curve *add_curve(char *name, int type);
58 struct Curve *copy_curve( struct Curve *cu);
59 void make_local_curve( struct Curve *cu);
60 short curve_type( struct Curve *cu);
61 void test_curve_type( struct Object *ob);
62 void tex_space_curve( struct Curve *cu);
63 int count_curveverts( struct ListBase *nurb);
64 int count_curveverts_without_handles( struct ListBase *nurb);
65 void freeNurb( struct Nurb *nu);
66 void freeNurblist( struct ListBase *lb);
67 struct Nurb *duplicateNurb( struct Nurb *nu);
68 void duplicateNurblist( struct ListBase *lb1,  struct ListBase *lb2);
69 void test2DNurb( struct Nurb *nu);
70 void minmaxNurb( struct Nurb *nu, float *min, float *max);
71
72 void makeknots( struct Nurb *nu, short uv);
73
74 void makeNurbfaces(struct Nurb *nu, float *coord_array, int rowstride);
75 void makeNurbcurve(struct Nurb *nu, float *coord_array, float *tilt_array, float *radius_array, int resolu, int stride);
76 void forward_diff_bezier(float q0, float q1, float q2, float q3, float *p, int it, int stride);
77 float *make_orco_curve(struct Scene *scene, struct Object *ob);
78 float *make_orco_surf( struct Object *ob);
79 void makebevelcurve(struct Scene *scene, struct Object *ob,  struct ListBase *disp);
80
81 void makeBevelList( struct Object *ob);
82
83 void calchandleNurb( struct BezTriple *bezt, struct BezTriple *prev,  struct BezTriple *next, int mode);
84 void calchandlesNurb( struct Nurb *nu);
85 void testhandlesNurb( struct Nurb *nu);
86 void autocalchandlesNurb( struct Nurb *nu, int flag);
87 void autocalchandlesNurb_all(ListBase *editnurb, int flag);
88 void sethandlesNurb(ListBase *editnurb, short code);
89
90 void switchdirectionNurb( struct Nurb *nu);
91
92 float (*curve_getVertexCos(struct Curve *cu, struct ListBase *lb, int *numVerts_r))[3];
93 void curve_applyVertexCos(struct Curve *cu, struct ListBase *lb, float (*vertexCos)[3]);
94
95 float (*curve_getKeyVertexCos(struct Curve *cu, struct ListBase *lb, float *key))[3];
96 void curve_applyKeyVertexTilts(struct Curve *cu, struct ListBase *lb, float *key);
97
98 /* nurb checks if they can be drawn, also clamp order func */
99 int check_valid_nurb_u( struct Nurb *nu);
100 int check_valid_nurb_v( struct Nurb *nu);
101
102 int clamp_nurb_order_u( struct Nurb *nu);
103 int clamp_nurb_order_v( struct Nurb *nu);
104
105 #endif
106