Initial revision
[blender.git] / source / blender / blenkernel / BKE_ipo.h
1 /**
2  * blenlib/BKE_ipo.h (mar-2001 nzc)
3  *      
4  * $Id$ 
5  *
6  * ***** BEGIN GPL/BL DUAL 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. The Blender
12  * Foundation also sells licenses for use in proprietary software under
13  * the Blender License.  See http://www.blender.org/BL/ for information
14  * about this.
15  *
16  * This program is distributed in the hope that it will be useful,
17  * but WITHOUT ANY WARRANTY; without even the implied warranty of
18  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19  * GNU General Public License for more details.
20  *
21  * You should have received a copy of the GNU General Public License
22  * along with this program; if not, write to the Free Software Foundation,
23  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
24  *
25  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
26  * All rights reserved.
27  *
28  * The Original Code is: all of this file.
29  *
30  * Contributor(s): none yet.
31  *
32  * ***** END GPL/BL DUAL LICENSE BLOCK *****
33  */
34 #ifndef BKE_IPO_H
35 #define BKE_IPO_H
36
37 typedef struct CfraElem {
38         struct CfraElem *next, *prev;
39         float cfra;
40         int sel;
41 } CfraElem;
42
43 struct Ipo;
44 struct IpoCurve;
45 struct MTex;
46 struct Material;
47 struct Object;
48 struct Sequence;
49 struct ListBase;
50 struct BezTriple;
51 /*  struct IPO_Channel; */
52
53 float frame_to_float(int cfra);
54 void free_ipo(struct Ipo *ipo);
55 struct Ipo *add_ipo(char *name, int idcode);
56 struct Ipo *copy_ipo(struct Ipo *ipo);
57 void make_local_obipo(struct Ipo *ipo);
58 void make_local_matipo(struct Ipo *ipo);
59 void make_local_keyipo(struct Ipo *ipo);
60 void make_local_ipo(struct Ipo *ipo);
61 void calchandles_ipocurve(struct IpoCurve *icu);
62 void testhandles_ipocurve(struct IpoCurve *icu);
63 void sort_time_ipocurve(struct IpoCurve *icu);
64 int test_time_ipocurve(struct IpoCurve *icu);
65 void correct_bezpart(float *v1, float *v2, float *v3, float *v4);
66 int findzero(float x, float q0, float q1, float q2, float q3, float *o);
67 void berekeny(float f1, float f2, float f3, float f4, float *o, int b);
68 void berekenx(float *f, float *o, int b);
69 float eval_icu(struct IpoCurve *icu, float ipotime);
70 void calc_icu(struct IpoCurve *icu, float ctime);
71 float calc_ipo_time(struct Ipo *ipo, float ctime);
72 void calc_ipo(struct Ipo *ipo, float ctime);
73 void write_ipo_poin(void *poin, int type, float val);
74 float read_ipo_poin(void *poin, int type);
75 void *give_mtex_poin(struct MTex *mtex, int adrcode );
76 void *get_ipo_poin(struct ID *id, struct IpoCurve *icu, int *type);
77 void set_icu_vars(struct IpoCurve *icu);
78 void execute_ipo(struct ID *id, struct Ipo *ipo);
79 void do_ipo_nocalc(struct Ipo *ipo);
80 void do_ipo(struct Ipo *ipo);
81 void do_mat_ipo(struct Material *ma);
82 void do_ob_ipo(struct Object *ob);
83 void do_seq_ipo(struct Sequence *seq);
84 int has_ipo_code(struct Ipo *ipo, int code);
85 void do_all_ipos(void);
86 int calc_ipo_spec(struct Ipo *ipo, int adrcode, float *ctime);
87 void clear_delta_obipo(struct Ipo *ipo);
88 void add_to_cfra_elem(struct ListBase *lb, struct BezTriple *bezt);
89 void make_cfra_list(struct Ipo *ipo, struct ListBase *elems);
90 /* the sort is an IPO_Channel... */
91 int IPO_GetChannels(struct Ipo *ipo, short *channels);
92 void test_ipo_get(void);                             
93
94 float IPO_GetFloatValue(struct Ipo *ipo,
95 /*                                              struct IPO_Channel channel, */
96                                                 /* channels are shorts... bit ugly for now*/
97                                                 short c,
98                                                 float ctime);
99
100
101 #endif