| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2009-06-23 00:09:26 +00:00
										 |  |  |  * $Id$ | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * ***** BEGIN GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							|  |  |  |  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  |  * The Original Code is Copyright (C) 2009 Blender Foundation, Joshua Leung | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is: all of this file. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  |  * Contributor(s): Joshua Leung (full recode) | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* System includes ----------------------------------------------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <math.h>
 | 
					
						
							|  |  |  | #include <stdlib.h>
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #include <float.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_CONFIG_H
 | 
					
						
							|  |  |  | #include <config.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "MEM_guardedalloc.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "BLI_blenlib.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | #include "BLI_math.h"
 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | #include "BLI_dlrbTree.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "DNA_listBase.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-20 11:07:42 +00:00
										 |  |  | #include "DNA_anim_types.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | #include "DNA_action_types.h"
 | 
					
						
							|  |  |  | #include "DNA_armature_types.h"
 | 
					
						
							|  |  |  | #include "DNA_camera_types.h"
 | 
					
						
							|  |  |  | #include "DNA_curve_types.h"
 | 
					
						
							|  |  |  | #include "DNA_object_types.h"
 | 
					
						
							|  |  |  | #include "DNA_screen_types.h"
 | 
					
						
							|  |  |  | #include "DNA_scene_types.h"
 | 
					
						
							|  |  |  | #include "DNA_space_types.h"
 | 
					
						
							|  |  |  | #include "DNA_key_types.h"
 | 
					
						
							|  |  |  | #include "DNA_lamp_types.h"
 | 
					
						
							|  |  |  | #include "DNA_material_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-10-06 03:05:20 +00:00
										 |  |  | #include "DNA_meta_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-11 05:03:49 +00:00
										 |  |  | #include "DNA_node_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-10-06 03:05:20 +00:00
										 |  |  | #include "DNA_particle_types.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | #include "DNA_userdef_types.h"
 | 
					
						
							|  |  |  | #include "DNA_gpencil_types.h"
 | 
					
						
							|  |  |  | #include "DNA_windowmanager_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-02-13 06:33:07 +00:00
										 |  |  | #include "DNA_world_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | #include "DNA_view2d_types.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "BKE_action.h"
 | 
					
						
							|  |  |  | #include "BKE_depsgraph.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-20 11:07:42 +00:00
										 |  |  | #include "BKE_fcurve.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | #include "BKE_key.h"
 | 
					
						
							|  |  |  | #include "BKE_material.h"
 | 
					
						
							|  |  |  | #include "BKE_object.h"
 | 
					
						
							|  |  |  | #include "BKE_global.h" 	// XXX remove me!
 | 
					
						
							|  |  |  | #include "BKE_context.h"
 | 
					
						
							|  |  |  | #include "BKE_utildefines.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "BIF_gl.h"
 | 
					
						
							|  |  |  | #include "BIF_glutil.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "UI_interface.h"
 | 
					
						
							|  |  |  | #include "UI_interface_icons.h"
 | 
					
						
							|  |  |  | #include "UI_resources.h"
 | 
					
						
							|  |  |  | #include "UI_view2d.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "ED_anim_api.h"
 | 
					
						
							|  |  |  | #include "ED_keyframing.h"
 | 
					
						
							|  |  |  | #include "ED_keyframes_draw.h"
 | 
					
						
							|  |  |  | #include "ED_screen.h"
 | 
					
						
							|  |  |  | #include "ED_space_api.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-17 00:17:37 +00:00
										 |  |  | /* *************************** Keyframe Processing *************************** */ | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | /* ActKeyColumns (Keyframe Columns) ------------------------------------------ */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-15 11:20:44 +00:00
										 |  |  | /* Comparator callback used for ActKeyColumns and cframe float-value pointer */ | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | // NOTE: this is exported to other modules that use the ActKeyColumns for finding keyframes
 | 
					
						
							| 
									
										
										
										
											2009-11-15 11:20:44 +00:00
										 |  |  | short compare_ak_cfraPtr (void *node, void *data) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ActKeyColumn *ak= (ActKeyColumn *)node; | 
					
						
							|  |  |  | 	float *cframe= data; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (*cframe < ak->cfra) | 
					
						
							|  |  |  | 		return -1; | 
					
						
							|  |  |  | 	else if (*cframe > ak->cfra) | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | /* --------------- */ | 
					
						
							| 
									
										
										
										
											2009-11-15 11:20:44 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* Comparator callback used for ActKeyColumns and BezTriple */ | 
					
						
							|  |  |  | static short compare_ak_bezt (void *node, void *data) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ActKeyColumn *ak= (ActKeyColumn *)node; | 
					
						
							|  |  |  | 	BezTriple *bezt= (BezTriple *)data; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (bezt->vec[1][0] < ak->cfra) | 
					
						
							|  |  |  | 		return -1; | 
					
						
							|  |  |  | 	else if (bezt->vec[1][0] > ak->cfra) | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* New node callback used for building ActKeyColumns from BezTriples */ | 
					
						
							|  |  |  | static DLRBT_Node *nalloc_ak_bezt (void *data) | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	ActKeyColumn *ak= MEM_callocN(sizeof(ActKeyColumn), "ActKeyColumn"); | 
					
						
							| 
									
										
										
										
											2009-11-15 11:20:44 +00:00
										 |  |  | 	BezTriple *bezt= (BezTriple *)data; | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	/* store settings based on state of BezTriple */ | 
					
						
							|  |  |  | 	ak->cfra= bezt->vec[1][0]; | 
					
						
							|  |  |  | 	ak->sel= BEZSELECTED(bezt) ? SELECT : 0; | 
					
						
							| 
									
										
										
										
											2009-09-04 02:44:56 +00:00
										 |  |  | 	ak->key_type= BEZKEYTYPE(bezt);  | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* set 'modified', since this is used to identify long keyframes */ | 
					
						
							|  |  |  | 	ak->modified = 1; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-15 11:20:44 +00:00
										 |  |  | 	return (DLRBT_Node *)ak; | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-15 11:20:44 +00:00
										 |  |  | /* Node updater callback used for building ActKeyColumns from BezTriples */ | 
					
						
							|  |  |  | static void nupdate_ak_bezt (void *node, void *data) | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-11-15 11:20:44 +00:00
										 |  |  | 	ActKeyColumn *ak= (ActKeyColumn *)node; | 
					
						
							|  |  |  | 	BezTriple *bezt= (BezTriple *)data; | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-15 11:20:44 +00:00
										 |  |  | 	/* set selection status and 'touched' status */ | 
					
						
							|  |  |  | 	if (BEZSELECTED(bezt)) ak->sel = SELECT; | 
					
						
							|  |  |  | 	ak->modified += 1; | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-15 11:20:44 +00:00
										 |  |  | 	/* for keyframe type, 'proper' keyframes have priority over breakdowns (and other types for now) */ | 
					
						
							|  |  |  | 	if (BEZKEYTYPE(bezt) == BEZT_KEYTYPE_KEYFRAME) | 
					
						
							|  |  |  | 		ak->key_type= BEZT_KEYTYPE_KEYFRAME; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* --------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Add the given BezTriple to the given 'list' of Keyframes */ | 
					
						
							|  |  |  | static void add_bezt_to_keycolumns_list(DLRBT_Tree *keys, BezTriple *bezt) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if ELEM(NULL, keys, bezt)  | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		BLI_dlrbTree_add(keys, compare_ak_bezt, nalloc_ak_bezt, nupdate_ak_bezt, bezt); | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | /* ActBeztColumns (Helpers for Long Keyframes) ------------------------------ */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-11 11:18:55 +00:00
										 |  |  | /* maximum size of default buffer for BezTriple columns */ | 
					
						
							|  |  |  | #define MAX_ABK_BUFSIZE 	4
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | /* BezTriple Container Node */ | 
					
						
							|  |  |  | // NOTE: only used internally while building Long Keyframes for now, but may be useful externally?
 | 
					
						
							|  |  |  | typedef struct ActBeztColumn { | 
					
						
							|  |  |  | 	/* Tree Node interface ---------------- */ | 
					
						
							|  |  |  | 		/* ListBase linkage */ | 
					
						
							|  |  |  | 	struct ActBeztColumn *next, *prev; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		/* sorting-tree linkage */ | 
					
						
							|  |  |  | 	struct ActBeztColumn *left, *right;	/* 'children' of this node, less than and greater than it (respectively) */ | 
					
						
							|  |  |  | 	struct ActBeztColumn *parent;		/* parent of this node in the tree */ | 
					
						
							|  |  |  | 	char tree_col;						/* DLRB_BLACK or DLRB_RED */ | 
					
						
							|  |  |  | 	char pad; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* BezTriple Store -------------------- */ | 
					
						
							|  |  |  | 	short numBezts;						/* number of BezTriples on this frame */ | 
					
						
							|  |  |  | 	float cfra;							/* frame that the BezTriples occur on */ | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-12-11 11:18:55 +00:00
										 |  |  | 	BezTriple *bezts[MAX_ABK_BUFSIZE];	/* buffer of pointers to BezTriples on the same frame */ | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | 	//BezTriple **bezts_extra;			/* secondary buffer of pointers if need be */
 | 
					
						
							|  |  |  | } ActBeztColumn; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* --------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Comparator callback used for ActBeztColumns and BezTriple */ | 
					
						
							|  |  |  | static short compare_abk_bezt (void *node, void *data) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ActBeztColumn *abk= (ActBeztColumn *)node; | 
					
						
							|  |  |  | 	BezTriple *bezt= (BezTriple *)data; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (bezt->vec[1][0] < abk->cfra) | 
					
						
							|  |  |  | 		return -1; | 
					
						
							|  |  |  | 	else if (bezt->vec[1][0] > abk->cfra) | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* New node callback used for building ActBeztColumns from BezTriples */ | 
					
						
							|  |  |  | static DLRBT_Node *nalloc_abk_bezt (void *data) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ActBeztColumn *abk= MEM_callocN(sizeof(ActBeztColumn), "ActKeyColumn"); | 
					
						
							|  |  |  | 	BezTriple *bezt= (BezTriple *)data; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* store the BeztTriple in the buffer, and keep track of its frame number */ | 
					
						
							|  |  |  | 	abk->cfra= bezt->vec[1][0]; | 
					
						
							|  |  |  | 	abk->bezts[abk->numBezts++]= bezt; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return (DLRBT_Node *)abk; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Node updater callback used for building ActBeztColumns from BezTriples */ | 
					
						
							|  |  |  | static void nupdate_abk_bezt (void *node, void *data) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ActBeztColumn *abk= (ActBeztColumn *)node; | 
					
						
							|  |  |  | 	BezTriple *bezt= (BezTriple *)data; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* just add the BezTriple to the buffer if there's space, or allocate a new one */ | 
					
						
							| 
									
										
										
										
											2009-12-11 11:18:55 +00:00
										 |  |  | 	if (abk->numBezts >= MAX_ABK_BUFSIZE) { | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | 		// TODO: need to allocate new array to cater...
 | 
					
						
							|  |  |  | 		//bezts_extra= MEM_callocN(...);
 | 
					
						
							| 
									
										
										
										
											2009-12-08 16:39:00 +00:00
										 |  |  | 		if(G.f & G_DEBUG) | 
					
						
							|  |  |  | 			printf("FIXME: nupdate_abk_bezt() missing case for too many overlapping BezTriples \n"); | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* just store an extra one */ | 
					
						
							|  |  |  | 		abk->bezts[abk->numBezts++]= bezt; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* --------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Return the BezTriple in the given ActBeztColumn that matches the requested value */ | 
					
						
							|  |  |  | static BezTriple *abk_get_bezt_with_value (ActBeztColumn *abk, float value) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	BezTriple *bezt; | 
					
						
							|  |  |  | 	int i; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* sanity checks */ | 
					
						
							|  |  |  | 	if (abk == NULL) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* look over each BezTriple in this container */ | 
					
						
							|  |  |  | 	for (i = 0; i < abk->numBezts; i++) {		 | 
					
						
							|  |  |  | 		/* only do exact match for now... */ | 
					
						
							|  |  |  | 		if (i >= sizeof(abk->bezts)/sizeof(BezTriple)) { | 
					
						
							|  |  |  | 			// TODO: this case needs special handling
 | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			/* just use the default buffer */ | 
					
						
							|  |  |  | 			bezt= abk->bezts[i]; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if (bezt->vec[1][1] == value) | 
					
						
							|  |  |  | 				return bezt; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ActKeyBlocks (Long Keyframes) ------------------------------------------ */ | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* Create a ActKeyColumn for a pair of BezTriples */ | 
					
						
							|  |  |  | static ActKeyBlock *bezts_to_new_actkeyblock(BezTriple *prev, BezTriple *beztn) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ActKeyBlock *ab= MEM_callocN(sizeof(ActKeyBlock), "ActKeyBlock"); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	ab->start= prev->vec[1][0]; | 
					
						
							|  |  |  | 	ab->end= beztn->vec[1][0]; | 
					
						
							|  |  |  | 	ab->val= beztn->vec[1][1]; | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	ab->sel= (BEZSELECTED(prev) || BEZSELECTED(beztn)) ? SELECT : 0; | 
					
						
							|  |  |  | 	ab->modified = 1; | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	return ab; | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | static void add_bezt_to_keyblocks_list(DLRBT_Tree *blocks, DLRBT_Tree *beztTree, BezTriple *beztn) | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	ActKeyBlock *new_ab= NULL; | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | 	ActBeztColumn *abk; | 
					
						
							|  |  |  | 	BezTriple *prev; | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | 	/* get the BezTriple immediately before the given one which has the same value */ | 
					
						
							|  |  |  | 		/* the keyframes immediately before the ones containing the specified keyframe */ | 
					
						
							|  |  |  | 	abk= (ActBeztColumn *)BLI_dlrbTree_search_prev(beztTree, compare_abk_bezt, beztn); | 
					
						
							|  |  |  | 		/* if applicable, the BezTriple with the same value */ | 
					
						
							|  |  |  | 	prev= (abk) ? abk_get_bezt_with_value(abk, beztn->vec[1][1]) : NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	/* check if block needed - same value(s)?
 | 
					
						
							|  |  |  | 	 *	-> firstly, handles must have same central value as each other | 
					
						
							|  |  |  | 	 *	-> secondly, handles which control that section of the curve must be constant | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	if ((!prev) || (!beztn)) return; | 
					
						
							|  |  |  | 	if (IS_EQ(beztn->vec[1][1], prev->vec[1][1])==0) return; | 
					
						
							|  |  |  | 	if (IS_EQ(beztn->vec[1][1], beztn->vec[0][1])==0) return; | 
					
						
							|  |  |  | 	if (IS_EQ(prev->vec[1][1], prev->vec[2][1])==0) return; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* if there are no blocks already, just add as root */ | 
					
						
							|  |  |  | 	if (blocks->root == NULL) { | 
					
						
							|  |  |  | 		/* just add this as the root, then call the tree-balancing functions to validate */ | 
					
						
							|  |  |  | 		new_ab= bezts_to_new_actkeyblock(prev, beztn); | 
					
						
							|  |  |  | 		blocks->root= (DLRBT_Node *)new_ab; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		ActKeyBlock *ab, *abp=NULL, *abn=NULL; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* try to find a keyblock that starts on the previous beztriple, and add a new one if none start there
 | 
					
						
							|  |  |  | 		 * Note: we can't search from end to try to optimise this as it causes errors there's | 
					
						
							|  |  |  | 		 * 		an A ___ B |---| B situation | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		// FIXME: here there is a bug where we are trying to get the summary for the following channels
 | 
					
						
							|  |  |  | 		//		A|--------------|A ______________ B|--------------|B
 | 
					
						
							|  |  |  | 		//		A|------------------------------------------------|A
 | 
					
						
							|  |  |  | 		//		A|----|A|---|A|-----------------------------------|A
 | 
					
						
							|  |  |  | 		for (ab= blocks->root; ab; abp= ab, ab= abn) { | 
					
						
							|  |  |  | 			/* check if this is a match, or whether we go left or right */ | 
					
						
							|  |  |  | 			if (ab->start == prev->vec[1][0]) { | 
					
						
							|  |  |  | 				/* set selection status and 'touched' status */ | 
					
						
							|  |  |  | 				if (BEZSELECTED(beztn)) ab->sel = SELECT; | 
					
						
							|  |  |  | 				ab->modified += 1; | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				/* done... no need to insert */ | 
					
						
							|  |  |  | 				return; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				ActKeyBlock **abnp= NULL;  | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 				/* check if go left or right, but if not available, add new node */ | 
					
						
							|  |  |  | 				if (ab->start < prev->vec[1][0])  | 
					
						
							|  |  |  | 					abnp= &ab->right; | 
					
						
							|  |  |  | 				else | 
					
						
							|  |  |  | 					abnp= &ab->left; | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 				/* if this does not exist, add a new node, otherwise continue... */ | 
					
						
							|  |  |  | 				if (*abnp == NULL) { | 
					
						
							|  |  |  | 					/* add a new node representing this, and attach it to the relevant place */ | 
					
						
							|  |  |  | 					new_ab= bezts_to_new_actkeyblock(prev, beztn); | 
					
						
							|  |  |  | 					new_ab->parent= ab; | 
					
						
							|  |  |  | 					*abnp= new_ab; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else | 
					
						
							|  |  |  | 					abn= *abnp; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	/* now, balance the tree taking into account this newly added node */ | 
					
						
							|  |  |  | 	BLI_dlrbTree_insert(blocks, (DLRBT_Node *)new_ab); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* --------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Handle the 'touched' status of ActKeyColumn tree nodes */ | 
					
						
							|  |  |  | static void set_touched_actkeycolumn (ActKeyColumn *ak) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* sanity check */ | 
					
						
							|  |  |  | 	if (ak == NULL) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* deal with self first */ | 
					
						
							|  |  |  | 	if (ak->modified) { | 
					
						
							|  |  |  | 		ak->modified= 0; | 
					
						
							|  |  |  | 		ak->totcurve++; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	/* children */ | 
					
						
							|  |  |  | 	set_touched_actkeycolumn(ak->left); | 
					
						
							|  |  |  | 	set_touched_actkeycolumn(ak->right); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Handle the 'touched' status of ActKeyBlock tree nodes */ | 
					
						
							|  |  |  | static void set_touched_actkeyblock (ActKeyBlock *ab) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* sanity check */ | 
					
						
							|  |  |  | 	if (ab == NULL) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 	/* deal with self first */ | 
					
						
							|  |  |  | 	if (ab->modified) { | 
					
						
							|  |  |  | 		ab->modified= 0; | 
					
						
							|  |  |  | 		ab->totcurve++; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	/* children */ | 
					
						
							|  |  |  | 	set_touched_actkeyblock(ab->left); | 
					
						
							|  |  |  | 	set_touched_actkeyblock(ab->right); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-17 00:17:37 +00:00
										 |  |  | /* *************************** Keyframe Drawing *************************** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | /* coordinates for diamond shape */ | 
					
						
							|  |  |  | static const float _unit_diamond_shape[4][2] = { | 
					
						
							|  |  |  | 	{0.0f, 1.0f},	/* top vert */ | 
					
						
							|  |  |  | 	{1.0f, 0.0f},	/* mid-right */ | 
					
						
							|  |  |  | 	{0.0f, -1.0f},	/* bottom vert */ | 
					
						
							|  |  |  | 	{-1.0f, 0.0f}	/* mid-left */ | 
					
						
							|  |  |  | };  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* draw a simple diamond shape with OpenGL */ | 
					
						
							| 
									
										
										
										
											2009-09-04 02:44:56 +00:00
										 |  |  | void draw_keyframe_shape (float x, float y, float xscale, float hsize, short sel, short key_type, short mode) | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | 	static GLuint displist1=0; | 
					
						
							|  |  |  | 	static GLuint displist2=0; | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | 	/* initialise 2 display lists for diamond shape - one empty, one filled */ | 
					
						
							|  |  |  | 	if (displist1 == 0) { | 
					
						
							|  |  |  | 		displist1= glGenLists(1); | 
					
						
							|  |  |  | 			glNewList(displist1, GL_COMPILE); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glBegin(GL_LINE_LOOP); | 
					
						
							|  |  |  | 				glVertex2fv(_unit_diamond_shape[0]); | 
					
						
							|  |  |  | 				glVertex2fv(_unit_diamond_shape[1]); | 
					
						
							|  |  |  | 				glVertex2fv(_unit_diamond_shape[2]); | 
					
						
							|  |  |  | 				glVertex2fv(_unit_diamond_shape[3]); | 
					
						
							|  |  |  | 			glEnd(); | 
					
						
							|  |  |  | 		glEndList(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (displist2 == 0) { | 
					
						
							|  |  |  | 		displist2= glGenLists(1); | 
					
						
							|  |  |  | 			glNewList(displist2, GL_COMPILE); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			glBegin(GL_QUADS); | 
					
						
							|  |  |  | 				glVertex2fv(_unit_diamond_shape[0]); | 
					
						
							|  |  |  | 				glVertex2fv(_unit_diamond_shape[1]); | 
					
						
							|  |  |  | 				glVertex2fv(_unit_diamond_shape[2]); | 
					
						
							|  |  |  | 				glVertex2fv(_unit_diamond_shape[3]); | 
					
						
							|  |  |  | 			glEnd(); | 
					
						
							|  |  |  | 		glEndList(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-09-04 02:44:56 +00:00
										 |  |  | 	/* tweak size of keyframe shape according to type of keyframe 
 | 
					
						
							|  |  |  | 	 * 	- 'proper' keyframes have key_type=0, so get drawn at full size | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	hsize -= 0.5f*key_type; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | 	/* adjust view transform before starting */ | 
					
						
							|  |  |  | 	glTranslatef(x, y, 0.0f); | 
					
						
							|  |  |  | 	glScalef(1.0f/xscale*hsize, hsize, 1.0f); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* anti-aliased lines for more consistent appearance */ | 
					
						
							|  |  |  | 	glEnable(GL_LINE_SMOOTH); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-10 00:32:13 +00:00
										 |  |  | 	/* draw! */ | 
					
						
							|  |  |  | 	if ELEM(mode, KEYFRAME_SHAPE_INSIDE, KEYFRAME_SHAPE_BOTH) { | 
					
						
							|  |  |  | 		/* interior - hardcoded colors (for selected and unselected only) */ | 
					
						
							| 
									
										
										
										
											2009-09-04 02:44:56 +00:00
										 |  |  | 		switch (key_type) { | 
					
						
							|  |  |  | 			case BEZT_KEYTYPE_BREAKDOWN: /* bluish frames for now */ | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				if (sel) glColor3f(0.33f, 0.75f, 0.93f); | 
					
						
							|  |  |  | 				else glColor3f(0.70f, 0.86f, 0.91f); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2009-09-21 12:29:53 +00:00
										 |  |  | 			case BEZT_KEYTYPE_EXTREME: /* redish frames for now */ | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				if (sel) glColor3f(95.0f, 0.5f, 0.5f); | 
					
						
							|  |  |  | 				else glColor3f(0.91f, 0.70f, 0.80f); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2009-09-04 02:44:56 +00:00
										 |  |  | 			case BEZT_KEYTYPE_KEYFRAME: /* traditional yellowish frames for now */ | 
					
						
							|  |  |  | 			default: | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				if (sel) UI_ThemeColorShade(TH_STRIP_SELECT, 50); | 
					
						
							|  |  |  | 				else glColor3f(0.91f, 0.91f, 0.91f); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-07-10 00:32:13 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		glCallList(displist2); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-10 00:32:13 +00:00
										 |  |  | 	if ELEM(mode, KEYFRAME_SHAPE_FRAME, KEYFRAME_SHAPE_BOTH) { | 
					
						
							|  |  |  | 		/* exterior - black frame */ | 
					
						
							|  |  |  | 		glColor3ub(0, 0, 0); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glCallList(displist1); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	glDisable(GL_LINE_SMOOTH); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | 	/* restore view transform */ | 
					
						
							|  |  |  | 	glScalef(xscale/hsize, 1.0f/hsize, 1.0); | 
					
						
							|  |  |  | 	glTranslatef(-x, -y, 0.0f); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | static void draw_keylist(View2D *v2d, DLRBT_Tree *keys, DLRBT_Tree *blocks, float ypos) | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	ActKeyColumn *ak; | 
					
						
							|  |  |  | 	ActKeyBlock *ab; | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | 	float xscale; | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	glEnable(GL_BLEND); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | 	/* get View2D scaling factor */ | 
					
						
							|  |  |  | 	UI_view2d_getscale(v2d, &xscale, NULL); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	/* draw keyblocks */ | 
					
						
							|  |  |  | 	if (blocks) { | 
					
						
							|  |  |  | 		for (ab= blocks->first; ab; ab= ab->next) { | 
					
						
							|  |  |  | 			short startCurves, endCurves, totCurves; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* find out how many curves occur at each keyframe */ | 
					
						
							| 
									
										
										
										
											2009-11-15 11:20:44 +00:00
										 |  |  | 			ak= (ActKeyColumn *)BLI_dlrbTree_search_exact(keys, compare_ak_cfraPtr, &ab->start); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 			startCurves = (ak)? ak->totcurve: 0; | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-11-15 11:20:44 +00:00
										 |  |  | 			ak= (ActKeyColumn *)BLI_dlrbTree_search_exact(keys, compare_ak_cfraPtr, &ab->end); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 			endCurves = (ak)? ak->totcurve: 0; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* only draw keyblock if it appears in at all of the keyframes at lowest end */ | 
					
						
							|  |  |  | 			if (!startCurves && !endCurves)  | 
					
						
							|  |  |  | 				continue; | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 				totCurves = (startCurves>endCurves)? endCurves: startCurves; | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 			if (ab->totcurve >= totCurves) { | 
					
						
							|  |  |  | 				/* draw block */ | 
					
						
							|  |  |  | 				if (ab->sel) | 
					
						
							|  |  |  | 					UI_ThemeColor4(TH_STRIP_SELECT); | 
					
						
							|  |  |  | 				else | 
					
						
							|  |  |  | 					UI_ThemeColor4(TH_STRIP); | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | 				 | 
					
						
							|  |  |  | 				glRectf(ab->start, ypos-5, ab->end, ypos+5); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* draw keys */ | 
					
						
							|  |  |  | 	if (keys) { | 
					
						
							|  |  |  | 		for (ak= keys->first; ak; ak= ak->next) { | 
					
						
							| 
									
										
										
										
											2009-07-20 12:42:31 +00:00
										 |  |  | 			/* optimisation: if keyframe doesn't appear within 5 units (screenspace) in visible area, don't draw 
 | 
					
						
							|  |  |  | 			 *	- this might give some improvements, since we current have to flip between view/region matrices | 
					
						
							|  |  |  | 			 */ | 
					
						
							|  |  |  | 			if (IN_RANGE_INCL(ak->cfra, v2d->cur.xmin, v2d->cur.xmax) == 0) | 
					
						
							|  |  |  | 				continue; | 
					
						
							|  |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | 			/* draw using OpenGL - uglier but faster */ | 
					
						
							| 
									
										
										
										
											2009-07-20 12:42:31 +00:00
										 |  |  | 			// NOTE1: a previous version of this didn't work nice for some intel cards
 | 
					
						
							|  |  |  | 			// NOTE2: if we wanted to go back to icons, these are  icon = (ak->sel & SELECT) ? ICON_SPACE2 : ICON_SPACE3;
 | 
					
						
							| 
									
										
										
										
											2009-09-04 02:44:56 +00:00
										 |  |  | 			draw_keyframe_shape(ak->cfra, ypos, xscale, 5.0f, (ak->sel & SELECT), ak->key_type, KEYFRAME_SHAPE_BOTH); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 		}	 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glDisable(GL_BLEND); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-22 10:15:02 +00:00
										 |  |  | /* *************************** Channel Drawing Funcs *************************** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-13 11:21:02 +00:00
										 |  |  | void draw_summary_channel(View2D *v2d, bAnimContext *ac, float ypos) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	DLRBT_Tree keys, blocks; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_init(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_init(&blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		summary_to_keylist(ac, &keys, &blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_linkedlist_sync(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_linkedlist_sync(&blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		draw_keylist(v2d, &keys, &blocks, ypos); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_free(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_free(&blocks); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | void draw_scene_channel(View2D *v2d, bDopeSheet *ads, Scene *sce, float ypos) | 
					
						
							| 
									
										
										
										
											2009-02-13 06:33:07 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	DLRBT_Tree keys, blocks; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_init(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_init(&blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		scene_to_keylist(ads, sce, &keys, &blocks); | 
					
						
							| 
									
										
										
										
											2009-02-13 06:33:07 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	BLI_dlrbTree_linkedlist_sync(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_linkedlist_sync(&blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		draw_keylist(v2d, &keys, &blocks, ypos); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_free(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_free(&blocks); | 
					
						
							| 
									
										
										
										
											2009-02-13 06:33:07 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | void draw_object_channel(View2D *v2d, bDopeSheet *ads, Object *ob, float ypos) | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	DLRBT_Tree keys, blocks; | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	BLI_dlrbTree_init(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_init(&blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		ob_to_keylist(ads, ob, &keys, &blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_linkedlist_sync(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_linkedlist_sync(&blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		draw_keylist(v2d, &keys, &blocks, ypos); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_free(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_free(&blocks); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | void draw_fcurve_channel(View2D *v2d, AnimData *adt, FCurve *fcu, float ypos) | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	DLRBT_Tree keys, blocks; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_init(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_init(&blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		fcurve_to_keylist(adt, fcu, &keys, &blocks); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	BLI_dlrbTree_linkedlist_sync(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_linkedlist_sync(&blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		draw_keylist(v2d, &keys, &blocks, ypos); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_free(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_free(&blocks); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | void draw_agroup_channel(View2D *v2d, AnimData *adt, bActionGroup *agrp, float ypos) | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	DLRBT_Tree keys, blocks; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_init(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_init(&blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		agroup_to_keylist(adt, agrp, &keys, &blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_linkedlist_sync(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_linkedlist_sync(&blocks); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 		draw_keylist(v2d, &keys, &blocks, ypos); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_free(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_free(&blocks); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | void draw_action_channel(View2D *v2d, AnimData *adt, bAction *act, float ypos) | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	DLRBT_Tree keys, blocks; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_init(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_init(&blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		action_to_keylist(adt, act, &keys, &blocks); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	BLI_dlrbTree_linkedlist_sync(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_linkedlist_sync(&blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		draw_keylist(v2d, &keys, &blocks, ypos); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_free(&keys); | 
					
						
							|  |  |  | 	BLI_dlrbTree_free(&blocks); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | void draw_gpl_channel(View2D *v2d, bDopeSheet *ads, bGPDlayer *gpl, float ypos) | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 	DLRBT_Tree keys; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_init(&keys); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 		gpl_to_keylist(ads, gpl, &keys, NULL); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_linkedlist_sync(&keys); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		draw_keylist(v2d, &keys, NULL, ypos); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BLI_dlrbTree_free(&keys); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-22 10:15:02 +00:00
										 |  |  | /* *************************** Keyframe List Conversions *************************** */ | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-13 11:21:02 +00:00
										 |  |  | void summary_to_keylist(bAnimContext *ac, DLRBT_Tree *keys, DLRBT_Tree *blocks) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (ac) { | 
					
						
							|  |  |  | 		ListBase anim_data = {NULL, NULL}; | 
					
						
							|  |  |  | 		bAnimListElem *ale; | 
					
						
							|  |  |  | 		int filter; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* get F-Curves to take keyframes from */ | 
					
						
							|  |  |  | 		filter= (ANIMFILTER_VISIBLE | ANIMFILTER_CURVESONLY); | 
					
						
							|  |  |  | 		ANIM_animdata_filter(ac, &anim_data, filter, ac->data, ac->datatype); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* loop through each F-Curve, grabbing the keyframes */ | 
					
						
							|  |  |  | 		for (ale= anim_data.first; ale; ale= ale->next) | 
					
						
							|  |  |  | 			fcurve_to_keylist(ale->adt, ale->data, keys, blocks); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		BLI_freelistN(&anim_data); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | void scene_to_keylist(bDopeSheet *ads, Scene *sce, DLRBT_Tree *keys, DLRBT_Tree *blocks) | 
					
						
							| 
									
										
										
										
											2009-02-13 06:33:07 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	if (sce) { | 
					
						
							|  |  |  | 		AnimData *adt; | 
					
						
							|  |  |  | 		int filterflag; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* get filterflag */ | 
					
						
							|  |  |  | 		if (ads) | 
					
						
							|  |  |  | 			filterflag= ads->filterflag; | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			filterflag= 0; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 		/* scene animdata */ | 
					
						
							|  |  |  | 		if ((sce->adt) && !(filterflag & ADS_FILTER_NOSCE)) { | 
					
						
							|  |  |  | 			adt= sce->adt; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if (adt->action)  | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | 				action_to_keylist(adt, adt->action, keys, blocks); | 
					
						
							| 
									
										
										
										
											2009-02-13 06:33:07 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* world animdata */ | 
					
						
							|  |  |  | 		if ((sce->world) && (sce->world->adt) && !(filterflag & ADS_FILTER_NOWOR)) { | 
					
						
							|  |  |  | 			adt= sce->world->adt; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if (adt->action)  | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | 				action_to_keylist(adt, adt->action, keys, blocks); | 
					
						
							| 
									
										
										
										
											2009-02-13 06:33:07 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-11-11 05:03:49 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* nodetree animdata */ | 
					
						
							|  |  |  | 		if ((sce->nodetree) && (sce->nodetree->adt) && !(filterflag & ADS_FILTER_NONTREE)) { | 
					
						
							|  |  |  | 			adt= sce->nodetree->adt; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if (adt->action)  | 
					
						
							|  |  |  | 				action_to_keylist(adt, adt->action, keys, blocks); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-02-13 06:33:07 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | void ob_to_keylist(bDopeSheet *ads, Object *ob, DLRBT_Tree *keys, DLRBT_Tree *blocks) | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-02-13 06:33:07 +00:00
										 |  |  | 	Key *key= ob_get_key(ob); | 
					
						
							| 
									
										
										
										
											2009-10-06 03:05:20 +00:00
										 |  |  | 	int filterflag= (ads)? ads->filterflag : 0; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* sanity check */ | 
					
						
							|  |  |  | 	if (ob == NULL) | 
					
						
							|  |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-10-06 03:05:20 +00:00
										 |  |  | 	/* Add action keyframes */ | 
					
						
							|  |  |  | 	if (ob->adt && ob->adt->action) | 
					
						
							|  |  |  | 		action_to_keylist(ob->adt, ob->adt->action, keys, blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* Add shapekey keyframes (only if dopesheet allows, if it is available) */ | 
					
						
							|  |  |  | 	if ((key && key->adt && key->adt->action) && !(filterflag & ADS_FILTER_NOSHAPEKEYS)) | 
					
						
							|  |  |  | 		action_to_keylist(key->adt, key->adt->action, keys, blocks); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* Add material keyframes */ | 
					
						
							|  |  |  | 	if ((ob->totcol) && !(filterflag & ADS_FILTER_NOMAT)) { | 
					
						
							|  |  |  | 		int a; | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-10-06 03:05:20 +00:00
										 |  |  | 		for (a=0; a < ob->totcol; a++) { | 
					
						
							|  |  |  | 			Material *ma= give_current_material(ob, a); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* there might not be a material */ | 
					
						
							|  |  |  | 			if (ELEM(NULL, ma, ma->adt))  | 
					
						
							|  |  |  | 				continue; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* add material's data */ | 
					
						
							|  |  |  | 			action_to_keylist(ma->adt, ma->adt->action, keys, blocks); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* Add object data keyframes */ | 
					
						
							|  |  |  | 	switch (ob->type) { | 
					
						
							|  |  |  | 		case OB_CAMERA: /* ------- Camera ------------ */ | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			Camera *ca= (Camera *)ob->data; | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-10-06 03:05:20 +00:00
										 |  |  | 			if ((ca->adt) && !(filterflag & ADS_FILTER_NOCAM))  | 
					
						
							|  |  |  | 				action_to_keylist(ca->adt, ca->adt->action, keys, blocks); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case OB_LAMP: /* ---------- Lamp ----------- */ | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			Lamp *la= (Lamp *)ob->data; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if ((la->adt) && !(filterflag & ADS_FILTER_NOLAM))  | 
					
						
							|  |  |  | 				action_to_keylist(la->adt, la->adt->action, keys, blocks); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case OB_CURVE: /* ------- Curve ---------- */ | 
					
						
							| 
									
										
										
										
											2009-12-27 23:37:13 +00:00
										 |  |  | 		case OB_SURF: /* ------- Nurbs Surface ---------- */ | 
					
						
							|  |  |  | 		case OB_FONT: /* ------- Text Curve ---------- */ | 
					
						
							| 
									
										
										
										
											2009-10-06 03:05:20 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			Curve *cu= (Curve *)ob->data; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if ((cu->adt) && !(filterflag & ADS_FILTER_NOCUR))  | 
					
						
							|  |  |  | 				action_to_keylist(cu->adt, cu->adt->action, keys, blocks); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case OB_MBALL: /* ------- MetaBall ---------- */ | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			MetaBall *mb= (MetaBall *)ob->data; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if ((mb->adt) && !(filterflag & ADS_FILTER_NOMBA))  | 
					
						
							|  |  |  | 				action_to_keylist(mb->adt, mb->adt->action, keys, blocks); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case OB_ARMATURE: /* ------- Armature ---------- */ | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			bArmature *arm= (bArmature *)ob->data; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if ((arm->adt) && !(filterflag & ADS_FILTER_NOARM))  | 
					
						
							|  |  |  | 				action_to_keylist(arm->adt, arm->adt->action, keys, blocks); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* Add Particle System Keyframes */ | 
					
						
							|  |  |  | 	if ((ob->particlesystem.first) && !(filterflag & ADS_FILTER_NOPART)) { | 
					
						
							|  |  |  | 		ParticleSystem *psys = ob->particlesystem.first; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		for(; psys; psys=psys->next) { | 
					
						
							|  |  |  | 			if (ELEM(NULL, psys->part, psys->part->adt)) | 
					
						
							|  |  |  | 				continue; | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 				action_to_keylist(psys->part->adt, psys->part->adt->action, keys, blocks); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | void fcurve_to_keylist(AnimData *adt, FCurve *fcu, DLRBT_Tree *keys, DLRBT_Tree *blocks) | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | 	DLRBT_Tree *beztTree = NULL; | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	BezTriple *bezt; | 
					
						
							|  |  |  | 	int v; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-03-02 00:55:10 +00:00
										 |  |  | 	if (fcu && fcu->totvert && fcu->bezt) { | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | 		/* apply NLA-mapping (if applicable) */ | 
					
						
							|  |  |  | 		if (adt)	 | 
					
						
							|  |  |  | 			ANIM_nla_mapping_apply_fcurve(adt, fcu, 0, 1); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | 		/* if getting long keyframes too, grab the BezTriples in a BST for 
 | 
					
						
							|  |  |  | 		 * accelerated searching... | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		if (blocks) { | 
					
						
							|  |  |  | 			/* init new tree */ | 
					
						
							|  |  |  | 			beztTree= BLI_dlrbTree_new(); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* populate tree with the BezTriples */ | 
					
						
							|  |  |  | 			for (v=0, bezt=fcu->bezt; v < fcu->totvert; v++, bezt++) | 
					
						
							|  |  |  | 				BLI_dlrbTree_add(beztTree, compare_abk_bezt, nalloc_abk_bezt, nupdate_abk_bezt, bezt); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* make sure that it is suitable for linked-list searching too */ | 
					
						
							|  |  |  | 			BLI_dlrbTree_linkedlist_sync(beztTree); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | 		/* loop through beztriples, making ActKeysColumns and ActKeyBlocks */ | 
					
						
							|  |  |  | 		for (v=0, bezt=fcu->bezt; v < fcu->totvert; v++, bezt++) { | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 			add_bezt_to_keycolumns_list(keys, bezt); | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | 			if (blocks) add_bezt_to_keyblocks_list(blocks, beztTree, bezt); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* update the number of curves that elements have appeared in  */ | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 		if (keys) | 
					
						
							|  |  |  | 			set_touched_actkeycolumn(keys->root); | 
					
						
							|  |  |  | 		if (blocks) | 
					
						
							|  |  |  | 			set_touched_actkeyblock(blocks->root); | 
					
						
							| 
									
										
										
										
											2009-11-17 08:27:46 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 		/* free temp data for building long keyframes */ | 
					
						
							|  |  |  | 		if (blocks && beztTree) { | 
					
						
							|  |  |  | 			BLI_dlrbTree_free(beztTree); | 
					
						
							|  |  |  | 			MEM_freeN(beztTree); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* unapply NLA-mapping if applicable */ | 
					
						
							|  |  |  | 		ANIM_nla_mapping_apply_fcurve(adt, fcu, 1, 1); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | void agroup_to_keylist(AnimData *adt, bActionGroup *agrp, DLRBT_Tree *keys, DLRBT_Tree *blocks) | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-20 11:07:42 +00:00
										 |  |  | 	FCurve *fcu; | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (agrp) { | 
					
						
							| 
									
										
										
										
											2009-01-20 11:07:42 +00:00
										 |  |  | 		/* loop through F-Curves */ | 
					
						
							|  |  |  | 		for (fcu= agrp->channels.first; fcu && fcu->grp==agrp; fcu= fcu->next) { | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | 			fcurve_to_keylist(adt, fcu, keys, blocks); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | void action_to_keylist(AnimData *adt, bAction *act, DLRBT_Tree *keys, DLRBT_Tree *blocks) | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-20 11:07:42 +00:00
										 |  |  | 	FCurve *fcu; | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (act) { | 
					
						
							| 
									
										
										
										
											2009-01-20 11:07:42 +00:00
										 |  |  | 		/* loop through F-Curves */ | 
					
						
							|  |  |  | 		for (fcu= act->curves.first; fcu; fcu= fcu->next) { | 
					
						
							| 
									
										
										
										
											2009-07-09 13:14:51 +00:00
										 |  |  | 			fcurve_to_keylist(adt, fcu, keys, blocks); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | void gpl_to_keylist(bDopeSheet *ads, bGPDlayer *gpl, DLRBT_Tree *keys, DLRBT_Tree *blocks) | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	bGPDframe *gpf; | 
					
						
							|  |  |  | 	ActKeyColumn *ak; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (gpl && keys) { | 
					
						
							|  |  |  | 		/* loop over frames, converting directly to 'keyframes' (should be in order too) */ | 
					
						
							|  |  |  | 		for (gpf= gpl->frames.first; gpf; gpf= gpf->next) { | 
					
						
							|  |  |  | 			ak= MEM_callocN(sizeof(ActKeyColumn), "ActKeyColumn"); | 
					
						
							| 
									
										
										
										
											2009-07-18 07:11:37 +00:00
										 |  |  | 			BLI_addtail((ListBase *)keys, ak); | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			ak->cfra= (float)gpf->framenum; | 
					
						
							|  |  |  | 			ak->modified = 1; | 
					
						
							| 
									
										
										
										
											2009-09-04 02:44:56 +00:00
										 |  |  | 			ak->key_type= 0;  | 
					
						
							| 
									
										
										
										
											2008-12-22 08:13:25 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			if (gpf->flag & GP_FRAME_SELECT) | 
					
						
							|  |  |  | 				ak->sel = SELECT; | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 				ak->sel = 0; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 |