| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2009-06-23 00:09:26 +00:00
										 |  |  |  * $Id$ | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * ***** BEGIN GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							|  |  |  |  * Inc., 59 Temple Place * Suite 330, Boston, MA  02111*1307, USA. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2008, Blender Foundation | 
					
						
							|  |  |  |  * This is a new part of Blender (with some old code) | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Contributor(s): Joshua Leung | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-06 10:31:25 +00:00
										 |  |  | #ifndef ED_KEYFRAMING_H
 | 
					
						
							|  |  |  | #define ED_KEYFRAMING_H
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | struct ListBase; | 
					
						
							|  |  |  | struct ID; | 
					
						
							| 
									
										
										
										
											2009-07-12 02:06:15 +00:00
										 |  |  | struct Scene; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-11 12:19:42 +00:00
										 |  |  | struct KeyingSet; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-15 01:10:36 +00:00
										 |  |  | struct bAction; | 
					
						
							| 
									
										
											  
											
												2.5: Blender "Animato" - New Animation System 
Finally, here is the basic (functional) prototype of the new animation system which will allow for the infamous "everything is animatable", and which also addresses several of the more serious shortcomings of the old system. Unfortunately, this will break old animation files (especially right now, as I haven't written the version patching code yet), however, this is for the future.
Highlights of the new system:
* Scrapped IPO-Curves/IPO/(Action+Constraint-Channels)/Action system, and replaced it with F-Curve/Action. 
- F-Curves (animators from other packages will feel at home with this name) replace IPO-Curves. 
- The 'new' Actions, act as the containers for F-Curves, so that they can be reused. They are therefore more akin to the old 'IPO' blocks, except they do not have the blocktype restriction, so you can store materials/texture/geometry F-Curves in the same Action as Object transforms, etc.
* F-Curves use RNA-paths for Data Access, hence allowing "every" (where sensible/editable that is) user-accessible setting from RNA to be animated.
* Drivers are no longer mixed with Animation Data, so rigs will not be that easily broken and several dependency problems can be eliminated. (NOTE: drivers haven't been hooked up yet, but the code is in place)
* F-Curve modifier system allows useful 'large-scale' manipulation of F-Curve values, including (I've only included implemented ones here): envelope deform (similar to lattices to allow broad-scale reshaping of curves), curve generator (polynomial or py-expression), cycles (replacing the old cyclic extrapolation modes, giving more control over this). (NOTE: currently this cannot be tested, as there's not access to them, but the code is all in place)
* NLA system with 'tracks' (i.e. layers), and multiple strips per track. (NOTE: NLA system is not yet functional, as it's only partially coded still) 
There are more nice things that I will be preparing some nice docs for soon, but for now, check for more details:
http://lists.blender.org/pipermail/bf-taskforce25/2009-January/000260.html
So, what currently works:
* I've implemented two basic operators for the 3D-view only to Insert and Delete Keyframes. These are tempolary ones only that will be replaced in due course with 'proper' code.
* Object Loc/Rot/Scale can be keyframed. Also, the colour of the 'active' material (Note: this should really be for nth material instead, but that doesn't work yet in RNA) can also be keyframed into the same datablock.
* Standard animation refresh (i.e. animation resulting from NLA and Action evaluation) is now done completely separate from drivers before anything else is done after a frame change. Drivers are handled after this in a separate pass, as dictated by depsgraph flags, etc.
Notes:
* Drivers haven't been hooked up yet
* Only objects and data directly linked to objects can be animated.
* Depsgraph will need further tweaks. Currently, I've only made sure that it will update some things in the most basic cases (i.e. frame change).
* Animation Editors are currently broken (in terms of editing stuff). This will be my next target (priority to get Dopesheet working first, then F-Curve editor - i.e. old IPO Editor)
* I've had to put in large chunks of XXX sandboxing for old animation system code all around the place. This will be cleaned up in due course, as some places need special review.
In particular, the particles and sequencer code have far too many manual calls to calculate + flush animation info, which is really bad (this is a 'please explain yourselves' call to Physics coders!).
											
										 
											2009-01-17 03:12:50 +00:00
										 |  |  | struct FCurve; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | struct BezTriple; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-15 01:10:36 +00:00
										 |  |  | struct bPoseChannel; | 
					
						
							|  |  |  | struct bConstraint; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct bContext; | 
					
						
							| 
									
										
											  
											
												2.5: Blender "Animato" - New Animation System 
Finally, here is the basic (functional) prototype of the new animation system which will allow for the infamous "everything is animatable", and which also addresses several of the more serious shortcomings of the old system. Unfortunately, this will break old animation files (especially right now, as I haven't written the version patching code yet), however, this is for the future.
Highlights of the new system:
* Scrapped IPO-Curves/IPO/(Action+Constraint-Channels)/Action system, and replaced it with F-Curve/Action. 
- F-Curves (animators from other packages will feel at home with this name) replace IPO-Curves. 
- The 'new' Actions, act as the containers for F-Curves, so that they can be reused. They are therefore more akin to the old 'IPO' blocks, except they do not have the blocktype restriction, so you can store materials/texture/geometry F-Curves in the same Action as Object transforms, etc.
* F-Curves use RNA-paths for Data Access, hence allowing "every" (where sensible/editable that is) user-accessible setting from RNA to be animated.
* Drivers are no longer mixed with Animation Data, so rigs will not be that easily broken and several dependency problems can be eliminated. (NOTE: drivers haven't been hooked up yet, but the code is in place)
* F-Curve modifier system allows useful 'large-scale' manipulation of F-Curve values, including (I've only included implemented ones here): envelope deform (similar to lattices to allow broad-scale reshaping of curves), curve generator (polynomial or py-expression), cycles (replacing the old cyclic extrapolation modes, giving more control over this). (NOTE: currently this cannot be tested, as there's not access to them, but the code is all in place)
* NLA system with 'tracks' (i.e. layers), and multiple strips per track. (NOTE: NLA system is not yet functional, as it's only partially coded still) 
There are more nice things that I will be preparing some nice docs for soon, but for now, check for more details:
http://lists.blender.org/pipermail/bf-taskforce25/2009-January/000260.html
So, what currently works:
* I've implemented two basic operators for the 3D-view only to Insert and Delete Keyframes. These are tempolary ones only that will be replaced in due course with 'proper' code.
* Object Loc/Rot/Scale can be keyframed. Also, the colour of the 'active' material (Note: this should really be for nth material instead, but that doesn't work yet in RNA) can also be keyframed into the same datablock.
* Standard animation refresh (i.e. animation resulting from NLA and Action evaluation) is now done completely separate from drivers before anything else is done after a frame change. Drivers are handled after this in a separate pass, as dictated by depsgraph flags, etc.
Notes:
* Drivers haven't been hooked up yet
* Only objects and data directly linked to objects can be animated.
* Depsgraph will need further tweaks. Currently, I've only made sure that it will update some things in the most basic cases (i.e. frame change).
* Animation Editors are currently broken (in terms of editing stuff). This will be my next target (priority to get Dopesheet working first, then F-Curve editor - i.e. old IPO Editor)
* I've had to put in large chunks of XXX sandboxing for old animation system code all around the place. This will be cleaned up in due course, as some places need special review.
In particular, the particles and sequencer code have far too many manual calls to calculate + flush animation info, which is really bad (this is a 'please explain yourselves' call to Physics coders!).
											
										 
											2009-01-17 03:12:50 +00:00
										 |  |  | struct wmOperatorType; | 
					
						
							| 
									
										
										
										
											2008-12-29 01:19:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | struct PointerRNA; | 
					
						
							|  |  |  | struct PropertyRNA; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | /* ************ Keyframing Management **************** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-15 01:10:36 +00:00
										 |  |  | /* Get (or add relevant data to be able to do so) the Active Action for the given 
 | 
					
						
							|  |  |  |  * Animation Data block, given an ID block where the Animation Data should reside. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | struct bAction *verify_adt_action(struct ID *id, short add); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Get (or add relevant data to be able to do so) F-Curve from the given Action. 
 | 
					
						
							|  |  |  |  * This assumes that all the destinations are valid. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | struct FCurve *verify_fcurve(struct bAction *act, const char group[], const char rna_path[], const int array_index, short add); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* -------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | /* Lesser Keyframing API call:
 | 
					
						
							|  |  |  |  *	Use this when validation of necessary animation data isn't necessary as it already | 
					
						
							|  |  |  |  * 	exists, and there is a beztriple that can be directly copied into the array. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | int insert_bezt_fcurve(struct FCurve *fcu, struct BezTriple *bezt, short flag); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* Main Keyframing API call: 
 | 
					
						
							|  |  |  |  *	Use this when validation of necessary animation data isn't necessary as it | 
					
						
							|  |  |  |  *	already exists. It will insert a keyframe using the current value being keyframed. | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  |  * 	Returns the index at which a keyframe was added (or -1 if failed) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | int insert_vert_fcurve(struct FCurve *fcu, float x, float y, short flag); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | /* -------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Secondary Keyframing API calls: 
 | 
					
						
							|  |  |  |  *	Use this to insert a keyframe using the current value being keyframed, in the  | 
					
						
							|  |  |  |  *	nominated F-Curve (no creation of animation data performed). Returns success. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | short insert_keyframe_direct(struct PointerRNA ptr, struct PropertyRNA *prop, struct FCurve *fcu, float cfra, short flag); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | /* -------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Main Keyframing API calls: 
 | 
					
						
							|  |  |  |  *	Use this to create any necessary animation data, and then insert a keyframe | 
					
						
							|  |  |  |  *	using the current value being keyframed, in the relevant place. Returns success. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-04-15 01:10:36 +00:00
										 |  |  | short insert_keyframe(struct ID *id, struct bAction *act, const char group[], const char rna_path[], int array_index, float cfra, short flag); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* Main Keyframing API call: 
 | 
					
						
							|  |  |  |  * 	Use this to delete keyframe on current frame for relevant channel. Will perform checks just in case. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-04-15 01:10:36 +00:00
										 |  |  | short delete_keyframe(struct ID *id, struct bAction *act, const char group[], const char rna_path[], int array_index, float cfra, short flag); | 
					
						
							| 
									
										
										
										
											2009-02-11 12:19:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-15 01:10:36 +00:00
										 |  |  | /* ************ Keying Sets ********************** */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* temporary struct to gather data combos to keyframe
 | 
					
						
							|  |  |  |  * (is used by modify_keyframes for 'relative' KeyingSets, provided via the dsources arg) | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef struct bCommonKeySrc { | 
					
						
							|  |  |  | 	struct bCommonKeySrc *next, *prev; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* general data/destination-source settings */ | 
					
						
							|  |  |  | 	struct ID *id;					/* id-block this comes from */ | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		/* specific cases */ | 
					
						
							|  |  |  | 	struct bPoseChannel *pchan;	 | 
					
						
							|  |  |  | 	struct bConstraint *con; | 
					
						
							|  |  |  | } bCommonKeySrc; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* -------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* mode for modify_keyframes */ | 
					
						
							|  |  |  | enum { | 
					
						
							|  |  |  | 	MODIFYKEY_MODE_INSERT = 0, | 
					
						
							|  |  |  | 	MODIFYKEY_MODE_DELETE, | 
					
						
							|  |  |  | } eModifyKey_Modes; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Keyframing Helper Call - use the provided Keying Set to Add/Remove Keyframes */ | 
					
						
							| 
									
										
										
										
											2009-10-08 05:53:26 +00:00
										 |  |  | int modify_keyframes(struct Scene *scene, struct ListBase *dsources, struct bAction *act, struct KeyingSet *ks, short mode, float cfra); | 
					
						
							| 
									
										
										
										
											2009-04-15 01:10:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* -------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Generate menu of KeyingSets */ | 
					
						
							|  |  |  | char *ANIM_build_keyingsets_menu(struct ListBase *list, short for_edit); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Get the first builtin KeyingSet with the given name, which occurs after the given one (or start of list if none given) */ | 
					
						
							|  |  |  | struct KeyingSet *ANIM_builtin_keyingset_get_named(struct KeyingSet *prevKS, char name[]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Initialise builtin KeyingSets on startup */ | 
					
						
							|  |  |  | void init_builtin_keyingsets(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-08 06:39:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* -------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Get the active KeyingSet for the given scene */ | 
					
						
							|  |  |  | struct KeyingSet *ANIM_scene_get_active_keyingset(struct Scene *scene); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-10 13:08:12 +00:00
										 |  |  | /* ************ Drivers ********************** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-25 04:51:04 +00:00
										 |  |  | /* Returns whether there is a driver in the copy/paste buffer to paste */ | 
					
						
							|  |  |  | short ANIM_driver_can_paste(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-10 13:08:12 +00:00
										 |  |  | /* Main Driver Management API calls:
 | 
					
						
							|  |  |  |  * 	Add a new driver for the specified property on the given ID block | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-07-12 02:06:15 +00:00
										 |  |  | short ANIM_add_driver (struct ID *id, const char rna_path[], int array_index, short flag, int type); | 
					
						
							| 
									
										
										
										
											2009-04-10 13:08:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* Main Driver Management API calls:
 | 
					
						
							|  |  |  |  * 	Remove the driver for the specified property on the given ID block (if available) | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-09-25 04:51:04 +00:00
										 |  |  | short ANIM_remove_driver(struct ID *id, const char rna_path[], int array_index, short flag); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Main Driver Management API calls:
 | 
					
						
							|  |  |  |  * 	Make a copy of the driver for the specified property on the given ID block | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | short ANIM_copy_driver(struct ID *id, const char rna_path[], int array_index, short flag); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Main Driver Management API calls:
 | 
					
						
							|  |  |  |  * 	Add a new driver for the specified property on the given ID block or replace an existing one | 
					
						
							|  |  |  |  *	with the driver + driver-curve data from the buffer  | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | short ANIM_paste_driver(struct ID *id, const char rna_path[], int array_index, short flag); | 
					
						
							| 
									
										
										
										
											2009-04-10 13:08:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | /* ************ Auto-Keyframing ********************** */ | 
					
						
							|  |  |  | /* Notes:
 | 
					
						
							|  |  |  |  * - All the defines for this (User-Pref settings and Per-Scene settings) | 
					
						
							|  |  |  |  * 	are defined in DNA_userdef_types.h | 
					
						
							|  |  |  |  * - Scene settings take presidence over those for userprefs, with old files | 
					
						
							|  |  |  |  * 	inheriting userpref settings for the scene settings | 
					
						
							|  |  |  |  * - "On/Off + Mode" are stored per Scene, but "settings" are currently stored | 
					
						
							|  |  |  |  * 	as userprefs | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Auto-Keying macros for use by various tools */ | 
					
						
							|  |  |  | 	/* check if auto-keyframing is enabled (per scene takes presidence) */ | 
					
						
							| 
									
										
										
										
											2009-06-23 00:41:55 +00:00
										 |  |  | #define IS_AUTOKEY_ON(scene)	((scene) ? (scene->toolsettings->autokey_mode & AUTOKEY_ON) : (U.autokey_mode & AUTOKEY_ON))
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	/* check the mode for auto-keyframing (per scene takes presidence)  */ | 
					
						
							| 
									
										
										
										
											2009-06-23 00:41:55 +00:00
										 |  |  | #define IS_AUTOKEY_MODE(scene, mode) 	((scene) ? (scene->toolsettings->autokey_mode == AUTOKEY_MODE_##mode) : (U.autokey_mode == AUTOKEY_MODE_##mode))
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	/* check if a flag is set for auto-keyframing (as userprefs only!) */ | 
					
						
							|  |  |  | #define IS_AUTOKEY_FLAG(flag)	(U.autokey_flag & AUTOKEY_FLAG_##flag)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-12 02:06:15 +00:00
										 |  |  | /* auto-keyframing feature - checks for whether anything should be done for the current frame */ | 
					
						
							|  |  |  | int autokeyframe_cfra_can_key(struct Scene *scene, struct ID *id); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | /* ************ Keyframe Checking ******************** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-08 12:30:09 +00:00
										 |  |  | /* Lesser Keyframe Checking API call:
 | 
					
						
							|  |  |  |  *	- Used for the buttons to check for keyframes... | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | short fcurve_frame_has_keyframe(struct FCurve *fcu, float frame, short filter); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | /* Main Keyframe Checking API call:
 | 
					
						
							|  |  |  |  * Checks whether a keyframe exists for the given ID-block one the given frame. | 
					
						
							|  |  |  |  *  - It is recommended to call this method over the other keyframe-checkers directly, | 
					
						
							|  |  |  |  * 	  in case some detail of the implementation changes... | 
					
						
							|  |  |  |  *	- frame: the value of this is quite often result of frame_to_float(CFRA) | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | short id_frame_has_keyframe(struct ID *id, float frame, short filter); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* filter flags for id_cfra_has_keyframe 
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * WARNING: do not alter order of these, as also stored in files | 
					
						
							|  |  |  |  *	(for v3d->keyflags) | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | enum { | 
					
						
							|  |  |  | 		/* general */ | 
					
						
							| 
									
										
										
										
											2008-12-21 04:11:19 +00:00
										 |  |  | 	ANIMFILTER_KEYS_LOCAL	= (1<<0),		/* only include locally available anim data */ | 
					
						
							|  |  |  | 	ANIMFILTER_KEYS_MUTED	= (1<<1),		/* include muted elements */ | 
					
						
							|  |  |  | 	ANIMFILTER_KEYS_ACTIVE	= (1<<2),		/* only include active-subelements */ | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 		/* object specific */ | 
					
						
							| 
									
										
										
										
											2008-12-21 04:11:19 +00:00
										 |  |  | 	ANIMFILTER_KEYS_NOMAT		= (1<<9),		/* don't include material keyframes */ | 
					
						
							|  |  |  | 	ANIMFILTER_KEYS_NOSKEY		= (1<<10),		/* don't include shape keys (for geometry) */ | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | } eAnimFilterFlags; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-06 10:31:25 +00:00
										 |  |  | #endif /*  ED_KEYFRAMING_H */
 |