Filling in branch from trunk
[blender.git] / source / blender / include / BSE_editaction_types.h
1 /**
2  * $Id: BIF_editaction.h 10519 2007-04-13 11:15:08Z aligorith $
3  *
4  * ***** BEGIN GPL/BL DUAL 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. The Blender
10  * Foundation also sells licenses for use in proprietary software under
11  * the Blender License.  See http://www.blender.org/BL/ for information
12  * about this.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program; if not, write to the Free Software Foundation,
21  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22  *
23  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
24  * All rights reserved.
25  *
26  * The Original Code is: all of this file.
27  *
28  * Contributor(s): 2007, Joshua Leung (major Action Editor recode)
29  *
30  * ***** END GPL/BL DUAL LICENSE BLOCK *****
31  */
32  
33 #ifndef BIF_EDITACTION_TYPES_H
34 #define BIF_EDITACTION_TYPES_H 
35
36 /******************************************************* */
37 /* FILTERED ACTION DATA - TYPES */
38
39 /* types of keyframe data in ActListElem */
40 #define ALE_NONE        0
41 #define ALE_IPO         1
42 #define ALE_ICU         2
43
44 /* This struct defines a structure used for quick access */
45 typedef struct bActListElem {
46         struct bActListElem *next, *prev;
47         
48         void    *data;          /* source data this elem represents */
49         int     type;           /* one of the ACTTYPE_* values */
50         int             flag;           /* copy of elem's flags for quick access */
51         int     index;          /* copy of adrcode where applicable */
52         
53         void    *key_data;      /* motion data - ipo or ipo-curve */
54         short   datatype;       /* type of motion data to expect */
55         
56         void    *owner;         /* will either be an action channel or fake ipo-channel (for keys) */
57         short   ownertype;      /* type of owner */
58 } bActListElem;
59
60 /******************************************************* */
61 /* FILTER ACTION DATA - METHODS/TYPES */
62
63 /* filtering flags  - under what circumstances should a channel be added */
64 #define ACTFILTER_VISIBLE               0x001   /* should channels be visible */
65 #define ACTFILTER_SEL                   0x002   /* should channels be selected */
66 #define ACTFILTER_FOREDIT               0x004   /* does editable status matter */
67 #define ACTFILTER_CHANNELS              0x008   /* do we only care that it is a channel */
68 #define ACTFILTER_IPOKEYS               0x010   /* only channels referencing ipo's */
69 #define ACTFILTER_ONLYICU               0x020   /* only reference ipo-curves */
70 #define ACTFILTER_FORDRAWING    0x040   /* make list for interface drawing */
71
72 /* Action Editor - Main Data types */
73 #define ACTCONT_NONE            0
74 #define ACTCONT_ACTION          1
75 #define ACTCONT_SHAPEKEY        2
76
77 #endif