| 
									
										
										
										
											2011-02-23 10:52:22 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2009-07-02 05:25:14 +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, | 
					
						
							| 
									
										
										
										
											2010-02-12 13:34:04 +00:00
										 |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							| 
									
										
										
										
											2009-07-02 05:25:14 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2009 Blender Foundation, Joshua Leung | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is: all of this file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Contributor(s): Joshua Leung (full recode) | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-02-27 20:29:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** \file blender/editors/animation/keyframing.c
 | 
					
						
							|  |  |  |  *  \ingroup edanimation | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  |   | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | #include <stdio.h>
 | 
					
						
							| 
									
										
										
										
											2009-02-09 10:04:11 +00:00
										 |  |  | #include <stddef.h>
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #include <math.h>
 | 
					
						
							|  |  |  | #include <float.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "MEM_guardedalloc.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "BLI_blenlib.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | #include "BLI_math.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | #include "BLI_dynstr.h"
 | 
					
						
							| 
									
										
										
										
											2011-01-07 18:36:47 +00:00
										 |  |  | #include "BLI_utildefines.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | #include "DNA_anim_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-24 10:58:34 +00:00
										 |  |  | #include "DNA_armature_types.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | #include "DNA_constraint_types.h"
 | 
					
						
							|  |  |  | #include "DNA_key_types.h"
 | 
					
						
							|  |  |  | #include "DNA_material_types.h"
 | 
					
						
							|  |  |  | #include "DNA_scene_types.h"
 | 
					
						
							| 
									
										
										
										
											2010-08-04 04:01:27 +00:00
										 |  |  | #include "DNA_object_types.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | #include "BKE_animsys.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | #include "BKE_action.h"
 | 
					
						
							| 
									
										
										
										
											2011-02-07 11:51:28 +00:00
										 |  |  | #include "BKE_armature.h"
 | 
					
						
							| 
									
										
										
										
											2009-02-19 16:22:07 +00:00
										 |  |  | #include "BKE_constraint.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-24 12:35:06 +00:00
										 |  |  | #include "BKE_depsgraph.h"
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | #include "BKE_fcurve.h"
 | 
					
						
							| 
									
										
										
										
											2010-08-01 12:47:49 +00:00
										 |  |  | #include "BKE_main.h"
 | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | #include "BKE_nla.h"
 | 
					
						
							| 
									
										
										
										
											2009-05-11 02:26:18 +00:00
										 |  |  | #include "BKE_global.h"
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | #include "BKE_context.h"
 | 
					
						
							| 
									
										
										
										
											2009-02-11 12:19:42 +00:00
										 |  |  | #include "BKE_report.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | #include "BKE_key.h"
 | 
					
						
							|  |  |  | #include "BKE_material.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-29 01:19:25 +00:00
										 |  |  | #include "ED_anim_api.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | #include "ED_keyframing.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-29 01:19:25 +00:00
										 |  |  | #include "ED_keyframes_edit.h"
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | #include "ED_screen.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-11 12:19:42 +00:00
										 |  |  | #include "UI_interface.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-05 09:54:39 +00:00
										 |  |  | #include "WM_api.h"
 | 
					
						
							|  |  |  | #include "WM_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | #include "RNA_access.h"
 | 
					
						
							|  |  |  | #include "RNA_define.h"
 | 
					
						
							| 
									
										
										
										
											2011-01-03 05:36:52 +00:00
										 |  |  | #include "RNA_enum_types.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-13 02:40:56 +00:00
										 |  |  | #include "anim_intern.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-14 12:09:20 +00:00
										 |  |  | /* ************************************************** */ | 
					
						
							|  |  |  | /* Keyframing Setting Wrangling */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Get the active settings for keyframing settings from context (specifically the given scene) */ | 
					
						
							|  |  |  | short ANIM_get_keyframing_flags (Scene *scene, short incl_mode) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	short flag = 0; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* standard flags */ | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		/* visual keying */ | 
					
						
							| 
									
										
										
										
											2011-02-04 08:33:07 +00:00
										 |  |  | 		if (IS_AUTOKEY_FLAG(scene, AUTOMATKEY))  | 
					
						
							| 
									
										
										
										
											2009-12-14 12:09:20 +00:00
										 |  |  | 			flag |= INSERTKEY_MATRIX; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* only needed */ | 
					
						
							| 
									
										
										
										
											2011-02-04 08:33:07 +00:00
										 |  |  | 		if (IS_AUTOKEY_FLAG(scene, INSERTNEEDED))  | 
					
						
							| 
									
										
										
										
											2009-12-14 12:09:20 +00:00
										 |  |  | 			flag |= INSERTKEY_NEEDED; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-01-18 01:58:19 +00:00
										 |  |  | 		/* default F-Curve color mode - RGB from XYZ indices */ | 
					
						
							| 
									
										
										
										
											2011-02-04 08:33:07 +00:00
										 |  |  | 		if (IS_AUTOKEY_FLAG(scene, XYZ2RGB))  | 
					
						
							| 
									
										
										
										
											2009-12-14 12:09:20 +00:00
										 |  |  | 			flag |= INSERTKEY_XYZ2RGB; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* only if including settings from the autokeying mode... */ | 
					
						
							|  |  |  | 	if (incl_mode)  | 
					
						
							|  |  |  | 	{  | 
					
						
							|  |  |  | 		/* keyframing mode - only replace existing keyframes */ | 
					
						
							|  |  |  | 		if (IS_AUTOKEY_MODE(scene, EDITKEYS))  | 
					
						
							|  |  |  | 			flag |= INSERTKEY_REPLACE; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	return flag; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | /* ******************************************* */ | 
					
						
							|  |  |  | /* Animation Data Validation */ | 
					
						
							| 
									
										
										
										
											2008-12-29 01:19:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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. | 
					
						
							| 
									
										
										
										
											2008-12-29 01:19:25 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-04-15 01:10:36 +00:00
										 |  |  | bAction *verify_adt_action (ID *id, short add) | 
					
						
							| 
									
										
										
										
											2008-12-29 01:19:25 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-17 05:36:58 +00:00
										 |  |  | 	AnimData *adt; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* init animdata if none available yet */ | 
					
						
							|  |  |  | 	adt= BKE_animdata_from_id(id); | 
					
						
							|  |  |  | 	if ((adt == NULL) && (add)) | 
					
						
							|  |  |  | 		adt= BKE_id_add_animdata(id); | 
					
						
							|  |  |  | 	if (adt == NULL) {  | 
					
						
							|  |  |  | 		/* if still none (as not allowed to add, or ID doesn't have animdata for some reason) */ | 
					
						
							| 
									
										
										
										
											2009-05-11 02:07:40 +00:00
										 |  |  | 		printf("ERROR: Couldn't add AnimData (ID = %s) \n", (id) ? (id->name) : "<None>"); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		return NULL; | 
					
						
							| 
									
										
										
										
											2009-01-17 05:36:58 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		 | 
					
						
							|  |  |  | 	/* init action if none available yet */ | 
					
						
							|  |  |  | 	// TODO: need some wizardry to handle NLA stuff correct
 | 
					
						
							| 
									
										
										
										
											2010-06-17 15:28:40 +00:00
										 |  |  | 	if ((adt->action == NULL) && (add)) { | 
					
						
							|  |  |  | 		char actname[sizeof(id->name)-2]; | 
					
						
							|  |  |  | 		BLI_snprintf(actname, sizeof(actname), "%sAction", id->name+2); | 
					
						
							|  |  |  | 		adt->action= add_empty_action(actname); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-04-15 01:10:36 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 	/* return the action */ | 
					
						
							|  |  |  | 	return adt->action; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Get (or add relevant data to be able to do so) F-Curve from the Active Action, 
 | 
					
						
							|  |  |  |  * for the given Animation Data block. This assumes that all the destinations are valid. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | FCurve *verify_fcurve (bAction *act, const char group[], const char rna_path[], const int array_index, short add) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bActionGroup *grp; | 
					
						
							|  |  |  | 	FCurve *fcu; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* sanity checks */ | 
					
						
							|  |  |  | 	if ELEM(NULL, act, rna_path) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		 | 
					
						
							|  |  |  | 	/* try to find f-curve matching for this setting 
 | 
					
						
							|  |  |  | 	 *	- add if not found and allowed to add one | 
					
						
							|  |  |  | 	 *		TODO: add auto-grouping support? how this works will need to be resolved | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	if (act) | 
					
						
							|  |  |  | 		fcu= list_find_fcurve(&act->curves, rna_path, array_index); | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		fcu= NULL; | 
					
						
							| 
									
										
										
										
											2008-12-29 01:19:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	if ((fcu == NULL) && (add)) { | 
					
						
							| 
									
										
										
										
											2009-02-09 10:04:11 +00:00
										 |  |  | 		/* use default settings to make a F-Curve */ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		fcu= MEM_callocN(sizeof(FCurve), "FCurve"); | 
					
						
							| 
									
										
										
										
											2008-12-29 01:19:25 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-08-04 14:13:05 +00:00
										 |  |  | 		fcu->flag = (FCURVE_VISIBLE|FCURVE_SELECTED); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		if (act->curves.first==NULL)  | 
					
						
							|  |  |  | 			fcu->flag |= FCURVE_ACTIVE;	/* first one added active */ | 
					
						
							| 
									
										
										
										
											2008-12-29 01:19:25 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		/* store path - make copy, and store that */ | 
					
						
							|  |  |  | 		fcu->rna_path= BLI_strdupn(rna_path, strlen(rna_path)); | 
					
						
							|  |  |  | 		fcu->array_index= array_index; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-02-09 10:04:11 +00:00
										 |  |  | 		/* if a group name has been provided, try to add or find a group, then add F-Curve to it */ | 
					
						
							|  |  |  | 		if (group) { | 
					
						
							|  |  |  | 			/* try to find group */ | 
					
						
							|  |  |  | 			grp= action_groups_find_named(act, group); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* no matching groups, so add one */ | 
					
						
							| 
									
										
										
										
											2010-04-01 06:26:41 +00:00
										 |  |  | 			if (grp == NULL) | 
					
						
							|  |  |  | 				grp= action_groups_add_new(act, group); | 
					
						
							| 
									
										
										
										
											2009-02-09 10:04:11 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			/* add F-Curve to group */ | 
					
						
							|  |  |  | 			action_groups_add_channel(act, grp, fcu); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			/* just add F-Curve to end of Action's list */ | 
					
						
							|  |  |  | 			BLI_addtail(&act->curves, fcu); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-29 01:19:25 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	/* return the F-Curve */ | 
					
						
							|  |  |  | 	return fcu; | 
					
						
							| 
									
										
										
										
											2008-12-29 01:19:25 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | /* ************************************************** */ | 
					
						
							|  |  |  | /* KEYFRAME INSERTION */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* -------------- BezTriple Insertion -------------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | /* This function adds a given BezTriple to an F-Curve. It will allocate 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  |  * memory for the array if needed, and will insert the BezTriple into a | 
					
						
							|  |  |  |  * suitable place in chronological order. | 
					
						
							|  |  |  |  *  | 
					
						
							| 
									
										
											  
											
												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
										 |  |  |  * NOTE: any recalculate of the F-Curve that needs to be done will need to  | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  |  * 		be done by the caller. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | int insert_bezt_fcurve (FCurve *fcu, BezTriple *bezt, short flag) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int i= 0; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-02-12 01:06:18 +00:00
										 |  |  | 	/* are there already keyframes? */ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	if (fcu->bezt) { | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		short replace = -1; | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		i = binarysearch_bezt_index(fcu->bezt, bezt->vec[1][0], fcu->totvert, &replace); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2010-02-12 01:06:18 +00:00
										 |  |  | 		/* replace an existing keyframe? */ | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		if (replace) {			 | 
					
						
							|  |  |  | 			/* sanity check: 'i' may in rare cases exceed arraylen */ | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 			if ((i >= 0) && (i < fcu->totvert)) { | 
					
						
							| 
									
										
											  
											
												Keyframe Defaults and Cleanups: 
This commit fixes reports #21638 and #21818, which were both also Durian feature requests.
Cbanges:
* Added new default setting for the type of handles created when creating keyframes. This can be found in the user-preferences, and is used whenever existing keyframes aren't being overwritten (instead of the value being always taken from the keyframes either side, #21638).
* When keyframing over existing keyframes, only the values will be changed. The handles will be offset by the same amount that the value of the keyframe changed, though how well this works in practice still needs to be tested more thoroughly (#21818, already fixed earlier, but this commit is the full fix).
* When 'free' handles are added by default, they are offset to be +/- 1 frame on either side of the keyframe so that it is obvious that they can be moved. However, they just take the same value of the keyframe since this is easiest.
* Properly initialising handle colour defaults for 3D-View and Graph Editor. Graph Editor's theme userprefs also show these settings now, though the layout is really quick hack-style.
											
										 
											2010-04-02 01:03:40 +00:00
										 |  |  | 				/* just change the values when replacing, so as to not overwrite handles */ | 
					
						
							|  |  |  | 				BezTriple *dst= (fcu->bezt + i); | 
					
						
							|  |  |  | 				float dy= bezt->vec[1][1] - dst->vec[1][1]; | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				/* just apply delta value change to the handle values */ | 
					
						
							|  |  |  | 				dst->vec[0][1] += dy; | 
					
						
							|  |  |  | 				dst->vec[1][1] += dy; | 
					
						
							|  |  |  | 				dst->vec[2][1] += dy; | 
					
						
							| 
									
										
										
										
											2011-01-14 02:06:35 +00:00
										 |  |  | 				 | 
					
						
							| 
									
										
										
										
											2010-12-15 17:36:08 +00:00
										 |  |  | 				dst->f1= bezt->f1; | 
					
						
							|  |  |  | 				dst->f2= bezt->f2; | 
					
						
							|  |  |  | 				dst->f3= bezt->f3; | 
					
						
							| 
									
										
											  
											
												Keyframe Defaults and Cleanups: 
This commit fixes reports #21638 and #21818, which were both also Durian feature requests.
Cbanges:
* Added new default setting for the type of handles created when creating keyframes. This can be found in the user-preferences, and is used whenever existing keyframes aren't being overwritten (instead of the value being always taken from the keyframes either side, #21638).
* When keyframing over existing keyframes, only the values will be changed. The handles will be offset by the same amount that the value of the keyframe changed, though how well this works in practice still needs to be tested more thoroughly (#21818, already fixed earlier, but this commit is the full fix).
* When 'free' handles are added by default, they are offset to be +/- 1 frame on either side of the keyframe so that it is obvious that they can be moved. However, they just take the same value of the keyframe since this is easiest.
* Properly initialising handle colour defaults for 3D-View and Graph Editor. Graph Editor's theme userprefs also show these settings now, though the layout is really quick hack-style.
											
										 
											2010-04-02 01:03:40 +00:00
										 |  |  | 				 | 
					
						
							|  |  |  | 				// TODO: perform some other operations?
 | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-02-12 01:06:18 +00:00
										 |  |  | 		/* keyframing modes allow to not replace keyframe */ | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 		else if ((flag & INSERTKEY_REPLACE) == 0) { | 
					
						
							| 
									
										
										
										
											2009-09-04 22:50:15 +00:00
										 |  |  | 			/* insert new - if we're not restricted to replacing keyframes only */ | 
					
						
							|  |  |  | 			BezTriple *newb= MEM_callocN((fcu->totvert+1)*sizeof(BezTriple), "beztriple"); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
											  
											
												Keyframe Defaults and Cleanups: 
This commit fixes reports #21638 and #21818, which were both also Durian feature requests.
Cbanges:
* Added new default setting for the type of handles created when creating keyframes. This can be found in the user-preferences, and is used whenever existing keyframes aren't being overwritten (instead of the value being always taken from the keyframes either side, #21638).
* When keyframing over existing keyframes, only the values will be changed. The handles will be offset by the same amount that the value of the keyframe changed, though how well this works in practice still needs to be tested more thoroughly (#21818, already fixed earlier, but this commit is the full fix).
* When 'free' handles are added by default, they are offset to be +/- 1 frame on either side of the keyframe so that it is obvious that they can be moved. However, they just take the same value of the keyframe since this is easiest.
* Properly initialising handle colour defaults for 3D-View and Graph Editor. Graph Editor's theme userprefs also show these settings now, though the layout is really quick hack-style.
											
										 
											2010-04-02 01:03:40 +00:00
										 |  |  | 			/* add the beztriples that should occur before the beztriple to be pasted (originally in fcu) */ | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 			if (i > 0) | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 				memcpy(newb, fcu->bezt, i*sizeof(BezTriple)); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			/* add beztriple to paste at index i */ | 
					
						
							|  |  |  | 			*(newb + i)= *bezt; | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
											  
											
												Keyframe Defaults and Cleanups: 
This commit fixes reports #21638 and #21818, which were both also Durian feature requests.
Cbanges:
* Added new default setting for the type of handles created when creating keyframes. This can be found in the user-preferences, and is used whenever existing keyframes aren't being overwritten (instead of the value being always taken from the keyframes either side, #21638).
* When keyframing over existing keyframes, only the values will be changed. The handles will be offset by the same amount that the value of the keyframe changed, though how well this works in practice still needs to be tested more thoroughly (#21818, already fixed earlier, but this commit is the full fix).
* When 'free' handles are added by default, they are offset to be +/- 1 frame on either side of the keyframe so that it is obvious that they can be moved. However, they just take the same value of the keyframe since this is easiest.
* Properly initialising handle colour defaults for 3D-View and Graph Editor. Graph Editor's theme userprefs also show these settings now, though the layout is really quick hack-style.
											
										 
											2010-04-02 01:03:40 +00:00
										 |  |  | 			/* add the beztriples that occur after the beztriple to be pasted (originally in fcu) */ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 			if (i < fcu->totvert)  | 
					
						
							|  |  |  | 				memcpy(newb+i+1, fcu->bezt+i, (fcu->totvert-i)*sizeof(BezTriple)); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 			/* replace (+ free) old with new, only if necessary to do so */ | 
					
						
							| 
									
										
										
										
											2009-09-04 22:50:15 +00:00
										 |  |  | 			MEM_freeN(fcu->bezt); | 
					
						
							|  |  |  | 			fcu->bezt= newb; | 
					
						
							| 
									
										
										
										
											2010-02-12 01:06:18 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 			fcu->totvert++; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-02-12 01:06:18 +00:00
										 |  |  | 	/* no keyframes already, but can only add if...
 | 
					
						
							|  |  |  | 	 *	1) keyframing modes say that keyframes can only be replaced, so adding new ones won't know | 
					
						
							|  |  |  | 	 *	2) there are no samples on the curve | 
					
						
							|  |  |  | 	 *		// NOTE: maybe we may want to allow this later when doing samples -> bezt conversions, 
 | 
					
						
							|  |  |  | 	 *		// but for now, having both is asking for trouble
 | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	else if ((flag & INSERTKEY_REPLACE)==0 && (fcu->fpt==NULL)) { | 
					
						
							|  |  |  | 		/* create new keyframes array */ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		fcu->bezt= MEM_callocN(sizeof(BezTriple), "beztriple"); | 
					
						
							|  |  |  | 		*(fcu->bezt)= *bezt; | 
					
						
							|  |  |  | 		fcu->totvert= 1; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-02-12 01:06:18 +00:00
										 |  |  | 	/* cannot add anything */ | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* return error code -1 to prevent any misunderstandings */ | 
					
						
							|  |  |  | 		return -1; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* we need to return the index, so that some tools which do post-processing can 
 | 
					
						
							|  |  |  | 	 * detect where we added the BezTriple in the array | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	return i; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | /* This function is a wrapper for insert_bezt_fcurve_internal(), and should be used when
 | 
					
						
							|  |  |  |  * adding a new keyframe to a curve, when the keyframe doesn't exist anywhere else yet.  | 
					
						
							|  |  |  |  * It returns the index at which the keyframe was added. | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | int insert_vert_fcurve (FCurve *fcu, float x, float y, short flag) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-11-23 08:44:21 +00:00
										 |  |  | 	BezTriple beztr= {{{0}}}; | 
					
						
							| 
									
										
										
										
											2011-02-27 08:31:10 +00:00
										 |  |  | 	unsigned int oldTot = fcu->totvert; | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	int a; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-04-02 03:52:44 +00:00
										 |  |  | 	/* set all three points, for nicer start position 
 | 
					
						
							|  |  |  | 	 * NOTE: +/- 1 on vec.x for left and right handles is so that 'free' handles work ok... | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
											  
											
												Keyframe Defaults and Cleanups: 
This commit fixes reports #21638 and #21818, which were both also Durian feature requests.
Cbanges:
* Added new default setting for the type of handles created when creating keyframes. This can be found in the user-preferences, and is used whenever existing keyframes aren't being overwritten (instead of the value being always taken from the keyframes either side, #21638).
* When keyframing over existing keyframes, only the values will be changed. The handles will be offset by the same amount that the value of the keyframe changed, though how well this works in practice still needs to be tested more thoroughly (#21818, already fixed earlier, but this commit is the full fix).
* When 'free' handles are added by default, they are offset to be +/- 1 frame on either side of the keyframe so that it is obvious that they can be moved. However, they just take the same value of the keyframe since this is easiest.
* Properly initialising handle colour defaults for 3D-View and Graph Editor. Graph Editor's theme userprefs also show these settings now, though the layout is really quick hack-style.
											
										 
											2010-04-02 01:03:40 +00:00
										 |  |  | 	beztr.vec[0][0]= x-1.0f;  | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	beztr.vec[0][1]= y; | 
					
						
							|  |  |  | 	beztr.vec[1][0]= x; | 
					
						
							|  |  |  | 	beztr.vec[1][1]= y; | 
					
						
							| 
									
										
											  
											
												Keyframe Defaults and Cleanups: 
This commit fixes reports #21638 and #21818, which were both also Durian feature requests.
Cbanges:
* Added new default setting for the type of handles created when creating keyframes. This can be found in the user-preferences, and is used whenever existing keyframes aren't being overwritten (instead of the value being always taken from the keyframes either side, #21638).
* When keyframing over existing keyframes, only the values will be changed. The handles will be offset by the same amount that the value of the keyframe changed, though how well this works in practice still needs to be tested more thoroughly (#21818, already fixed earlier, but this commit is the full fix).
* When 'free' handles are added by default, they are offset to be +/- 1 frame on either side of the keyframe so that it is obvious that they can be moved. However, they just take the same value of the keyframe since this is easiest.
* Properly initialising handle colour defaults for 3D-View and Graph Editor. Graph Editor's theme userprefs also show these settings now, though the layout is really quick hack-style.
											
										 
											2010-04-02 01:03:40 +00:00
										 |  |  | 	beztr.vec[2][0]= x+1.0f; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	beztr.vec[2][1]= y; | 
					
						
							|  |  |  | 	beztr.f1= beztr.f2= beztr.f3= SELECT; | 
					
						
							| 
									
										
											  
											
												Keyframe Defaults and Cleanups: 
This commit fixes reports #21638 and #21818, which were both also Durian feature requests.
Cbanges:
* Added new default setting for the type of handles created when creating keyframes. This can be found in the user-preferences, and is used whenever existing keyframes aren't being overwritten (instead of the value being always taken from the keyframes either side, #21638).
* When keyframing over existing keyframes, only the values will be changed. The handles will be offset by the same amount that the value of the keyframe changed, though how well this works in practice still needs to be tested more thoroughly (#21818, already fixed earlier, but this commit is the full fix).
* When 'free' handles are added by default, they are offset to be +/- 1 frame on either side of the keyframe so that it is obvious that they can be moved. However, they just take the same value of the keyframe since this is easiest.
* Properly initialising handle colour defaults for 3D-View and Graph Editor. Graph Editor's theme userprefs also show these settings now, though the layout is really quick hack-style.
											
										 
											2010-04-02 01:03:40 +00:00
										 |  |  | 	beztr.h1= beztr.h2= U.keyhandles_new; /* use default handle type here */ | 
					
						
							| 
									
										
										
										
											2009-12-10 10:40:28 +00:00
										 |  |  | 	//BEZKEYTYPE(&beztr)= scene->keytype; /* default keyframe type */
 | 
					
						
							| 
									
										
										
										
											2011-12-02 19:49:09 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* use default interpolation mode, with exceptions for int/discrete values */ | 
					
						
							|  |  |  | 	beztr.ipo= U.ipo_new; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(fcu->flag & FCURVE_DISCRETE_VALUES) | 
					
						
							|  |  |  | 		beztr.ipo = BEZT_IPO_CONST; | 
					
						
							|  |  |  | 	else if(beztr.ipo == BEZT_IPO_BEZ && (fcu->flag & FCURVE_INT_VALUES)) | 
					
						
							|  |  |  | 		beztr.ipo = BEZT_IPO_LIN; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* add temp beztriple to keyframes */ | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 	a= insert_bezt_fcurve(fcu, &beztr, flag); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* what if 'a' is a negative index? 
 | 
					
						
							|  |  |  | 	 * for now, just exit to prevent any segfaults | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 	if (a < 0) return -1; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* don't recalculate handles if fast is set
 | 
					
						
							|  |  |  | 	 *	- this is a hack to make importers faster | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 	 *	- we may calculate twice (due to autohandle needing to be calculated twice) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 	if ((flag & INSERTKEY_FAST) == 0)  | 
					
						
							|  |  |  | 		calchandles_fcurve(fcu); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* set handletype and interpolation */ | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 	if ((fcu->totvert > 2) && (flag & INSERTKEY_REPLACE)==0) { | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		BezTriple *bezt= (fcu->bezt + a); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-02-27 01:53:05 +00:00
										 |  |  | 		/* set interpolation from previous (if available), but only if we didn't just replace some keyframe 
 | 
					
						
							|  |  |  | 		 * 	- replacement is indicated by no-change in number of verts | 
					
						
							|  |  |  | 		 *	- when replacing, the user may have specified some interpolation that should be kept | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		if (fcu->totvert > oldTot) { | 
					
						
							|  |  |  | 			if (a > 0)  | 
					
						
							|  |  |  | 				bezt->ipo= (bezt-1)->ipo; | 
					
						
							|  |  |  | 			else if (a < fcu->totvert-1)  | 
					
						
							|  |  |  | 				bezt->ipo= (bezt+1)->ipo; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 		/* don't recalculate handles if fast is set
 | 
					
						
							|  |  |  | 		 *	- this is a hack to make importers faster | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 		 *	- we may calculate twice (due to autohandle needing to be calculated twice) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 		if ((flag & INSERTKEY_FAST) == 0)  | 
					
						
							|  |  |  | 			calchandles_fcurve(fcu); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* return the index at which the keyframe was added */ | 
					
						
							|  |  |  | 	return a; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* -------------- 'Smarter' Keyframing Functions -------------------- */ | 
					
						
							|  |  |  | /* return codes for new_key_needed */ | 
					
						
							| 
									
										
										
										
											2011-02-17 22:34:41 +00:00
										 |  |  | enum { | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	KEYNEEDED_DONTADD = 0, | 
					
						
							|  |  |  | 	KEYNEEDED_JUSTADD, | 
					
						
							|  |  |  | 	KEYNEEDED_DELPREV, | 
					
						
							|  |  |  | 	KEYNEEDED_DELNEXT | 
					
						
							| 
									
										
										
										
											2011-02-17 22:34:41 +00:00
										 |  |  | } /*eKeyNeededStatus*/; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* This helper function determines whether a new keyframe is needed */ | 
					
						
							|  |  |  | /* Cases where keyframes should not be added:
 | 
					
						
							| 
									
										
										
										
											2012-03-04 04:35:12 +00:00
										 |  |  |  *	1. Keyframe to be added between two keyframes with similar values | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  |  *	2. Keyframe to be added on frame where two keyframes are already situated | 
					
						
							|  |  |  |  *	3. Keyframe lies at point that intersects the linear line between two keyframes | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | static short new_key_needed (FCurve *fcu, float cFrame, float nValue)  | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	BezTriple *bezt=NULL, *prev=NULL; | 
					
						
							|  |  |  | 	int totCount, i; | 
					
						
							|  |  |  | 	float valA = 0.0f, valB = 0.0f; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* safety checking */ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	if (fcu == NULL) return KEYNEEDED_JUSTADD; | 
					
						
							|  |  |  | 	totCount= fcu->totvert; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	if (totCount == 0) return KEYNEEDED_JUSTADD; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* loop through checking if any are the same */ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	bezt= fcu->bezt; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	for (i=0; i<totCount; i++) { | 
					
						
							|  |  |  | 		float prevPosi=0.0f, prevVal=0.0f; | 
					
						
							|  |  |  | 		float beztPosi=0.0f, beztVal=0.0f; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 		/* get current time+value */	 | 
					
						
							|  |  |  | 		beztPosi= bezt->vec[1][0]; | 
					
						
							|  |  |  | 		beztVal= bezt->vec[1][1]; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 		if (prev) { | 
					
						
							|  |  |  | 			/* there is a keyframe before the one currently being examined */		 | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* get previous time+value */ | 
					
						
							|  |  |  | 			prevPosi= prev->vec[1][0]; | 
					
						
							|  |  |  | 			prevVal= prev->vec[1][1]; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* keyframe to be added at point where there are already two similar points? */ | 
					
						
							| 
									
										
										
										
											2011-03-27 14:59:55 +00:00
										 |  |  | 			if (IS_EQF(prevPosi, cFrame) && IS_EQF(beztPosi, cFrame) && IS_EQF(beztPosi, prevPosi)) { | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 				return KEYNEEDED_DONTADD; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* keyframe between prev+current points ? */ | 
					
						
							|  |  |  | 			if ((prevPosi <= cFrame) && (cFrame <= beztPosi)) { | 
					
						
							|  |  |  | 				/* is the value of keyframe to be added the same as keyframes on either side ? */ | 
					
						
							| 
									
										
										
										
											2011-03-27 14:59:55 +00:00
										 |  |  | 				if (IS_EQF(prevVal, nValue) && IS_EQF(beztVal, nValue) && IS_EQF(prevVal, beztVal)) { | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 					return KEYNEEDED_DONTADD; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							|  |  |  | 					float realVal; | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 					/* get real value of curve at that point */ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 					realVal= evaluate_fcurve(fcu, cFrame); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 					 | 
					
						
							|  |  |  | 					/* compare whether it's the same as proposed */ | 
					
						
							| 
									
										
										
										
											2011-03-27 14:59:55 +00:00
										 |  |  | 					if (IS_EQF(realVal, nValue)) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 						return KEYNEEDED_DONTADD; | 
					
						
							|  |  |  | 					else  | 
					
						
							|  |  |  | 						return KEYNEEDED_JUSTADD; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* new keyframe before prev beztriple? */ | 
					
						
							|  |  |  | 			if (cFrame < prevPosi) { | 
					
						
							|  |  |  | 				/* A new keyframe will be added. However, whether the previous beztriple
 | 
					
						
							|  |  |  | 				 * stays around or not depends on whether the values of previous/current | 
					
						
							|  |  |  | 				 * beztriples and new keyframe are the same. | 
					
						
							|  |  |  | 				 */ | 
					
						
							| 
									
										
										
										
											2011-03-27 14:59:55 +00:00
										 |  |  | 				if (IS_EQF(prevVal, nValue) && IS_EQF(beztVal, nValue) && IS_EQF(prevVal, beztVal)) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 					return KEYNEEDED_DELNEXT; | 
					
						
							|  |  |  | 				else  | 
					
						
							|  |  |  | 					return KEYNEEDED_JUSTADD; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			/* just add a keyframe if there's only one keyframe 
 | 
					
						
							| 
									
										
										
										
											2012-03-02 16:05:54 +00:00
										 |  |  | 			 * and the new one occurs before the existing one does. | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 			 */ | 
					
						
							|  |  |  | 			if ((cFrame < beztPosi) && (totCount==1)) | 
					
						
							|  |  |  | 				return KEYNEEDED_JUSTADD; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* continue. frame to do not yet passed (or other conditions not met) */ | 
					
						
							|  |  |  | 		if (i < (totCount-1)) { | 
					
						
							|  |  |  | 			prev= bezt; | 
					
						
							|  |  |  | 			bezt++; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* Frame in which to add a new-keyframe occurs after all other keys
 | 
					
						
							|  |  |  | 	 * -> If there are at least two existing keyframes, then if the values of the | 
					
						
							|  |  |  | 	 *	 last two keyframes and the new-keyframe match, the last existing keyframe | 
					
						
							|  |  |  | 	 *	 gets deleted as it is no longer required. | 
					
						
							|  |  |  | 	 * -> Otherwise, a keyframe is just added. 1.0 is added so that fake-2nd-to-last | 
					
						
							|  |  |  | 	 *	 keyframe is not equal to last keyframe. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	bezt= (fcu->bezt + (fcu->totvert - 1)); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	valA= bezt->vec[1][1]; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (prev) | 
					
						
							|  |  |  | 		valB= prev->vec[1][1]; | 
					
						
							|  |  |  | 	else  | 
					
						
							|  |  |  | 		valB= bezt->vec[1][1] + 1.0f;  | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-03-27 14:59:55 +00:00
										 |  |  | 	if (IS_EQF(valA, nValue) && IS_EQF(valA, valB)) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		return KEYNEEDED_DELPREV; | 
					
						
							|  |  |  | 	else  | 
					
						
							|  |  |  | 		return KEYNEEDED_JUSTADD; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | /* ------------------ RNA Data-Access Functions ------------------ */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Try to read value using RNA-properties obtained already */ | 
					
						
							|  |  |  | static float setting_get_rna_value (PointerRNA *ptr, PropertyRNA *prop, int index) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	float value= 0.0f; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-04-19 13:37:59 +00:00
										 |  |  | 	switch (RNA_property_type(prop)) { | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		case PROP_BOOLEAN: | 
					
						
							| 
									
										
										
											
												Implemented dynamic and multidimensional array support in RNA.
Example code: http://www.pasteall.org/7332/c.
New API functions: http://www.pasteall.org/7330/c.
Maximum number of dimensions is currently limited to 3, but can be increased arbitrarily if needed.
What this means for ID property access:
* MeshFace.verts - dynamic array, size 3 or 4 depending on MFace.v4
* MeshTextureFace.uv - dynamic, 2-dimensional array, size depends on MFace.v4
* Object.matrix - 2-dimensional array
What this means for functions:
* more intuitive API possibility, for example:
  Mesh.add_vertices([(x, y, z), (x, y, z), ...])
  Mesh.add_faces([(1, 2, 3), (4, 5, 6), ...])
Python part is not complete yet, e.g. it is possible to:
MeshFace.verts = (1, 2, 3) # even if Mesh.verts is (1, 2, 3, 4) and vice-versa
MeshTextureFace.uv = [(0.0, 0.0)] * 4 # only if a corresponding MFace is a quad
but the following won't work:
MeshTextureFace.uv[3] = (0.0, 0.0) # setting uv[3] modifies MTFace.uv[1][0] instead of MTFace.uv[3]
											
										 
											2009-08-25 17:06:36 +00:00
										 |  |  | 			if (RNA_property_array_length(ptr, prop)) | 
					
						
							| 
									
										
										
										
											2009-02-02 19:57:57 +00:00
										 |  |  | 				value= (float)RNA_property_boolean_get_index(ptr, prop, index); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 			else | 
					
						
							|  |  |  | 				value= (float)RNA_property_boolean_get(ptr, prop); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case PROP_INT: | 
					
						
							| 
									
										
										
											
												Implemented dynamic and multidimensional array support in RNA.
Example code: http://www.pasteall.org/7332/c.
New API functions: http://www.pasteall.org/7330/c.
Maximum number of dimensions is currently limited to 3, but can be increased arbitrarily if needed.
What this means for ID property access:
* MeshFace.verts - dynamic array, size 3 or 4 depending on MFace.v4
* MeshTextureFace.uv - dynamic, 2-dimensional array, size depends on MFace.v4
* Object.matrix - 2-dimensional array
What this means for functions:
* more intuitive API possibility, for example:
  Mesh.add_vertices([(x, y, z), (x, y, z), ...])
  Mesh.add_faces([(1, 2, 3), (4, 5, 6), ...])
Python part is not complete yet, e.g. it is possible to:
MeshFace.verts = (1, 2, 3) # even if Mesh.verts is (1, 2, 3, 4) and vice-versa
MeshTextureFace.uv = [(0.0, 0.0)] * 4 # only if a corresponding MFace is a quad
but the following won't work:
MeshTextureFace.uv[3] = (0.0, 0.0) # setting uv[3] modifies MTFace.uv[1][0] instead of MTFace.uv[3]
											
										 
											2009-08-25 17:06:36 +00:00
										 |  |  | 			if (RNA_property_array_length(ptr, prop)) | 
					
						
							| 
									
										
										
										
											2009-02-02 19:57:57 +00:00
										 |  |  | 				value= (float)RNA_property_int_get_index(ptr, prop, index); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 			else | 
					
						
							|  |  |  | 				value= (float)RNA_property_int_get(ptr, prop); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case PROP_FLOAT: | 
					
						
							| 
									
										
										
											
												Implemented dynamic and multidimensional array support in RNA.
Example code: http://www.pasteall.org/7332/c.
New API functions: http://www.pasteall.org/7330/c.
Maximum number of dimensions is currently limited to 3, but can be increased arbitrarily if needed.
What this means for ID property access:
* MeshFace.verts - dynamic array, size 3 or 4 depending on MFace.v4
* MeshTextureFace.uv - dynamic, 2-dimensional array, size depends on MFace.v4
* Object.matrix - 2-dimensional array
What this means for functions:
* more intuitive API possibility, for example:
  Mesh.add_vertices([(x, y, z), (x, y, z), ...])
  Mesh.add_faces([(1, 2, 3), (4, 5, 6), ...])
Python part is not complete yet, e.g. it is possible to:
MeshFace.verts = (1, 2, 3) # even if Mesh.verts is (1, 2, 3, 4) and vice-versa
MeshTextureFace.uv = [(0.0, 0.0)] * 4 # only if a corresponding MFace is a quad
but the following won't work:
MeshTextureFace.uv[3] = (0.0, 0.0) # setting uv[3] modifies MTFace.uv[1][0] instead of MTFace.uv[3]
											
										 
											2009-08-25 17:06:36 +00:00
										 |  |  | 			if (RNA_property_array_length(ptr, prop)) | 
					
						
							| 
									
										
										
										
											2009-02-02 19:57:57 +00:00
										 |  |  | 				value= RNA_property_float_get_index(ptr, prop, index); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 			else | 
					
						
							|  |  |  | 				value= RNA_property_float_get(ptr, prop); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case PROP_ENUM: | 
					
						
							|  |  |  | 			value= (float)RNA_property_enum_get(ptr, prop); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		default: | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | /* ------------------ 'Visual' Keyframing Functions ------------------ */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* internal status codes for visualkey_can_use */ | 
					
						
							|  |  |  | enum { | 
					
						
							|  |  |  | 	VISUALKEY_NONE = 0, | 
					
						
							|  |  |  | 	VISUALKEY_LOC, | 
					
						
							| 
									
										
										
										
											2011-12-09 01:27:59 +00:00
										 |  |  | 	VISUALKEY_ROT | 
					
						
							|  |  |  | 	/* VISUALKEY_SCA */ /* TODO - looks like support can be added now */ | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* This helper function determines if visual-keyframing should be used when  
 | 
					
						
							|  |  |  |  * inserting keyframes for the given channel. As visual-keyframing only works | 
					
						
							|  |  |  |  * on Object and Pose-Channel blocks, this should only get called for those  | 
					
						
							|  |  |  |  * blocktypes, when using "standard" keying but 'Visual Keying' option in Auto-Keying  | 
					
						
							|  |  |  |  * settings is on. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | static short visualkey_can_use (PointerRNA *ptr, PropertyRNA *prop) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	bConstraint *con= NULL; | 
					
						
							|  |  |  | 	short searchtype= VISUALKEY_NONE; | 
					
						
							| 
									
										
										
										
											2011-09-02 12:26:57 +00:00
										 |  |  | 	short has_parent = FALSE; | 
					
						
							| 
									
										
										
										
											2011-09-12 00:13:49 +00:00
										 |  |  | 	const char *identifier= NULL; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* validate data */ | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 	// TODO: this check is probably not needed, but it won't hurt
 | 
					
						
							|  |  |  | 	if (ELEM3(NULL, ptr, ptr->data, prop)) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* get first constraint and determine type of keyframe constraints to check for 
 | 
					
						
							|  |  |  | 	 * 	- constraints can be on either Objects or PoseChannels, so we only check if the | 
					
						
							| 
									
										
										
										
											2011-09-25 12:31:21 +00:00
										 |  |  | 	 *    ptr->type is RNA_Object or RNA_PoseBone, which are the RNA wrapping-info for | 
					
						
							|  |  |  | 	 *    those structs, allowing us to identify the owner of the data | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	if (ptr->type == &RNA_Object) { | 
					
						
							|  |  |  | 		/* Object */ | 
					
						
							|  |  |  | 		Object *ob= (Object *)ptr->data; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 		con= ob->constraints.first; | 
					
						
							| 
									
										
										
										
											2011-09-12 00:13:49 +00:00
										 |  |  | 		identifier= RNA_property_identifier(prop); | 
					
						
							| 
									
										
										
										
											2011-09-02 12:26:57 +00:00
										 |  |  | 		has_parent= (ob->parent != NULL); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-11-18 11:40:55 +00:00
										 |  |  | 	else if (ptr->type == &RNA_PoseBone) { | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 		/* Pose Channel */ | 
					
						
							|  |  |  | 		bPoseChannel *pchan= (bPoseChannel *)ptr->data; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		con= pchan->constraints.first; | 
					
						
							| 
									
										
										
										
											2011-09-12 00:13:49 +00:00
										 |  |  | 		identifier= RNA_property_identifier(prop); | 
					
						
							| 
									
										
										
										
											2011-09-02 12:26:57 +00:00
										 |  |  | 		has_parent= (pchan->parent != NULL); | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* check if any data to search using */ | 
					
						
							| 
									
										
										
										
											2011-09-02 12:26:57 +00:00
										 |  |  | 	if (ELEM(NULL, con, identifier) && (has_parent == FALSE)) | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 		return 0; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 	/* location or rotation identifiers only... */ | 
					
						
							| 
									
										
										
										
											2011-09-12 00:13:49 +00:00
										 |  |  | 	if(identifier == NULL) { | 
					
						
							|  |  |  | 		printf("%s failed: NULL identifier\n", __func__); | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if (strstr(identifier, "location")) { | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 		searchtype= VISUALKEY_LOC; | 
					
						
							| 
									
										
										
										
											2011-09-12 00:13:49 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if (strstr(identifier, "rotation")) { | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 		searchtype= VISUALKEY_ROT; | 
					
						
							| 
									
										
										
										
											2011-09-12 00:13:49 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2011-09-12 00:13:49 +00:00
										 |  |  | 		printf("%s failed: identifier - '%s' \n", __func__, identifier); | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 		return 0; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* only search if a searchtype and initial constraint are available */ | 
					
						
							| 
									
										
										
										
											2011-09-02 12:26:57 +00:00
										 |  |  | 	if (searchtype) { | 
					
						
							|  |  |  | 		/* parent is always matching */ | 
					
						
							|  |  |  | 		if (has_parent) | 
					
						
							|  |  |  | 			return 1; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* constraints */ | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		for (; con; con= con->next) { | 
					
						
							|  |  |  | 			/* only consider constraint if it is not disabled, and has influence */ | 
					
						
							|  |  |  | 			if (con->flag & CONSTRAINT_DISABLE) continue; | 
					
						
							|  |  |  | 			if (con->enforce == 0.0f) continue; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* some constraints may alter these transforms */ | 
					
						
							|  |  |  | 			switch (con->type) { | 
					
						
							|  |  |  | 				/* multi-transform constraints */ | 
					
						
							|  |  |  | 				case CONSTRAINT_TYPE_CHILDOF: | 
					
						
							|  |  |  | 					return 1; | 
					
						
							|  |  |  | 				case CONSTRAINT_TYPE_TRANSFORM: | 
					
						
							| 
									
										
										
										
											2010-12-24 16:45:04 +00:00
										 |  |  | 				case CONSTRAINT_TYPE_TRANSLIKE: | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 					return 1; | 
					
						
							|  |  |  | 				case CONSTRAINT_TYPE_FOLLOWPATH: | 
					
						
							|  |  |  | 					return 1; | 
					
						
							|  |  |  | 				case CONSTRAINT_TYPE_KINEMATIC: | 
					
						
							|  |  |  | 					return 1; | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 				/* single-transform constraits  */ | 
					
						
							|  |  |  | 				case CONSTRAINT_TYPE_TRACKTO: | 
					
						
							|  |  |  | 					if (searchtype==VISUALKEY_ROT) return 1; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				case CONSTRAINT_TYPE_ROTLIMIT: | 
					
						
							|  |  |  | 					if (searchtype==VISUALKEY_ROT) return 1; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				case CONSTRAINT_TYPE_LOCLIMIT: | 
					
						
							|  |  |  | 					if (searchtype==VISUALKEY_LOC) return 1; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				case CONSTRAINT_TYPE_ROTLIKE: | 
					
						
							|  |  |  | 					if (searchtype==VISUALKEY_ROT) return 1; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				case CONSTRAINT_TYPE_DISTLIMIT: | 
					
						
							|  |  |  | 					if (searchtype==VISUALKEY_LOC) return 1; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				case CONSTRAINT_TYPE_LOCLIKE: | 
					
						
							|  |  |  | 					if (searchtype==VISUALKEY_LOC) return 1; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				case CONSTRAINT_TYPE_LOCKTRACK: | 
					
						
							|  |  |  | 					if (searchtype==VISUALKEY_ROT) return 1; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				case CONSTRAINT_TYPE_MINMAX: | 
					
						
							|  |  |  | 					if (searchtype==VISUALKEY_LOC) return 1; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				default: | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* when some condition is met, this function returns, so here it can be 0 */ | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* This helper function extracts the value to use for visual-keyframing 
 | 
					
						
							|  |  |  |  * In the event that it is not possible to perform visual keying, try to fall-back | 
					
						
							| 
									
										
											  
											
												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
										 |  |  |  * to using the default method. Assumes that all data it has been passed is valid. | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | static float visualkey_get_value (PointerRNA *ptr, PropertyRNA *prop, int array_index) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-12-09 01:27:59 +00:00
										 |  |  | 	const char *identifier= RNA_property_identifier(prop); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 	/* handle for Objects or PoseChannels only 
 | 
					
						
							|  |  |  | 	 * 	- constraints can be on either Objects or PoseChannels, so we only check if the | 
					
						
							| 
									
										
										
										
											2009-11-25 11:05:11 +00:00
										 |  |  | 	 *	  ptr->type is RNA_Object or RNA_PoseBone, which are the RNA wrapping-info for | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 	 *  	  those structs, allowing us to identify the owner of the data  | 
					
						
							|  |  |  | 	 *	- assume that array_index will be sane | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	if (ptr->type == &RNA_Object) { | 
					
						
							|  |  |  | 		Object *ob= (Object *)ptr->data; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-09-02 12:26:57 +00:00
										 |  |  | 		/* only Location or Rotation keyframes are supported now */ | 
					
						
							|  |  |  | 		if (strstr(identifier, "location")) { | 
					
						
							|  |  |  | 			return ob->obmat[3][array_index]; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else if (strstr(identifier, "rotation_euler")) { | 
					
						
							|  |  |  | 			float eul[3]; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			mat4_to_eulO(eul, ob->rotmode, ob->obmat); | 
					
						
							|  |  |  | 			return eul[array_index]; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else if (strstr(identifier, "rotation_quaternion")) { | 
					
						
							|  |  |  | 			float trimat[3][3], quat[4]; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			copy_m3_m4(trimat, ob->obmat); | 
					
						
							|  |  |  | 			mat3_to_quat_is_ok(quat, trimat); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			return quat[array_index]; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else if (strstr(identifier, "rotation_axis_angle")) { | 
					
						
							|  |  |  | 			float axis[3], angle; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			mat4_to_axis_angle(axis, &angle, ob->obmat); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* w = 0, x,y,z = 1,2,3 */ | 
					
						
							|  |  |  | 			if (array_index == 0) | 
					
						
							|  |  |  | 				return angle; | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 				return axis[array_index - 1]; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-11-18 11:40:55 +00:00
										 |  |  | 	else if (ptr->type == &RNA_PoseBone) { | 
					
						
							| 
									
										
										
										
											2011-07-16 06:46:39 +00:00
										 |  |  | 		Object *ob = (Object *)ptr->id.data; /* we assume that this is always set, and is an object */ | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 		bPoseChannel *pchan= (bPoseChannel *)ptr->data; | 
					
						
							| 
									
										
										
										
											2011-07-16 06:46:39 +00:00
										 |  |  | 		float tmat[4][4]; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-07-16 06:46:39 +00:00
										 |  |  | 		/* Although it is not strictly required for this particular space conversion, 
 | 
					
						
							|  |  |  | 		 * arg1 must not be null, as there is a null check for the other conversions to | 
					
						
							|  |  |  | 		 * be safe. Therefore, the active object is passed here, and in many cases, this | 
					
						
							|  |  |  | 		 * will be what owns the pose-channel that is getting this anyway. | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2011-07-16 06:46:39 +00:00
										 |  |  | 		copy_m4_m4(tmat, pchan->pose_mat); | 
					
						
							|  |  |  | 		constraint_mat_convertspace(ob, pchan, tmat, CONSTRAINT_SPACE_POSE, CONSTRAINT_SPACE_LOCAL); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* Loc, Rot/Quat keyframes are supported... */ | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 		if (strstr(identifier, "location")) { | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 			/* only use for non-connected bones */ | 
					
						
							|  |  |  | 			if ((pchan->bone->parent) && !(pchan->bone->flag & BONE_CONNECTED)) | 
					
						
							| 
									
										
										
										
											2011-07-16 06:46:39 +00:00
										 |  |  | 				return tmat[3][array_index]; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 			else if (pchan->bone->parent == NULL) | 
					
						
							| 
									
										
										
										
											2011-07-16 06:46:39 +00:00
										 |  |  | 				return tmat[3][array_index]; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-09-28 10:19:20 +00:00
										 |  |  | 		else if (strstr(identifier, "rotation_euler")) { | 
					
						
							| 
									
										
										
										
											2011-07-16 06:46:39 +00:00
										 |  |  | 			float eul[3]; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			mat4_to_eulO(eul, pchan->rotmode, tmat); | 
					
						
							|  |  |  | 			return eul[array_index]; | 
					
						
							| 
									
										
										
										
											2009-02-17 10:58:40 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-09-28 10:19:20 +00:00
										 |  |  | 		else if (strstr(identifier, "rotation_quaternion")) { | 
					
						
							| 
									
										
										
										
											2011-07-16 06:46:39 +00:00
										 |  |  | 			float trimat[3][3], quat[4]; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			copy_m3_m4(trimat, tmat); | 
					
						
							|  |  |  | 			mat3_to_quat_is_ok(quat, trimat); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			return quat[array_index]; | 
					
						
							| 
									
										
										
										
											2011-02-07 11:38:57 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-07-16 06:46:39 +00:00
										 |  |  | 		else if (strstr(identifier, "rotation_axis_angle")) { | 
					
						
							|  |  |  | 			float axis[3], angle; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			mat4_to_axis_angle(axis, &angle, tmat); | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2011-02-07 11:38:57 +00:00
										 |  |  | 			/* w = 0, x,y,z = 1,2,3 */ | 
					
						
							|  |  |  | 			if (array_index == 0) | 
					
						
							| 
									
										
										
										
											2011-07-16 06:46:39 +00:00
										 |  |  | 				return angle; | 
					
						
							| 
									
										
										
										
											2011-02-07 11:38:57 +00:00
										 |  |  | 			else | 
					
						
							| 
									
										
										
										
											2011-07-16 06:46:39 +00:00
										 |  |  | 				return axis[array_index - 1]; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	/* as the function hasn't returned yet, read value from system in the default way */ | 
					
						
							|  |  |  | 	return setting_get_rna_value(ptr, prop, array_index); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ------------------------- Insert Key API ------------------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | /* Secondary Keyframing API call: 
 | 
					
						
							|  |  |  |  * 	Use this when validation of necessary animation data is not necessary, since an RNA-pointer to the necessary | 
					
						
							|  |  |  |  *	data being keyframed, and a pointer to the F-Curve to use have both been provided. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-03-01 12:20:18 +00:00
										 |  |  |  *	The flag argument is used for special settings that alter the behavior of | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  |  *	the keyframe insertion. These include the 'visual' keyframing modes, quick refresh, | 
					
						
							|  |  |  |  *	and extra keyframe filtering. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | short insert_keyframe_direct (ReportList *reports, PointerRNA ptr, PropertyRNA *prop, FCurve *fcu, float cfra, short flag) | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float curval= 0.0f; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* no F-Curve to add keyframe to? */ | 
					
						
							|  |  |  | 	if (fcu == NULL) { | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 		BKE_report(reports, RPT_ERROR, "No F-Curve to add keyframes to"); | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-08-25 00:12:11 +00:00
										 |  |  | 	/* F-Curve not editable? */ | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 	if (fcurve_is_keyframable(fcu) == 0) { | 
					
						
							|  |  |  | 		BKE_reportf(reports, RPT_ERROR,  | 
					
						
							| 
									
										
										
										
											2011-09-19 12:26:20 +00:00
										 |  |  | 			"F-Curve with path = '%s' [%d] cannot be keyframed. Ensure that it is not locked or sampled. Also, try removing F-Modifiers", | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 			fcu->rna_path, fcu->array_index); | 
					
						
							| 
									
										
										
										
											2009-08-25 00:12:11 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* if no property given yet, try to validate from F-Curve info */ | 
					
						
							|  |  |  | 	if ((ptr.id.data == NULL) && (ptr.data==NULL)) { | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 		BKE_report(reports, RPT_ERROR, "No RNA-pointer available to retrieve values for keyframing from"); | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (prop == NULL) { | 
					
						
							|  |  |  | 		PointerRNA tmp_ptr; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* try to get property we should be affecting */ | 
					
						
							|  |  |  | 		if ((RNA_path_resolve(&ptr, fcu->rna_path, &tmp_ptr, &prop) == 0) || (prop == NULL)) { | 
					
						
							|  |  |  | 			/* property not found... */ | 
					
						
							| 
									
										
										
										
											2010-12-03 17:05:21 +00:00
										 |  |  | 			const char *idname= (ptr.id.data) ? ((ID *)ptr.id.data)->name : "<No ID-Pointer>"; | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 			BKE_reportf(reports, RPT_ERROR, | 
					
						
							|  |  |  | 				"Could not insert keyframe, as RNA Path is invalid for the given ID (ID = %s, Path = %s)",  | 
					
						
							|  |  |  | 				idname, fcu->rna_path); | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | 			return 0; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			/* property found, so overwrite 'ptr' to make later code easier */ | 
					
						
							|  |  |  | 			ptr= tmp_ptr; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* set additional flags for the F-Curve (i.e. only integer values) */ | 
					
						
							|  |  |  | 	fcu->flag &= ~(FCURVE_INT_VALUES|FCURVE_DISCRETE_VALUES); | 
					
						
							|  |  |  | 	switch (RNA_property_type(prop)) { | 
					
						
							|  |  |  | 		case PROP_FLOAT: | 
					
						
							|  |  |  | 			/* do nothing */ | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case PROP_INT: | 
					
						
							|  |  |  | 			/* do integer (only 'whole' numbers) interpolation between all points */ | 
					
						
							|  |  |  | 			fcu->flag |= FCURVE_INT_VALUES; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		default: | 
					
						
							|  |  |  | 			/* do 'discrete' (i.e. enum, boolean values which cannot take any intermediate
 | 
					
						
							|  |  |  | 			 * values at all) interpolation between all points | 
					
						
							|  |  |  | 			 *	- however, we must also ensure that evaluated values are only integers still | 
					
						
							|  |  |  | 			 */ | 
					
						
							|  |  |  | 			fcu->flag |= (FCURVE_DISCRETE_VALUES|FCURVE_INT_VALUES); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* obtain value to give keyframe */ | 
					
						
							|  |  |  | 	if ( (flag & INSERTKEY_MATRIX) &&  | 
					
						
							|  |  |  | 		 (visualkey_can_use(&ptr, prop)) )  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		/* visual-keying is only available for object and pchan datablocks, as 
 | 
					
						
							|  |  |  | 		 * it works by keyframing using a value extracted from the final matrix  | 
					
						
							|  |  |  | 		 * instead of using the kt system to extract a value. | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		curval= visualkey_get_value(&ptr, prop, fcu->array_index); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* read value from system */ | 
					
						
							|  |  |  | 		curval= setting_get_rna_value(&ptr, prop, fcu->array_index); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* only insert keyframes where they are needed */ | 
					
						
							|  |  |  | 	if (flag & INSERTKEY_NEEDED) { | 
					
						
							|  |  |  | 		short insert_mode; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* check whether this curve really needs a new keyframe */ | 
					
						
							|  |  |  | 		insert_mode= new_key_needed(fcu, cfra, curval); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* insert new keyframe at current frame */ | 
					
						
							|  |  |  | 		if (insert_mode) | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 			insert_vert_fcurve(fcu, cfra, curval, flag); | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* delete keyframe immediately before/after newly added */ | 
					
						
							|  |  |  | 		switch (insert_mode) { | 
					
						
							|  |  |  | 			case KEYNEEDED_DELPREV: | 
					
						
							|  |  |  | 				delete_fcurve_key(fcu, fcu->totvert-2, 1); | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case KEYNEEDED_DELNEXT: | 
					
						
							|  |  |  | 				delete_fcurve_key(fcu, 1, 1); | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* only return success if keyframe added */ | 
					
						
							|  |  |  | 		if (insert_mode) | 
					
						
							|  |  |  | 			return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* just insert keyframe */ | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 		insert_vert_fcurve(fcu, cfra, curval, flag); | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* return success */ | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* failed */ | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | /* Main Keyframing API call:
 | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  |  *	Use this when validation of necessary animation data is necessary, since it may not exist yet. | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  |  *	 | 
					
						
							| 
									
										
										
										
											2012-03-01 12:20:18 +00:00
										 |  |  |  *	The flag argument is used for special settings that alter the behavior of | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  |  *	the keyframe insertion. These include the 'visual' keyframing modes, quick refresh, | 
					
						
							|  |  |  |  *	and extra keyframe filtering. | 
					
						
							| 
									
										
										
										
											2009-11-04 14:06:10 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  *	index of -1 keys all array indices | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | short insert_keyframe (ReportList *reports, ID *id, bAction *act, const char group[], const char rna_path[], int array_index, float cfra, short flag) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | {	 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	PointerRNA id_ptr, ptr; | 
					
						
							| 
									
										
										
										
											2010-07-14 11:03:07 +00:00
										 |  |  | 	PropertyRNA *prop = NULL; | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	FCurve *fcu; | 
					
						
							| 
									
										
										
										
											2009-11-04 14:06:10 +00:00
										 |  |  | 	int array_index_max= array_index+1; | 
					
						
							|  |  |  | 	int ret= 0; | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-04-05 11:26:33 +00:00
										 |  |  | 	/* validate pointer first - exit if failure */ | 
					
						
							| 
									
										
										
										
											2010-07-14 11:03:07 +00:00
										 |  |  | 	if (id == NULL) { | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 		BKE_reportf(reports, RPT_ERROR, "No ID-block to insert keyframe in (Path = %s)", rna_path); | 
					
						
							| 
									
										
										
										
											2010-07-14 11:03:07 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	RNA_id_pointer_create(id, &id_ptr); | 
					
						
							| 
									
										
										
										
											2009-04-05 11:26:33 +00:00
										 |  |  | 	if ((RNA_path_resolve(&id_ptr, rna_path, &ptr, &prop) == 0) || (prop == NULL)) { | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 		BKE_reportf(reports, RPT_ERROR, | 
					
						
							|  |  |  | 			"Could not insert keyframe, as RNA Path is invalid for the given ID (ID = %s, Path = %s)",  | 
					
						
							| 
									
										
										
										
											2010-07-14 11:03:07 +00:00
										 |  |  | 			(id)? id->name : "<Missing ID-Block>", rna_path); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-12-10 10:40:28 +00:00
										 |  |  | 	/* if no action is provided, keyframe to the default one attached to this ID-block */ | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | 	if (act == NULL) { | 
					
						
							|  |  |  | 		AnimData *adt= BKE_animdata_from_id(id); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* get action to add F-Curve+keyframe to */ | 
					
						
							| 
									
										
										
										
											2009-04-15 01:10:36 +00:00
										 |  |  | 		act= verify_adt_action(id, 1); | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2010-03-01 10:43:02 +00:00
										 |  |  | 		if (act == NULL) { | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 			BKE_reportf(reports, RPT_ERROR,  | 
					
						
							|  |  |  | 				"Could not insert keyframe, as this type does not support animation data (ID = %s, Path = %s)",  | 
					
						
							|  |  |  | 				id->name, rna_path); | 
					
						
							| 
									
										
										
										
											2009-12-16 17:49:51 +00:00
										 |  |  | 			return 0; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-01-25 10:16:36 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | 		/* apply NLA-mapping to frame to use (if applicable) */ | 
					
						
							|  |  |  | 		cfra= BKE_nla_tweakedit_remap(adt, cfra, NLATIME_CONVERT_UNMAP); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-11-05 08:54:33 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* key entire array convenience method */ | 
					
						
							|  |  |  | 	if (array_index == -1) {  | 
					
						
							| 
									
										
										
										
											2009-11-04 14:06:10 +00:00
										 |  |  | 		array_index= 0; | 
					
						
							| 
									
										
										
										
											2009-12-14 12:09:20 +00:00
										 |  |  | 		array_index_max= RNA_property_array_length(&ptr, prop); | 
					
						
							| 
									
										
										
										
											2010-01-29 09:32:13 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* for single properties, increase max_index so that the property itself gets included,
 | 
					
						
							|  |  |  | 		 * but don't do this for standard arrays since that can cause corruption issues  | 
					
						
							|  |  |  | 		 * (extra unused curves) | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		if (array_index_max == array_index) | 
					
						
							|  |  |  | 			array_index_max++; | 
					
						
							| 
									
										
										
										
											2009-11-04 14:06:10 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-11-05 08:54:33 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-04 14:06:10 +00:00
										 |  |  | 	/* will only loop once unless the array index was -1 */ | 
					
						
							| 
									
										
										
										
											2009-11-05 08:54:33 +00:00
										 |  |  | 	for (; array_index < array_index_max; array_index++) { | 
					
						
							| 
									
										
										
										
											2010-04-05 12:17:33 +00:00
										 |  |  | 		/* make sure the F-Curve exists 
 | 
					
						
							|  |  |  | 		 *	- if we're replacing keyframes only, DO NOT create new F-Curves if they do not exist yet | 
					
						
							|  |  |  | 		 *	  but still try to get the F-Curve if it exists... | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		fcu= verify_fcurve(act, group, rna_path, array_index, (flag & INSERTKEY_REPLACE)==0); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* we may not have a F-Curve when we're replacing only... */ | 
					
						
							|  |  |  | 		if (fcu) { | 
					
						
							|  |  |  | 			/* set color mode if the F-Curve is new (i.e. without any keyframes) */ | 
					
						
							|  |  |  | 			if ((fcu->totvert == 0) && (flag & INSERTKEY_XYZ2RGB)) { | 
					
						
							|  |  |  | 				/* for Loc/Rot/Scale and also Color F-Curves, the color of the F-Curve in the Graph Editor,
 | 
					
						
							|  |  |  | 				 * is determined by the array index for the F-Curve | 
					
						
							|  |  |  | 				 */ | 
					
						
							| 
									
										
										
										
											2011-04-11 00:49:08 +00:00
										 |  |  | 				if (ELEM5(RNA_property_subtype(prop), PROP_TRANSLATION, PROP_XYZ, PROP_EULER, PROP_COLOR, PROP_COORDS)) { | 
					
						
							| 
									
										
										
										
											2010-04-05 12:17:33 +00:00
										 |  |  | 					fcu->color_mode= FCURVE_COLOR_AUTO_RGB; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2009-12-10 10:40:28 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2010-04-05 12:17:33 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			/* insert keyframe */ | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 			ret += insert_keyframe_direct(reports, ptr, prop, fcu, cfra, flag); | 
					
						
							| 
									
										
										
										
											2009-12-10 10:40:28 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-11-04 14:06:10 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-11-05 08:54:33 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-04 14:06:10 +00:00
										 |  |  | 	return ret; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************** */ | 
					
						
							|  |  |  | /* KEYFRAME DELETION */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Main Keyframing API call:
 | 
					
						
							|  |  |  |  *	Use this when validation of necessary animation data isn't necessary as it | 
					
						
							|  |  |  |  *	already exists. It will delete a keyframe at the current frame. | 
					
						
							|  |  |  |  *	 | 
					
						
							| 
									
										
										
										
											2012-03-01 12:20:18 +00:00
										 |  |  |  *	The flag argument is used for special settings that alter the behavior of | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  |  *	the keyframe deletion. These include the quick refresh options. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | short delete_keyframe (ReportList *reports, ID *id, bAction *act, const char group[], const char rna_path[], int array_index, float cfra, short UNUSED(flag)) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-12-04 03:51:52 +00:00
										 |  |  | 	AnimData *adt= BKE_animdata_from_id(id); | 
					
						
							| 
									
										
										
										
											2010-03-01 10:43:02 +00:00
										 |  |  | 	PointerRNA id_ptr, ptr; | 
					
						
							|  |  |  | 	PropertyRNA *prop; | 
					
						
							|  |  |  | 	int array_index_max= array_index+1; | 
					
						
							|  |  |  | 	int ret= 0; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-01-26 03:16:14 +00:00
										 |  |  | 	/* sanity checks */ | 
					
						
							|  |  |  | 	if ELEM(NULL, id, adt) { | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 		BKE_report(reports, RPT_ERROR, "No ID-Block and/Or AnimData to delete keyframe from"); | 
					
						
							| 
									
										
										
										
											2010-01-26 03:23:15 +00:00
										 |  |  | 		return 0; | 
					
						
							| 
									
										
										
										
											2010-07-14 11:03:07 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-01-26 03:16:14 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-03-01 10:43:02 +00:00
										 |  |  | 	/* validate pointer first - exit if failure */ | 
					
						
							|  |  |  | 	RNA_id_pointer_create(id, &id_ptr); | 
					
						
							|  |  |  | 	if ((RNA_path_resolve(&id_ptr, rna_path, &ptr, &prop) == 0) || (prop == NULL)) { | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 		BKE_reportf(reports, RPT_ERROR, "Could not delete keyframe, as RNA Path is invalid for the given ID (ID = %s, Path = %s)", id->name, rna_path); | 
					
						
							| 
									
										
										
										
											2010-03-01 10:43:02 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	/* get F-Curve
 | 
					
						
							|  |  |  | 	 * Note: here is one of the places where we don't want new Action + F-Curve added! | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 * 		so 'add' var must be 0 | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2009-04-15 01:10:36 +00:00
										 |  |  | 	if (act == NULL) { | 
					
						
							| 
									
										
										
										
											2010-03-01 10:43:02 +00:00
										 |  |  | 		/* if no action is provided, use the default one attached to this ID-block 
 | 
					
						
							|  |  |  | 		 * 	- if it doesn't exist, then we're out of options... | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		if (adt->action) { | 
					
						
							|  |  |  | 			act= adt->action; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* apply NLA-mapping to frame to use (if applicable) */ | 
					
						
							|  |  |  | 			cfra= BKE_nla_tweakedit_remap(adt, cfra, NLATIME_CONVERT_UNMAP);  | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 			BKE_reportf(reports, RPT_ERROR, "No Action to delete keyframes from for ID = %s \n", id->name); | 
					
						
							| 
									
										
										
										
											2010-03-01 10:43:02 +00:00
										 |  |  | 			return 0; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-04-15 01:10:36 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-03-01 10:43:02 +00:00
										 |  |  | 	/* key entire array convenience method */ | 
					
						
							|  |  |  | 	if (array_index == -1) {  | 
					
						
							|  |  |  | 		array_index= 0; | 
					
						
							|  |  |  | 		array_index_max= RNA_property_array_length(&ptr, prop); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* for single properties, increase max_index so that the property itself gets included,
 | 
					
						
							|  |  |  | 		 * but don't do this for standard arrays since that can cause corruption issues  | 
					
						
							|  |  |  | 		 * (extra unused curves) | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		if (array_index_max == array_index) | 
					
						
							|  |  |  | 			array_index_max++; | 
					
						
							| 
									
										
										
										
											2009-08-25 00:12:11 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-03-01 10:43:02 +00:00
										 |  |  | 	/* will only loop once unless the array index was -1 */ | 
					
						
							|  |  |  | 	for (; array_index < array_index_max; array_index++) { | 
					
						
							|  |  |  | 		FCurve *fcu= verify_fcurve(act, group, rna_path, array_index, 0); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		short found = -1; | 
					
						
							|  |  |  | 		int i; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2010-03-01 10:43:02 +00:00
										 |  |  | 		/* check if F-Curve exists and/or whether it can be edited */ | 
					
						
							|  |  |  | 		if (fcu == NULL) | 
					
						
							|  |  |  | 			continue; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2010-03-01 10:43:02 +00:00
										 |  |  | 		if ( (fcu->flag & FCURVE_PROTECTED) || ((fcu->grp) && (fcu->grp->flag & AGRP_PROTECTED)) ) { | 
					
						
							|  |  |  | 			if (G.f & G_DEBUG) | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 				printf("WARNING: not deleting keyframe for locked F-Curve \n"); | 
					
						
							| 
									
										
										
										
											2010-03-01 10:43:02 +00:00
										 |  |  | 			continue; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* try to find index of beztriple to get rid of */ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		i = binarysearch_bezt_index(fcu->bezt, cfra, fcu->totvert, &found); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		if (found) {			 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 			/* delete the key at the index (will sanity check + do recalc afterwards) */ | 
					
						
							|  |  |  | 			delete_fcurve_key(fcu, i, 1); | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-12-04 03:51:52 +00:00
										 |  |  | 			/* Only delete curve too if it won't be doing anything anymore */ | 
					
						
							|  |  |  | 			if ((fcu->totvert == 0) && (list_has_suitable_fmodifier(&fcu->modifiers, 0, FMI_TYPE_GENERATE_CURVE) == 0)) | 
					
						
							|  |  |  | 				ANIM_fcurve_delete_from_animdata(NULL, adt, fcu); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			/* return success */ | 
					
						
							| 
									
										
										
										
											2010-03-01 10:43:02 +00:00
										 |  |  | 			ret++; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-03-01 10:43:02 +00:00
										 |  |  | 	/* return success/failure */ | 
					
						
							|  |  |  | 	return ret; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | /* ******************************************* */ | 
					
						
							|  |  |  | /* KEYFRAME MODIFICATION */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* mode for commonkey_modifykey */ | 
					
						
							| 
									
										
										
										
											2011-02-17 22:34:41 +00:00
										 |  |  | enum { | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | 	COMMONKEY_MODE_INSERT = 0, | 
					
						
							|  |  |  | 	COMMONKEY_MODE_DELETE, | 
					
						
							| 
									
										
										
										
											2011-02-17 22:34:41 +00:00
										 |  |  | } /*eCommonModifyKey_Modes*/; | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-25 10:55:03 +00:00
										 |  |  | /* Polling callback for use with ANIM_*_keyframe() operators
 | 
					
						
							|  |  |  |  * This is based on the standard ED_operator_areaactive callback, | 
					
						
							|  |  |  |  * except that it does special checks for a few spacetypes too... | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static int modify_key_op_poll(bContext *C) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ScrArea *sa= CTX_wm_area(C); | 
					
						
							|  |  |  | 	Scene *scene= CTX_data_scene(C); | 
					
						
							| 
									
										
										
										
											2009-07-28 16:33:02 +00:00
										 |  |  | 	SpaceOops *so= CTX_wm_space_outliner(C); | 
					
						
							| 
									
										
										
										
											2009-02-25 10:55:03 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* if no area or active scene */ | 
					
						
							|  |  |  | 	if (ELEM(NULL, sa, scene))  | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-05-07 03:44:34 +00:00
										 |  |  | 	/* if Outliner, don't allow in some views */ | 
					
						
							|  |  |  | 	if (so) { | 
					
						
							|  |  |  | 		if (ELEM4(so->outlinevis, SO_GROUPS, SO_LIBRARIES, SO_VERSE_SESSION, SO_VERSE_SESSION)) | 
					
						
							|  |  |  | 			return 0; | 
					
						
							|  |  |  | 		if (ELEM3(so->outlinevis, SO_SEQUENCE, SO_USERDEF, SO_KEYMAP)) | 
					
						
							|  |  |  | 			return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-02-25 10:55:03 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* TODO: checks for other space types can be added here */ | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* should be fine */ | 
					
						
							|  |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | /* Insert Key Operator ------------------------ */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | static int insert_key_exec (bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-08-01 12:47:49 +00:00
										 |  |  | 	Main *bmain= CTX_data_main(C); | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	Scene *scene= CTX_data_scene(C); | 
					
						
							|  |  |  | 	KeyingSet *ks= NULL; | 
					
						
							| 
									
										
										
										
											2011-01-03 05:36:52 +00:00
										 |  |  | 	int type= RNA_enum_get(op->ptr, "type"); | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	float cfra= (float)CFRA; // XXX for now, don't bother about all the yucky offset crap
 | 
					
						
							|  |  |  | 	short success; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | 	/* type is the Keying Set the user specified to use when calling the operator:
 | 
					
						
							|  |  |  | 	 *	- type == 0: use scene's active Keying Set | 
					
						
							|  |  |  | 	 *	- type > 0: use a user-defined Keying Set from the active scene | 
					
						
							|  |  |  | 	 *	- type < 0: use a builtin Keying Set | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	if (type == 0)  | 
					
						
							|  |  |  | 		type= scene->active_keyingset; | 
					
						
							|  |  |  | 	if (type > 0) | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 		ks= BLI_findlink(&scene->keyingsets, scene->active_keyingset-1); | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | 	else | 
					
						
							|  |  |  | 		ks= BLI_findlink(&builtin_keyingsets, -type-1); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* report failures */ | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	if (ks == NULL) { | 
					
						
							|  |  |  | 		BKE_report(op->reports, RPT_ERROR, "No active Keying Set"); | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* try to insert keyframes for the channels specified by KeyingSet */ | 
					
						
							| 
									
										
											  
											
												== Massive Keying Sets Recode ==
After a few days of wrong turns and learning the finer points of RNA-type-subclassing the hard way, this commit finally presents a refactored version of the Keying Sets system (now version 2) based on some requirements from Cessen.
For a more thorough discussion of this commit, see 
http://sites.google.com/site/aligorith/keyingsets_2.pdf?attredirects=0&d=1
------
The main highlight of this refactor is that relative Keying Sets have now been recoded so that Python callbacks are run to generate the Keying Set's list of paths everytime the Keying Set is used (to insert or delete keyframes), allowing complex heuristics to be used to determine whether a property gets keyframed based on the current context. These checks may include checking on selection status of related entities, or transform locks.
Built-In KeyingSets have also been recoded, and moved from C and out into Python. These are now coded as Relative Keying Sets, and can to some extent serve as basis for adding new relative Keying Sets. However, these have mostly been coded in a slightly 'modular' way which may be confusing for those not so familiar with Python in general. A usable template will be added soon for more general usage.
Keyframing settings (i.e. 'visual', 'needed') can now be specified on a per-path basis now, which is especially useful for Absolute Keying Sets, where control over this is often beneficial.
Most of the places where Auto-Keyframing is performed have been tidied up for consistency. I'm sure quite a few issues still exist there, but these I'll clean up over the next few days.
											
										 
											2010-03-16 06:18:49 +00:00
										 |  |  | 	success= ANIM_apply_keyingset(C, NULL, NULL, ks, MODIFYKEY_MODE_INSERT, cfra); | 
					
						
							| 
									
										
										
										
											2009-10-08 05:53:26 +00:00
										 |  |  | 	if (G.f & G_DEBUG) | 
					
						
							| 
									
										
										
										
											2010-01-22 06:48:29 +00:00
										 |  |  | 		BKE_reportf(op->reports, RPT_INFO, "KeyingSet '%s' - Successfully added %d Keyframes \n", ks->name, success); | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | 	/* report failure or do updates? */ | 
					
						
							| 
									
										
											  
											
												== Massive Keying Sets Recode ==
After a few days of wrong turns and learning the finer points of RNA-type-subclassing the hard way, this commit finally presents a refactored version of the Keying Sets system (now version 2) based on some requirements from Cessen.
For a more thorough discussion of this commit, see 
http://sites.google.com/site/aligorith/keyingsets_2.pdf?attredirects=0&d=1
------
The main highlight of this refactor is that relative Keying Sets have now been recoded so that Python callbacks are run to generate the Keying Set's list of paths everytime the Keying Set is used (to insert or delete keyframes), allowing complex heuristics to be used to determine whether a property gets keyframed based on the current context. These checks may include checking on selection status of related entities, or transform locks.
Built-In KeyingSets have also been recoded, and moved from C and out into Python. These are now coded as Relative Keying Sets, and can to some extent serve as basis for adding new relative Keying Sets. However, these have mostly been coded in a slightly 'modular' way which may be confusing for those not so familiar with Python in general. A usable template will be added soon for more general usage.
Keyframing settings (i.e. 'visual', 'needed') can now be specified on a per-path basis now, which is especially useful for Absolute Keying Sets, where control over this is often beneficial.
Most of the places where Auto-Keyframing is performed have been tidied up for consistency. I'm sure quite a few issues still exist there, but these I'll clean up over the next few days.
											
										 
											2010-03-16 06:18:49 +00:00
										 |  |  | 	if (success == MODIFYKEY_INVALID_CONTEXT) { | 
					
						
							|  |  |  | 		BKE_report(op->reports, RPT_ERROR, "No suitable context info for active Keying Set"); | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if (success) { | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | 		/* if the appropriate properties have been set, make a note that we've inserted something */ | 
					
						
							|  |  |  | 		if (RNA_boolean_get(op->ptr, "confirm_success")) | 
					
						
							|  |  |  | 			BKE_reportf(op->reports, RPT_INFO, "Successfully added %d Keyframes for KeyingSet '%s'", success, ks->name); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* send notifiers that keyframes have been changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 		WM_event_add_notifier(C, NC_ANIMATION|ND_KEYFRAME|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		BKE_report(op->reports, RPT_WARNING, "Keying Set failed to insert any keyframes"); | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	/* send updates */ | 
					
						
							| 
									
										
										
										
											2010-08-01 12:47:49 +00:00
										 |  |  | 	DAG_ids_flush_update(bmain, 0); | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | void ANIM_OT_keyframe_insert (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-06-06 15:38:50 +00:00
										 |  |  | 	PropertyRNA *prop; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Insert Keyframe"; | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | 	ot->idname= "ANIM_OT_keyframe_insert"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Insert keyframes on the current frame for all properties in the specified Keying Set"; | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* callbacks */ | 
					
						
							|  |  |  | 	ot->exec= insert_key_exec;  | 
					
						
							| 
									
										
										
										
											2009-02-25 10:55:03 +00:00
										 |  |  | 	ot->poll= modify_key_op_poll; | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-01-03 05:36:52 +00:00
										 |  |  | 	/* keyingset to use (dynamic enum) */ | 
					
						
							|  |  |  | 	prop= RNA_def_enum(ot->srna, "type", DummyRNA_DEFAULT_items, 0, "Keying Set", "The Keying Set to use"); | 
					
						
							|  |  |  | 	RNA_def_enum_funcs(prop, ANIM_keying_sets_enum_itemf); | 
					
						
							| 
									
										
										
										
											2010-06-06 15:38:50 +00:00
										 |  |  | 	RNA_def_property_flag(prop, PROP_HIDDEN); | 
					
						
							| 
									
										
										
										
											2011-01-03 05:36:52 +00:00
										 |  |  | 	ot->prop= prop; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | 	/* confirm whether a keyframe was added by showing a popup 
 | 
					
						
							|  |  |  | 	 *	- by default, this is enabled, since this operator is assumed to be called independently | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-02-17 16:34:28 +00:00
										 |  |  | 	prop= RNA_def_boolean(ot->srna, "confirm_success", 1, "Confirm Successful Insert", | 
					
						
							|  |  |  | 	                      "Show a popup when the keyframes get successfully added"); | 
					
						
							| 
									
										
										
										
											2010-06-06 15:38:50 +00:00
										 |  |  | 	RNA_def_property_flag(prop, PROP_HIDDEN); | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | /* Insert Key Operator (With Menu) ------------------------ */ | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | /* This operator checks if a menu should be shown for choosing the KeyingSet to use, 
 | 
					
						
							| 
									
										
										
										
											2010-03-25 11:34:18 +00:00
										 |  |  |  * then calls the menu if necessary before  | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-15 01:36:14 +00:00
										 |  |  | static int insert_key_menu_invoke (bContext *C, wmOperator *op, wmEvent *UNUSED(event)) | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Scene *scene= CTX_data_scene(C); | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | 	/* if prompting or no active Keying Set, show the menu */ | 
					
						
							|  |  |  | 	if ((scene->active_keyingset == 0) || RNA_boolean_get(op->ptr, "always_prompt")) { | 
					
						
							|  |  |  | 		/* call the menu, which will call this operator again, hence the cancelled */ | 
					
						
							| 
									
										
										
										
											2010-03-25 11:34:18 +00:00
										 |  |  | 		ANIM_keying_sets_menu_setup(C, op->type->name, "ANIM_OT_keyframe_insert_menu"); | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* just call the exec() on the active keyingset */ | 
					
						
							| 
									
										
										
										
											2011-01-03 05:36:52 +00:00
										 |  |  | 		RNA_enum_set(op->ptr, "type", 0); | 
					
						
							| 
									
										
										
										
											2012-01-16 16:12:03 +00:00
										 |  |  | 		RNA_boolean_set(op->ptr, "confirm_success", TRUE); | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		return op->type->exec(C, op); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  |   | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | void ANIM_OT_keyframe_insert_menu (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-06-06 15:38:50 +00:00
										 |  |  | 	PropertyRNA *prop; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | 	/* identifiers */ | 
					
						
							| 
									
										
										
										
											2009-07-24 06:51:33 +00:00
										 |  |  | 	ot->name= "Insert Keyframe Menu"; | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | 	ot->idname= "ANIM_OT_keyframe_insert_menu"; | 
					
						
							| 
									
										
										
										
											2010-12-02 02:03:30 +00:00
										 |  |  | 	ot->description= "Insert Keyframes for specified Keying Set, with menu of available Keying Sets if undefined"; | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* callbacks */ | 
					
						
							|  |  |  | 	ot->invoke= insert_key_menu_invoke; | 
					
						
							|  |  |  | 	ot->exec= insert_key_exec;  | 
					
						
							|  |  |  | 	ot->poll= ED_operator_areaactive; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-01-03 05:36:52 +00:00
										 |  |  | 	/* keyingset to use (dynamic enum) */ | 
					
						
							|  |  |  | 	prop= RNA_def_enum(ot->srna, "type", DummyRNA_DEFAULT_items, 0, "Keying Set", "The Keying Set to use"); | 
					
						
							|  |  |  | 	RNA_def_enum_funcs(prop, ANIM_keying_sets_enum_itemf); | 
					
						
							| 
									
										
										
										
											2010-06-06 15:38:50 +00:00
										 |  |  | 	RNA_def_property_flag(prop, PROP_HIDDEN); | 
					
						
							| 
									
										
										
										
											2011-01-03 05:36:52 +00:00
										 |  |  | 	ot->prop= prop; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | 	/* confirm whether a keyframe was added by showing a popup 
 | 
					
						
							|  |  |  | 	 *	- by default, this is disabled so that if a menu is shown, this doesn't come up too | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	// XXX should this just be always on?
 | 
					
						
							| 
									
										
										
										
											2012-02-17 16:34:28 +00:00
										 |  |  | 	prop= RNA_def_boolean(ot->srna, "confirm_success", 0, "Confirm Successful Insert", | 
					
						
							|  |  |  | 	                      "Show a popup when the keyframes get successfully added"); | 
					
						
							| 
									
										
										
										
											2010-06-06 15:38:50 +00:00
										 |  |  | 	RNA_def_property_flag(prop, PROP_HIDDEN); | 
					
						
							| 
									
										
										
										
											2011-01-03 05:36:52 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | 	/* whether the menu should always be shown 
 | 
					
						
							| 
									
										
										
										
											2012-03-01 12:20:18 +00:00
										 |  |  | 	 *	- by default, the menu should only be shown when there is no active Keying Set (2.5 behavior), | 
					
						
							|  |  |  | 	 *	  although in some cases it might be useful to always shown (pre 2.5 behavior) | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2010-06-06 15:38:50 +00:00
										 |  |  | 	prop= RNA_def_boolean(ot->srna, "always_prompt", 0, "Always Show Menu", ""); | 
					
						
							|  |  |  | 	RNA_def_property_flag(prop, PROP_HIDDEN); | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Delete Key Operator ------------------------ */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | static int delete_key_exec (bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-08-01 12:47:49 +00:00
										 |  |  | 	Main *bmain= CTX_data_main(C); | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	Scene *scene= CTX_data_scene(C); | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | 	KeyingSet *ks= NULL;	 | 
					
						
							| 
									
										
										
										
											2011-01-03 05:36:52 +00:00
										 |  |  | 	int type= RNA_enum_get(op->ptr, "type"); | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	float cfra= (float)CFRA; // XXX for now, don't bother about all the yucky offset crap
 | 
					
						
							|  |  |  | 	short success; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | 	/* type is the Keying Set the user specified to use when calling the operator:
 | 
					
						
							|  |  |  | 	 *	- type == 0: use scene's active Keying Set | 
					
						
							|  |  |  | 	 *	- type > 0: use a user-defined Keying Set from the active scene | 
					
						
							|  |  |  | 	 *	- type < 0: use a builtin Keying Set | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	if (type == 0)  | 
					
						
							|  |  |  | 		type= scene->active_keyingset; | 
					
						
							|  |  |  | 	if (type > 0) | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 		ks= BLI_findlink(&scene->keyingsets, scene->active_keyingset-1); | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | 	else | 
					
						
							|  |  |  | 		ks= BLI_findlink(&builtin_keyingsets, -type-1); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	/* report failure */ | 
					
						
							|  |  |  | 	if (ks == NULL) { | 
					
						
							|  |  |  | 		BKE_report(op->reports, RPT_ERROR, "No active Keying Set"); | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-02-17 16:34:28 +00:00
										 |  |  | 	/* try to delete keyframes for the channels specified by KeyingSet */ | 
					
						
							| 
									
										
											  
											
												== Massive Keying Sets Recode ==
After a few days of wrong turns and learning the finer points of RNA-type-subclassing the hard way, this commit finally presents a refactored version of the Keying Sets system (now version 2) based on some requirements from Cessen.
For a more thorough discussion of this commit, see 
http://sites.google.com/site/aligorith/keyingsets_2.pdf?attredirects=0&d=1
------
The main highlight of this refactor is that relative Keying Sets have now been recoded so that Python callbacks are run to generate the Keying Set's list of paths everytime the Keying Set is used (to insert or delete keyframes), allowing complex heuristics to be used to determine whether a property gets keyframed based on the current context. These checks may include checking on selection status of related entities, or transform locks.
Built-In KeyingSets have also been recoded, and moved from C and out into Python. These are now coded as Relative Keying Sets, and can to some extent serve as basis for adding new relative Keying Sets. However, these have mostly been coded in a slightly 'modular' way which may be confusing for those not so familiar with Python in general. A usable template will be added soon for more general usage.
Keyframing settings (i.e. 'visual', 'needed') can now be specified on a per-path basis now, which is especially useful for Absolute Keying Sets, where control over this is often beneficial.
Most of the places where Auto-Keyframing is performed have been tidied up for consistency. I'm sure quite a few issues still exist there, but these I'll clean up over the next few days.
											
										 
											2010-03-16 06:18:49 +00:00
										 |  |  | 	success= ANIM_apply_keyingset(C, NULL, NULL, ks, MODIFYKEY_MODE_DELETE, cfra); | 
					
						
							| 
									
										
										
										
											2009-10-08 05:53:26 +00:00
										 |  |  | 	if (G.f & G_DEBUG) | 
					
						
							|  |  |  | 		printf("KeyingSet '%s' - Successfully removed %d Keyframes \n", ks->name, success); | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | 	/* report failure or do updates? */ | 
					
						
							| 
									
										
											  
											
												== Massive Keying Sets Recode ==
After a few days of wrong turns and learning the finer points of RNA-type-subclassing the hard way, this commit finally presents a refactored version of the Keying Sets system (now version 2) based on some requirements from Cessen.
For a more thorough discussion of this commit, see 
http://sites.google.com/site/aligorith/keyingsets_2.pdf?attredirects=0&d=1
------
The main highlight of this refactor is that relative Keying Sets have now been recoded so that Python callbacks are run to generate the Keying Set's list of paths everytime the Keying Set is used (to insert or delete keyframes), allowing complex heuristics to be used to determine whether a property gets keyframed based on the current context. These checks may include checking on selection status of related entities, or transform locks.
Built-In KeyingSets have also been recoded, and moved from C and out into Python. These are now coded as Relative Keying Sets, and can to some extent serve as basis for adding new relative Keying Sets. However, these have mostly been coded in a slightly 'modular' way which may be confusing for those not so familiar with Python in general. A usable template will be added soon for more general usage.
Keyframing settings (i.e. 'visual', 'needed') can now be specified on a per-path basis now, which is especially useful for Absolute Keying Sets, where control over this is often beneficial.
Most of the places where Auto-Keyframing is performed have been tidied up for consistency. I'm sure quite a few issues still exist there, but these I'll clean up over the next few days.
											
										 
											2010-03-16 06:18:49 +00:00
										 |  |  | 	if (success == MODIFYKEY_INVALID_CONTEXT) { | 
					
						
							|  |  |  | 		BKE_report(op->reports, RPT_ERROR, "No suitable context info for active Keying Set"); | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if (success) { | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | 		/* if the appropriate properties have been set, make a note that we've inserted something */ | 
					
						
							|  |  |  | 		if (RNA_boolean_get(op->ptr, "confirm_success")) | 
					
						
							|  |  |  | 			BKE_reportf(op->reports, RPT_INFO, "Successfully removed %d Keyframes for KeyingSet '%s'", success, ks->name); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* send notifiers that keyframes have been changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 		WM_event_add_notifier(C, NC_ANIMATION|ND_KEYFRAME|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		BKE_report(op->reports, RPT_WARNING, "Keying Set failed to remove any keyframes"); | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* send updates */ | 
					
						
							| 
									
										
										
										
											2010-08-01 12:47:49 +00:00
										 |  |  | 	DAG_ids_flush_update(bmain, 0); | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | void ANIM_OT_keyframe_delete (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-01-03 05:36:52 +00:00
										 |  |  | 	PropertyRNA *prop; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	/* identifiers */ | 
					
						
							| 
									
										
										
										
											2011-04-19 11:17:29 +00:00
										 |  |  | 	ot->name= "Delete Keying-Set Keyframe"; | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | 	ot->idname= "ANIM_OT_keyframe_delete"; | 
					
						
							| 
									
										
										
										
											2010-02-10 21:15:44 +00:00
										 |  |  | 	ot->description= "Delete keyframes on the current frame for all properties in the specified Keying Set"; | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* callbacks */ | 
					
						
							|  |  |  | 	ot->exec= delete_key_exec;  | 
					
						
							| 
									
										
										
										
											2009-02-25 10:55:03 +00:00
										 |  |  | 	ot->poll= modify_key_op_poll; | 
					
						
							| 
									
										
										
										
											2009-02-13 09:46:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-01-03 05:36:52 +00:00
										 |  |  | 	/* keyingset to use (dynamic enum) */ | 
					
						
							|  |  |  | 	prop= RNA_def_enum(ot->srna, "type", DummyRNA_DEFAULT_items, 0, "Keying Set", "The Keying Set to use"); | 
					
						
							|  |  |  | 	RNA_def_enum_funcs(prop, ANIM_keying_sets_enum_itemf); | 
					
						
							|  |  |  | 	RNA_def_property_flag(prop, PROP_HIDDEN); | 
					
						
							|  |  |  | 	ot->prop= prop; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-24 04:21:32 +00:00
										 |  |  | 	/* confirm whether a keyframe was added by showing a popup 
 | 
					
						
							|  |  |  | 	 *	- by default, this is enabled, since this operator is assumed to be called independently | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-02-17 16:34:28 +00:00
										 |  |  | 	RNA_def_boolean(ot->srna, "confirm_success", 1, "Confirm Successful Delete", | 
					
						
							|  |  |  | 	                "Show a popup when the keyframes get successfully removed"); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | /* Delete Key Operator ------------------------ */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* XXX WARNING:
 | 
					
						
							|  |  |  |  * This is currently just a basic operator, which work in 3d-view context on objects only.  | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  |  * Should this be kept? It does have advantages over a version which requires selecting a keyingset to use... | 
					
						
							| 
									
										
											  
											
												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
										 |  |  |  * -- Joshua Leung, Jan 2009 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  |   | 
					
						
							| 
									
										
										
										
											2009-07-24 08:05:56 +00:00
										 |  |  | static int delete_key_v3d_exec (bContext *C, wmOperator *op) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-08-01 12:47:49 +00:00
										 |  |  | 	Main *bmain= CTX_data_main(C); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	Scene *scene= CTX_data_scene(C); | 
					
						
							|  |  |  | 	float cfra= (float)CFRA; // XXX for now, don't bother about all the yucky offset crap
 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	// XXX more comprehensive tests will be needed
 | 
					
						
							| 
									
										
										
										
											2009-10-29 09:14:20 +00:00
										 |  |  | 	CTX_DATA_BEGIN(C, Object*, ob, selected_objects)  | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	{ | 
					
						
							|  |  |  | 		ID *id= (ID *)ob; | 
					
						
							|  |  |  | 		FCurve *fcu, *fcn; | 
					
						
							|  |  |  | 		short success= 0; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* loop through all curves in animdata and delete keys on this frame */ | 
					
						
							| 
									
										
										
										
											2011-03-13 09:27:28 +00:00
										 |  |  | 		if ((ob->adt) && (ob->adt->action)) { | 
					
						
							| 
									
										
										
										
											2009-01-18 10:41:45 +00:00
										 |  |  | 			AnimData *adt= ob->adt; | 
					
						
							|  |  |  | 			bAction *act= adt->action; | 
					
						
							| 
									
										
										
										
											2009-01-17 05:36:58 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 			for (fcu= act->curves.first; fcu; fcu= fcn) { | 
					
						
							|  |  |  | 				fcn= fcu->next; | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 				success+= delete_keyframe(op->reports, id, NULL, NULL, fcu->rna_path, fcu->array_index, cfra, 0); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2011-03-13 09:27:28 +00:00
										 |  |  | 		BKE_reportf(op->reports, RPT_INFO, "Ob '%s' - Successfully had %d keyframes removed", id->name+2, success); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		 | 
					
						
							|  |  |  | 		ob->recalc |= OB_RECALC_OB; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	CTX_DATA_END; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* send updates */ | 
					
						
							| 
									
										
										
										
											2010-08-01 12:47:49 +00:00
										 |  |  | 	DAG_ids_flush_update(bmain, 0); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-01-28 18:26:47 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_OBJECT|ND_KEYS, NULL); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	 | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | void ANIM_OT_keyframe_delete_v3d (wmOperatorType *ot) | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name= "Delete Keyframe"; | 
					
						
							| 
									
										
										
										
											2011-05-15 17:59:48 +00:00
										 |  |  | 	ot->description= "Remove keyframes on current frame for selected object"; | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | 	ot->idname= "ANIM_OT_keyframe_delete_v3d"; | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* callbacks */ | 
					
						
							| 
									
										
										
										
											2009-03-31 22:36:13 +00:00
										 |  |  | 	ot->invoke= WM_operator_confirm; | 
					
						
							| 
									
										
										
										
											2009-07-24 08:05:56 +00:00
										 |  |  | 	ot->exec= delete_key_v3d_exec;  | 
					
						
							| 
									
										
										
										
											2009-01-31 19:40:40 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	ot->poll= ED_operator_areaactive; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag= OPTYPE_REGISTER|OPTYPE_UNDO; | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2008-12-21 10:33:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* Insert Key Button Operator ------------------------ */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int insert_key_button_exec (bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-08-01 12:47:49 +00:00
										 |  |  | 	Main *bmain= CTX_data_main(C); | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 	Scene *scene= CTX_data_scene(C); | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 	PointerRNA ptr= {{NULL}}; | 
					
						
							| 
									
										
										
										
											2009-04-09 11:36:12 +00:00
										 |  |  | 	PropertyRNA *prop= NULL; | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 	char *path; | 
					
						
							|  |  |  | 	float cfra= (float)CFRA; // XXX for now, don't bother about all the yucky offset crap
 | 
					
						
							|  |  |  | 	short success= 0; | 
					
						
							|  |  |  | 	int a, index, length, all= RNA_boolean_get(op->ptr, "all"); | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 	short flag = 0; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags for inserting keyframes */ | 
					
						
							| 
									
										
										
										
											2009-12-14 12:09:20 +00:00
										 |  |  | 	flag = ANIM_get_keyframing_flags(scene, 1); | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* try to insert keyframe using property retrieved from UI */ | 
					
						
							| 
									
										
										
										
											2010-09-25 14:32:26 +00:00
										 |  |  | 	uiContextActiveProperty(C, &ptr, &prop, &index); | 
					
						
							| 
									
										
										
										
											2009-04-09 11:36:12 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-09-23 20:26:03 +00:00
										 |  |  | 	if ((ptr.id.data && ptr.data && prop) && RNA_property_animateable(&ptr, prop)) { | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 		path= RNA_path_from_ID_to_property(&ptr, prop); | 
					
						
							| 
									
										
										
										
											2009-04-09 11:36:12 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-05-11 02:07:40 +00:00
										 |  |  | 		if (path) { | 
					
						
							|  |  |  | 			if (all) { | 
					
						
							| 
									
										
										
											
												Implemented dynamic and multidimensional array support in RNA.
Example code: http://www.pasteall.org/7332/c.
New API functions: http://www.pasteall.org/7330/c.
Maximum number of dimensions is currently limited to 3, but can be increased arbitrarily if needed.
What this means for ID property access:
* MeshFace.verts - dynamic array, size 3 or 4 depending on MFace.v4
* MeshTextureFace.uv - dynamic, 2-dimensional array, size depends on MFace.v4
* Object.matrix - 2-dimensional array
What this means for functions:
* more intuitive API possibility, for example:
  Mesh.add_vertices([(x, y, z), (x, y, z), ...])
  Mesh.add_faces([(1, 2, 3), (4, 5, 6), ...])
Python part is not complete yet, e.g. it is possible to:
MeshFace.verts = (1, 2, 3) # even if Mesh.verts is (1, 2, 3, 4) and vice-versa
MeshTextureFace.uv = [(0.0, 0.0)] * 4 # only if a corresponding MFace is a quad
but the following won't work:
MeshTextureFace.uv[3] = (0.0, 0.0) # setting uv[3] modifies MTFace.uv[1][0] instead of MTFace.uv[3]
											
										 
											2009-08-25 17:06:36 +00:00
										 |  |  | 				length= RNA_property_array_length(&ptr, prop); | 
					
						
							| 
									
										
										
										
											2009-04-09 11:36:12 +00:00
										 |  |  | 				 | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 				if(length) index= 0; | 
					
						
							|  |  |  | 				else length= 1; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 				length= 1; | 
					
						
							| 
									
										
										
										
											2009-04-09 11:36:12 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-05-11 02:07:40 +00:00
										 |  |  | 			for (a=0; a<length; a++) | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 				success+= insert_keyframe(op->reports, ptr.id.data, NULL, NULL, path, index+a, cfra, flag); | 
					
						
							| 
									
										
										
										
											2009-04-09 11:36:12 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 			MEM_freeN(path); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | 		else if (ptr.type == &RNA_NlaStrip) { | 
					
						
							|  |  |  | 			/* handle special vars for NLA-strips */ | 
					
						
							|  |  |  | 			NlaStrip *strip= (NlaStrip *)ptr.data; | 
					
						
							| 
									
										
										
										
											2009-09-04 04:27:06 +00:00
										 |  |  | 			FCurve *fcu= list_find_fcurve(&strip->fcurves, RNA_property_identifier(prop), flag); | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 			success+= insert_keyframe_direct(op->reports, ptr, prop, fcu, cfra, 0); | 
					
						
							| 
									
										
										
										
											2009-07-08 05:00:10 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-05-17 06:57:48 +00:00
										 |  |  | 		else { | 
					
						
							|  |  |  | 			if (G.f & G_DEBUG) | 
					
						
							|  |  |  | 				printf("Button Insert-Key: no path to property \n"); | 
					
						
							| 
									
										
										
										
											2011-09-19 12:26:20 +00:00
										 |  |  | 			BKE_report(op->reports, RPT_WARNING, "Failed to resolve path to property. Try using a Keying Set instead"); | 
					
						
							| 
									
										
										
										
											2009-05-17 06:57:48 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-05-11 02:07:40 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if (G.f & G_DEBUG) { | 
					
						
							| 
									
										
										
										
											2010-12-03 01:52:28 +00:00
										 |  |  | 		printf("ptr.data = %p, prop = %p,", (void *)ptr.data, (void *)prop); | 
					
						
							| 
									
										
										
										
											2011-01-03 05:36:52 +00:00
										 |  |  | 		if (prop) | 
					
						
							| 
									
										
										
										
											2012-03-03 11:45:08 +00:00
										 |  |  | 			printf("animatable = %d \n", RNA_property_animateable(&ptr, prop)); | 
					
						
							| 
									
										
										
										
											2009-06-09 10:30:11 +00:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2012-03-03 11:45:08 +00:00
										 |  |  | 			printf("animatable = NULL \n"); | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-05-11 02:07:40 +00:00
										 |  |  | 	if (success) { | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 		/* send updates */ | 
					
						
							| 
									
										
										
										
											2010-09-25 14:32:26 +00:00
										 |  |  | 		uiContextAnimUpdate(C); | 
					
						
							| 
									
										
										
										
											2011-01-03 05:36:52 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2010-08-01 12:47:49 +00:00
										 |  |  | 		DAG_ids_flush_update(bmain, 0); | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2010-02-09 00:02:22 +00:00
										 |  |  | 		/* send notifiers that keyframes have been changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 		WM_event_add_notifier(C, NC_ANIMATION|ND_KEYFRAME|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return (success)? OPERATOR_FINISHED: OPERATOR_CANCELLED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | void ANIM_OT_keyframe_insert_button (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							| 
									
										
										
										
											2009-07-24 08:05:56 +00:00
										 |  |  | 	ot->name= "Insert Keyframe (Buttons)"; | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | 	ot->idname= "ANIM_OT_keyframe_insert_button"; | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* callbacks */ | 
					
						
							|  |  |  | 	ot->exec= insert_key_button_exec;  | 
					
						
							|  |  |  | 	ot->poll= modify_key_op_poll; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							| 
									
										
										
										
											2009-07-24 08:05:56 +00:00
										 |  |  | 	ot->flag= OPTYPE_UNDO; | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* properties */ | 
					
						
							| 
									
										
										
										
											2011-09-19 12:26:20 +00:00
										 |  |  | 	RNA_def_boolean(ot->srna, "all", 1, "All", "Insert a keyframe for all element of the array"); | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Delete Key Button Operator ------------------------ */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int delete_key_button_exec (bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-08-01 12:47:49 +00:00
										 |  |  | 	Main *bmain= CTX_data_main(C); | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 	Scene *scene= CTX_data_scene(C); | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 	PointerRNA ptr= {{NULL}}; | 
					
						
							| 
									
										
										
										
											2009-04-09 11:36:12 +00:00
										 |  |  | 	PropertyRNA *prop= NULL; | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 	char *path; | 
					
						
							|  |  |  | 	float cfra= (float)CFRA; // XXX for now, don't bother about all the yucky offset crap
 | 
					
						
							|  |  |  | 	short success= 0; | 
					
						
							|  |  |  | 	int a, index, length, all= RNA_boolean_get(op->ptr, "all"); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* try to insert keyframe using property retrieved from UI */ | 
					
						
							| 
									
										
										
										
											2010-09-25 14:32:26 +00:00
										 |  |  | 	uiContextActiveProperty(C, &ptr, &prop, &index); | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-23 20:26:03 +00:00
										 |  |  | 	if (ptr.id.data && ptr.data && prop) { | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 		path= RNA_path_from_ID_to_property(&ptr, prop); | 
					
						
							| 
									
										
										
										
											2009-04-09 11:36:12 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-05-11 02:07:40 +00:00
										 |  |  | 		if (path) { | 
					
						
							|  |  |  | 			if (all) { | 
					
						
							| 
									
										
										
											
												Implemented dynamic and multidimensional array support in RNA.
Example code: http://www.pasteall.org/7332/c.
New API functions: http://www.pasteall.org/7330/c.
Maximum number of dimensions is currently limited to 3, but can be increased arbitrarily if needed.
What this means for ID property access:
* MeshFace.verts - dynamic array, size 3 or 4 depending on MFace.v4
* MeshTextureFace.uv - dynamic, 2-dimensional array, size depends on MFace.v4
* Object.matrix - 2-dimensional array
What this means for functions:
* more intuitive API possibility, for example:
  Mesh.add_vertices([(x, y, z), (x, y, z), ...])
  Mesh.add_faces([(1, 2, 3), (4, 5, 6), ...])
Python part is not complete yet, e.g. it is possible to:
MeshFace.verts = (1, 2, 3) # even if Mesh.verts is (1, 2, 3, 4) and vice-versa
MeshTextureFace.uv = [(0.0, 0.0)] * 4 # only if a corresponding MFace is a quad
but the following won't work:
MeshTextureFace.uv[3] = (0.0, 0.0) # setting uv[3] modifies MTFace.uv[1][0] instead of MTFace.uv[3]
											
										 
											2009-08-25 17:06:36 +00:00
										 |  |  | 				length= RNA_property_array_length(&ptr, prop); | 
					
						
							| 
									
										
										
										
											2009-04-09 11:36:12 +00:00
										 |  |  | 				 | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 				if (length) index= 0; | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 				else length= 1; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 				length= 1; | 
					
						
							| 
									
										
										
										
											2009-04-09 11:36:12 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-05-11 02:07:40 +00:00
										 |  |  | 			for (a=0; a<length; a++) | 
					
						
							| 
									
										
										
										
											2010-11-17 12:02:36 +00:00
										 |  |  | 				success+= delete_keyframe(op->reports, ptr.id.data, NULL, NULL, path, index+a, cfra, 0); | 
					
						
							| 
									
										
										
										
											2009-04-09 11:36:12 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 			MEM_freeN(path); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-05-11 02:07:40 +00:00
										 |  |  | 		else if (G.f & G_DEBUG) | 
					
						
							|  |  |  | 			printf("Button Delete-Key: no path to property \n"); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if (G.f & G_DEBUG) { | 
					
						
							| 
									
										
										
										
											2010-12-03 01:52:28 +00:00
										 |  |  | 		printf("ptr.data = %p, prop = %p \n", (void *)ptr.data, (void *)prop); | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-02-09 00:02:22 +00:00
										 |  |  | 	if (success) { | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 		/* send updates */ | 
					
						
							| 
									
										
										
										
											2010-09-25 14:32:26 +00:00
										 |  |  | 		uiContextAnimUpdate(C); | 
					
						
							| 
									
										
										
										
											2011-01-03 05:36:52 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2010-08-01 12:47:49 +00:00
										 |  |  | 		DAG_ids_flush_update(bmain, 0); | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2010-02-09 00:02:22 +00:00
										 |  |  | 		/* send notifiers that keyframes have been changed */ | 
					
						
							| 
									
										
										
										
											2010-06-18 04:39:32 +00:00
										 |  |  | 		WM_event_add_notifier(C, NC_ANIMATION|ND_KEYFRAME|NA_EDITED, NULL); | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return (success)? OPERATOR_FINISHED: OPERATOR_CANCELLED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | void ANIM_OT_keyframe_delete_button (wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							| 
									
										
										
										
											2009-07-24 08:05:56 +00:00
										 |  |  | 	ot->name= "Delete Keyframe (Buttons)"; | 
					
						
							| 
									
										
										
										
											2009-11-28 14:37:21 +00:00
										 |  |  | 	ot->idname= "ANIM_OT_keyframe_delete_button"; | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* callbacks */ | 
					
						
							|  |  |  | 	ot->exec= delete_key_button_exec;  | 
					
						
							|  |  |  | 	ot->poll= modify_key_op_poll; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							| 
									
										
										
										
											2009-07-24 08:05:56 +00:00
										 |  |  | 	ot->flag= OPTYPE_UNDO; | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* properties */ | 
					
						
							| 
									
										
										
										
											2011-09-19 12:26:20 +00:00
										 |  |  | 	RNA_def_boolean(ot->srna, "all", 1, "All", "Delete keyfames from all elements of the array"); | 
					
						
							| 
									
										
										
										
											2009-04-03 23:30:32 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | /* ******************************************* */ | 
					
						
							| 
									
										
										
										
											2009-07-12 02:06:15 +00:00
										 |  |  | /* AUTO KEYFRAME */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int autokeyframe_cfra_can_key(Scene *scene, ID *id) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	float cfra= (float)CFRA; // XXX for now, this will do
 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* only filter if auto-key mode requires this */ | 
					
						
							|  |  |  | 	if (IS_AUTOKEY_ON(scene) == 0) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							| 
									
										
										
										
											2009-07-31 07:43:47 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 	if (IS_AUTOKEY_MODE(scene, NORMAL)) { | 
					
						
							|  |  |  | 		/* can insert anytime we like... */ | 
					
						
							| 
									
										
										
										
											2009-07-12 02:06:15 +00:00
										 |  |  | 		return 1; | 
					
						
							| 
									
										
										
										
											2009-07-31 07:43:47 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else /* REPLACE */ { | 
					
						
							|  |  |  | 		/* for whole block - only key if there's a keyframe on that frame already
 | 
					
						
							|  |  |  | 		 *	this is a valid assumption when we're blocking + tweaking | 
					
						
							|  |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2009-07-12 02:06:15 +00:00
										 |  |  | 		return id_frame_has_keyframe(id, cfra, ANIMFILTER_KEYS_LOCAL); | 
					
						
							| 
									
										
										
										
											2009-07-31 07:43:47 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-07-12 02:06:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******************************************* */ | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | /* KEYFRAME DETECTION */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* --------------- API/Per-Datablock Handling ------------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-08 12:30:09 +00:00
										 |  |  | /* Checks if some F-Curve has a keyframe for a given frame */ | 
					
						
							|  |  |  | short fcurve_frame_has_keyframe (FCurve *fcu, float frame, short filter) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* quick sanity check */ | 
					
						
							| 
									
										
										
										
											2009-10-17 04:22:52 +00:00
										 |  |  | 	if (ELEM(NULL, fcu, fcu->bezt)) | 
					
						
							| 
									
										
										
										
											2009-07-08 12:30:09 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* we either include all regardless of muting, or only non-muted  */ | 
					
						
							|  |  |  | 	if ((filter & ANIMFILTER_KEYS_MUTED) || (fcu->flag & FCURVE_MUTED)==0) { | 
					
						
							|  |  |  | 		short replace = -1; | 
					
						
							|  |  |  | 		int i = binarysearch_bezt_index(fcu->bezt, frame, fcu->totvert, &replace); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* binarysearch_bezt_index will set replace to be 0 or 1
 | 
					
						
							|  |  |  | 		 * 	- obviously, 1 represents a match | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		if (replace) {			 | 
					
						
							|  |  |  | 			/* sanity check: 'i' may in rare cases exceed arraylen */ | 
					
						
							|  |  |  | 			if ((i >= 0) && (i < fcu->totvert)) | 
					
						
							|  |  |  | 				return 1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-10 03:34:20 +00:00
										 |  |  | /* Checks whether an Action has a keyframe for a given frame 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  |  * Since we're only concerned whether a keyframe exists, we can simply loop until a match is found... | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-02-14 17:55:27 +00:00
										 |  |  | static short action_frame_has_keyframe (bAction *act, float frame, short filter) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	FCurve *fcu; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* can only find if there is data */ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	if (act == NULL) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* if only check non-muted, check if muted */ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	if ((filter & ANIMFILTER_KEYS_MUTED) || (act->flag & ACT_MUTED)) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	/* loop over F-Curves, using binary-search to try to find matches 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	 *	- this assumes that keyframes are only beztriples | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	for (fcu= act->curves.first; fcu; fcu= fcu->next) { | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		/* only check if there are keyframes (currently only of type BezTriple) */ | 
					
						
							| 
									
										
										
										
											2009-02-09 11:05:34 +00:00
										 |  |  | 		if (fcu->bezt && fcu->totvert) { | 
					
						
							| 
									
										
										
										
											2009-07-08 12:30:09 +00:00
										 |  |  | 			if (fcurve_frame_has_keyframe(fcu, frame, filter)) | 
					
						
							|  |  |  | 				return 1; | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* nothing found */ | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Checks whether an Object has a keyframe for a given frame */ | 
					
						
							| 
									
										
										
										
											2011-02-14 17:55:27 +00:00
										 |  |  | static short object_frame_has_keyframe (Object *ob, float frame, short filter) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* error checking */ | 
					
						
							| 
									
										
										
										
											2009-01-18 10:41:45 +00:00
										 |  |  | 	if (ob == NULL) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	/* check own animation data - specifically, the action it contains */ | 
					
						
							| 
									
										
										
										
											2009-01-18 10:41:45 +00:00
										 |  |  | 	if ((ob->adt) && (ob->adt->action)) { | 
					
						
							| 
									
										
										
										
											2009-01-17 05:36:58 +00:00
										 |  |  | 		if (action_frame_has_keyframe(ob->adt->action, frame, filter)) | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 			return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* try shapekey keyframes (if available, and allowed by filter) */ | 
					
						
							| 
									
										
										
										
											2008-12-21 04:11:19 +00:00
										 |  |  | 	if ( !(filter & ANIMFILTER_KEYS_LOCAL) && !(filter & ANIMFILTER_KEYS_NOSKEY) ) { | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		Key *key= ob_get_key(ob); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* shapekeys can have keyframes ('Relative Shape Keys') 
 | 
					
						
							|  |  |  | 		 * or depend on time (old 'Absolute Shape Keys')  | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		  | 
					
						
							|  |  |  | 			/* 1. test for relative (with keyframes) */ | 
					
						
							|  |  |  | 		if (id_frame_has_keyframe((ID *)key, frame, filter)) | 
					
						
							|  |  |  | 			return 1; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* 2. test for time */ | 
					
						
							|  |  |  | 		// TODO... yet to be implemented (this feature may evolve before then anyway)
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* try materials */ | 
					
						
							| 
									
										
										
										
											2008-12-21 04:11:19 +00:00
										 |  |  | 	if ( !(filter & ANIMFILTER_KEYS_LOCAL) && !(filter & ANIMFILTER_KEYS_NOMAT) ) { | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		/* if only active, then we can skip a lot of looping */ | 
					
						
							| 
									
										
										
										
											2008-12-21 04:11:19 +00:00
										 |  |  | 		if (filter & ANIMFILTER_KEYS_ACTIVE) { | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 			Material *ma= give_current_material(ob, (ob->actcol + 1)); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* we only retrieve the active material... */ | 
					
						
							|  |  |  | 			if (id_frame_has_keyframe((ID *)ma, frame, filter)) | 
					
						
							|  |  |  | 				return 1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			int a; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* loop over materials */ | 
					
						
							|  |  |  | 			for (a=0; a<ob->totcol; a++) { | 
					
						
							|  |  |  | 				Material *ma= give_current_material(ob, a+1); | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				if (id_frame_has_keyframe((ID *)ma, frame, filter)) | 
					
						
							|  |  |  | 					return 1; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* nothing found */ | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* --------------- API ------------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Checks whether a keyframe exists for the given ID-block one the given frame */ | 
					
						
							|  |  |  | short id_frame_has_keyframe (ID *id, float frame, short filter) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	/* sanity checks */ | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	if (id == NULL) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	/* perform special checks for 'macro' types */ | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	switch (GS(id->name)) { | 
					
						
							|  |  |  | 		case ID_OB: /* object */ | 
					
						
							|  |  |  | 			return object_frame_has_keyframe((Object *)id, frame, filter); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		case ID_SCE: /* scene */ | 
					
						
							| 
									
										
										
										
											2012-03-01 12:20:18 +00:00
										 |  |  | 		// XXX TODO... for now, just use 'normal' behavior
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		//	break;
 | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		default: 	/* 'normal type' */ | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		{ | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 			AnimData *adt= BKE_animdata_from_id(id); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 			/* only check keyframes in active action */ | 
					
						
							|  |  |  | 			if (adt) | 
					
						
							|  |  |  | 				return action_frame_has_keyframe(adt->action, frame, filter); | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2008-12-20 08:24:24 +00:00
										 |  |  | 	/* no keyframe found */ | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************** */ | 
					
						
							| 
									
										
										
										
											2011-10-10 12:56:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | int ED_autokeyframe_object(bContext *C, Scene *scene, Object *ob, KeyingSet *ks) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* auto keyframing */ | 
					
						
							|  |  |  | 	if (autokeyframe_cfra_can_key(scene, &ob->id)) { | 
					
						
							|  |  |  | 		ListBase dsources = {NULL, NULL}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* now insert the keyframe(s) using the Keying Set
 | 
					
						
							|  |  |  | 		 *	1) add datasource override for the Object | 
					
						
							|  |  |  | 		 *	2) insert keyframes | 
					
						
							|  |  |  | 		 *	3) free the extra info | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		ANIM_relative_keyingset_add_source(&dsources, &ob->id, NULL, NULL); | 
					
						
							|  |  |  | 		ANIM_apply_keyingset(C, &dsources, NULL, ks, MODIFYKEY_MODE_INSERT, (float)CFRA); | 
					
						
							|  |  |  | 		BLI_freelistN(&dsources); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return TRUE; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		return FALSE; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int ED_autokeyframe_pchan(bContext *C, Scene *scene, Object *ob, bPoseChannel *pchan, KeyingSet *ks) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (autokeyframe_cfra_can_key(scene, &ob->id)) { | 
					
						
							|  |  |  | 		ListBase dsources = {NULL, NULL}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* now insert the keyframe(s) using the Keying Set
 | 
					
						
							|  |  |  | 		 *	1) add datasource override for the PoseChannel | 
					
						
							|  |  |  | 		 *	2) insert keyframes | 
					
						
							|  |  |  | 		 *	3) free the extra info | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		ANIM_relative_keyingset_add_source(&dsources, &ob->id, &RNA_PoseBone, pchan); | 
					
						
							|  |  |  | 		ANIM_apply_keyingset(C, &dsources, NULL, ks, MODIFYKEY_MODE_INSERT, (float)CFRA); | 
					
						
							|  |  |  | 		BLI_freelistN(&dsources); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* clear any unkeyed tags */ | 
					
						
							|  |  |  | 		if (pchan->bone) { | 
					
						
							|  |  |  | 			pchan->bone->flag &= ~BONE_UNKEYED; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return TRUE; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* add unkeyed tags */ | 
					
						
							|  |  |  | 		if (pchan->bone) { | 
					
						
							|  |  |  | 			pchan->bone->flag |= BONE_UNKEYED; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return FALSE; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |