| 
									
										
										
										
											2011-02-23 10:52:22 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +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-01-12 19:02:08 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Contributor(s):  | 
					
						
							|  |  |  |  * - Blender Foundation, 2003-2009 | 
					
						
							|  |  |  |  * - Peter Schlaile <peter [at] schlaile [dot] de> 2005/2006 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-27 20:40:57 +00:00
										 |  |  | /** \file blender/blenkernel/intern/sequencer.c
 | 
					
						
							|  |  |  |  *  \ingroup bke | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-19 03:21:37 +00:00
										 |  |  | #include <stddef.h>
 | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | #include <stdlib.h>
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | #include <math.h>
 | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "MEM_guardedalloc.h"
 | 
					
						
							| 
									
										
										
										
											2009-08-02 23:02:59 +00:00
										 |  |  | #include "MEM_CacheLimiterC-Api.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "DNA_sequence_types.h"
 | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | #include "DNA_movieclip_types.h"
 | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | #include "DNA_mask_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | #include "DNA_scene_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-22 20:22:35 +00:00
										 |  |  | #include "DNA_anim_types.h"
 | 
					
						
							| 
									
										
										
										
											2010-03-08 21:33:51 +00:00
										 |  |  | #include "DNA_object_types.h"
 | 
					
						
							| 
									
										
										
										
											2010-08-04 04:01:27 +00:00
										 |  |  | #include "DNA_sound_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-07 18:36:47 +00:00
										 |  |  | #include "BLI_math.h"
 | 
					
						
							|  |  |  | #include "BLI_fileops.h"
 | 
					
						
							|  |  |  | #include "BLI_listbase.h"
 | 
					
						
							|  |  |  | #include "BLI_path_util.h"
 | 
					
						
							|  |  |  | #include "BLI_string.h"
 | 
					
						
							|  |  |  | #include "BLI_threads.h"
 | 
					
						
							|  |  |  | #include "BLI_utildefines.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-07 16:17:18 +00:00
										 |  |  | #include "BKE_animsys.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | #include "BKE_global.h"
 | 
					
						
							|  |  |  | #include "BKE_image.h"
 | 
					
						
							|  |  |  | #include "BKE_main.h"
 | 
					
						
							| 
									
										
										
										
											2009-12-13 14:56:45 +00:00
										 |  |  | #include "BKE_sequencer.h"
 | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | #include "BKE_movieclip.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-22 20:22:35 +00:00
										 |  |  | #include "BKE_fcurve.h"
 | 
					
						
							| 
									
										
										
										
											2010-03-08 21:33:51 +00:00
										 |  |  | #include "BKE_scene.h"
 | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | #include "BKE_mask.h"
 | 
					
						
							| 
									
										
										
										
											2011-01-07 19:18:31 +00:00
										 |  |  | #include "BKE_utildefines.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-22 01:53:35 +00:00
										 |  |  | #include "RNA_access.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-22 20:49:13 +00:00
										 |  |  | #include "RE_pipeline.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-13 17:46:30 +00:00
										 |  |  | #include <pthread.h>
 | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "IMB_imbuf.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | #include "IMB_imbuf_types.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-09 21:16:39 +00:00
										 |  |  | #include "BKE_context.h"
 | 
					
						
							|  |  |  | #include "BKE_sound.h"
 | 
					
						
							| 
									
										
										
										
											2011-06-23 09:27:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef WITH_AUDASPACE
 | 
					
						
							|  |  |  | #  include "AUD_C-API.h"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-08-09 21:16:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static ImBuf *seq_render_strip_stack( | 
					
						
							|  |  |  |         SeqRenderData context, ListBase *seqbasep, float cfra, int chanshown); | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static ImBuf *seq_render_strip( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:35:12 +00:00
										 |  |  |         SeqRenderData context, Sequence *seq, float cfra); | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static void seq_free_animdata(Scene *scene, Sequence *seq); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* **** XXX ******** */ | 
					
						
							| 
									
										
										
										
											2009-12-17 23:29:11 +00:00
										 |  |  | #define SELECT 1
 | 
					
						
							| 
									
										
										
										
											2009-12-17 16:28:45 +00:00
										 |  |  | ListBase seqbase_clipboard; | 
					
						
							|  |  |  | int seqbase_clipboard_frame; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | SequencerDrawView sequencer_view3d_cb = NULL; /* NULL in background mode */ | 
					
						
							| 
									
										
										
										
											2010-03-08 20:08:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-19 10:07:19 +00:00
										 |  |  | void printf_strip(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	fprintf(stderr, "name: '%s', len:%d, start:%d, (startofs:%d, endofs:%d), (startstill:%d, endstill:%d), machine:%d, (startdisp:%d, enddisp:%d)\n", | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	        seq->name, seq->len, seq->start, seq->startofs, seq->endofs, seq->startstill, seq->endstill, seq->machine, seq->startdisp, seq->enddisp); | 
					
						
							| 
									
										
										
										
											2009-10-19 10:07:19 +00:00
										 |  |  | 	fprintf(stderr, "\tseq_tx_set_final_left: %d %d\n\n", seq_tx_get_final_left(seq, 0), seq_tx_get_final_right(seq, 0)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-06 16:44:05 +00:00
										 |  |  | int seqbase_recursive_apply(ListBase *seqbase, int (*apply_func)(Sequence *seq, void *), void *arg) | 
					
						
							| 
									
										
										
										
											2009-12-18 13:28:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Sequence *iseq; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (iseq = seqbase->first; iseq; iseq = iseq->next) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq_recursive_apply(iseq, apply_func, arg) == -1) | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			return -1;  /* bail out */ | 
					
						
							| 
									
										
										
										
											2009-12-18 13:28:03 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-06 16:44:05 +00:00
										 |  |  | 	return 1; | 
					
						
							| 
									
										
										
										
											2009-12-18 13:28:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-06 16:44:05 +00:00
										 |  |  | int seq_recursive_apply(Sequence *seq, int (*apply_func)(Sequence *, void *), void *arg) | 
					
						
							| 
									
										
										
										
											2009-12-18 13:28:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	int ret = apply_func(seq, arg); | 
					
						
							| 
									
										
										
										
											2010-07-06 16:44:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (ret == -1) | 
					
						
							| 
									
										
										
										
											2010-07-06 16:44:05 +00:00
										 |  |  | 		return -1;  /* bail out */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (ret && seq->seqbase.first) | 
					
						
							| 
									
										
										
										
											2010-07-06 16:44:05 +00:00
										 |  |  | 		ret = seqbase_recursive_apply(&seq->seqbase, apply_func, arg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return ret; | 
					
						
							| 
									
										
										
										
											2009-12-18 13:28:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | /* **********************************************************************
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  |  * alloc / free functions | 
					
						
							|  |  |  |  * ********************************************************************** */ | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* free */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-14 16:52:06 +00:00
										 |  |  | static void free_proxy_seq(Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	if (seq->strip && seq->strip->proxy && seq->strip->proxy->anim) { | 
					
						
							|  |  |  | 		IMB_free_anim(seq->strip->proxy->anim); | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 		seq->strip->proxy->anim = NULL; | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | void seq_free_strip(Strip *strip) | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	strip->us--; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (strip->us > 0) return; | 
					
						
							|  |  |  | 	if (strip->us < 0) { | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 		printf("error: negative users in strip\n"); | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (strip->stripdata) { | 
					
						
							|  |  |  | 		MEM_freeN(strip->stripdata); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (strip->proxy) { | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 		if (strip->proxy->anim) { | 
					
						
							|  |  |  | 			IMB_free_anim(strip->proxy->anim); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 		MEM_freeN(strip->proxy); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (strip->crop) { | 
					
						
							|  |  |  | 		MEM_freeN(strip->crop); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (strip->transform) { | 
					
						
							|  |  |  | 		MEM_freeN(strip->transform); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (strip->color_balance) { | 
					
						
							|  |  |  | 		MEM_freeN(strip->color_balance); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	MEM_freeN(strip); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-09 21:16:39 +00:00
										 |  |  | void seq_free_sequence(Scene *scene, Sequence *seq) | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->strip) seq_free_strip(seq->strip); | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->anim) IMB_free_anim(seq->anim); | 
					
						
							| 
									
										
										
										
											2009-08-09 21:16:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (seq->type & SEQ_TYPE_EFFECT) { | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 		struct SeqEffectHandle sh = get_sequence_effect(seq); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		sh.free(seq); | 
					
						
							| 
									
										
										
										
											2009-07-08 17:41:45 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->sound) { | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 		((ID *)seq->sound)->us--;  | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-17 16:28:45 +00:00
										 |  |  | 	/* clipboard has no scene and will never have a sound handle or be active */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (scene) { | 
					
						
							| 
									
										
										
										
											2009-12-17 16:28:45 +00:00
										 |  |  | 		Editing *ed = scene->ed; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		if (ed->act_seq == seq) | 
					
						
							|  |  |  | 			ed->act_seq = NULL; | 
					
						
							| 
									
										
										
										
											2009-12-17 16:28:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		if (seq->scene_sound && ELEM(seq->type, SEQ_TYPE_SOUND_RAM, SEQ_TYPE_SCENE)) | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 			sound_remove_scene_sound(scene, seq->scene_sound); | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-13 09:31:28 +00:00
										 |  |  | 		seq_free_animdata(scene, seq); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-03 21:13:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 	MEM_freeN(seq); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | void seq_free_sequence_recurse(Scene *scene, Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Sequence *iseq; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (iseq = seq->seqbase.first; iseq; iseq = iseq->next) { | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 		seq_free_sequence_recurse(scene, iseq); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	seq_free_sequence(scene, seq); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | Editing *BKE_sequencer_editing_get(Scene *scene, int alloc) | 
					
						
							| 
									
										
										
										
											2009-01-28 22:36:34 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | 	if (alloc) { | 
					
						
							|  |  |  | 		BKE_sequencer_editing_ensure(scene); | 
					
						
							| 
									
										
										
										
											2009-01-28 22:36:34 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	return scene->ed; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-01 09:00:16 +00:00
										 |  |  | static void seq_free_clipboard_recursive(Sequence *seq_parent) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Sequence *seq, *nseq; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = seq_parent->seqbase.first; seq; seq = nseq) { | 
					
						
							|  |  |  | 		nseq = seq->next; | 
					
						
							| 
									
										
										
										
											2011-04-01 09:00:16 +00:00
										 |  |  | 		seq_free_clipboard_recursive(seq); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	seq_free_sequence(NULL, seq_parent); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-17 16:28:45 +00:00
										 |  |  | void seq_free_clipboard(void) | 
					
						
							| 
									
										
										
										
											2009-12-17 14:45:47 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Sequence *seq, *nseq; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = seqbase_clipboard.first; seq; seq = nseq) { | 
					
						
							|  |  |  | 		nseq = seq->next; | 
					
						
							| 
									
										
										
										
											2011-04-01 09:00:16 +00:00
										 |  |  | 		seq_free_clipboard_recursive(seq); | 
					
						
							| 
									
										
										
										
											2009-12-17 14:45:47 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seqbase_clipboard.first = seqbase_clipboard.last = NULL; | 
					
						
							| 
									
										
										
										
											2009-12-17 14:45:47 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | Editing *BKE_sequencer_editing_ensure(Scene *scene) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (scene->ed == NULL) { | 
					
						
							|  |  |  | 		Editing *ed; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		ed = scene->ed = MEM_callocN(sizeof(Editing), "addseq"); | 
					
						
							|  |  |  | 		ed->seqbasep = &ed->seqbase; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return scene->ed; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void BKE_sequencer_editing_free(Scene *scene) | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-08-09 21:16:39 +00:00
										 |  |  | 	Editing *ed = scene->ed; | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 	MetaStack *ms; | 
					
						
							| 
									
										
										
										
											2009-12-18 13:28:03 +00:00
										 |  |  | 	Sequence *seq; | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (ed == NULL) | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-30 16:22:40 +00:00
										 |  |  | 	SEQ_BEGIN (ed, seq) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2009-08-09 21:16:39 +00:00
										 |  |  | 		seq_free_sequence(scene, seq); | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	SEQ_END | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	while ((ms = ed->metastack.first)) { | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 		BLI_remlink(&ed->metastack, ms); | 
					
						
							|  |  |  | 		MEM_freeN(ms); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	MEM_freeN(ed); | 
					
						
							| 
									
										
										
										
											2012-05-11 14:27:55 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	scene->ed = NULL; | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | /* **********************************************************************
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  |  * sequencer pipeline functions | 
					
						
							|  |  |  |  * ********************************************************************** */ | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | SeqRenderData seq_new_render_data( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  |         struct Main *bmain, struct Scene *scene, | 
					
						
							|  |  |  |         int rectx, int recty, int preview_render_size) | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	SeqRenderData rval; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	rval.bmain = bmain; | 
					
						
							|  |  |  | 	rval.scene = scene; | 
					
						
							|  |  |  | 	rval.rectx = rectx; | 
					
						
							|  |  |  | 	rval.recty = recty; | 
					
						
							|  |  |  | 	rval.preview_render_size = preview_render_size; | 
					
						
							|  |  |  | 	rval.motion_blur_samples = 0; | 
					
						
							|  |  |  | 	rval.motion_blur_shutter = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return rval; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | int seq_cmp_render_data(const SeqRenderData *a, const SeqRenderData *b) | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	if (a->preview_render_size < b->preview_render_size) { | 
					
						
							|  |  |  | 		return -1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (a->preview_render_size > b->preview_render_size) { | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (a->rectx < b->rectx) { | 
					
						
							|  |  |  | 		return -1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (a->rectx > b->rectx) { | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (a->recty < b->recty) { | 
					
						
							|  |  |  | 		return -1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (a->recty > b->recty) { | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (a->bmain < b->bmain) { | 
					
						
							|  |  |  | 		return -1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (a->bmain > b->bmain) { | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (a->scene < b->scene) { | 
					
						
							|  |  |  | 		return -1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (a->scene > b->scene) { | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (a->motion_blur_shutter < b->motion_blur_shutter) { | 
					
						
							|  |  |  | 		return -1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (a->motion_blur_shutter > b->motion_blur_shutter) { | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (a->motion_blur_samples < b->motion_blur_samples) { | 
					
						
							|  |  |  | 		return -1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (a->motion_blur_samples > b->motion_blur_samples) { | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | unsigned int seq_hash_render_data(const SeqRenderData *a) | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	unsigned int rval = a->rectx + a->recty; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	rval ^= a->preview_render_size; | 
					
						
							|  |  |  | 	rval ^= ((intptr_t) a->bmain) << 6; | 
					
						
							|  |  |  | 	rval ^= ((intptr_t) a->scene) << 6; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:35:12 +00:00
										 |  |  | 	rval ^= (int)(a->motion_blur_shutter * 100.0f) << 10; | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	rval ^= a->motion_blur_samples << 24; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return rval; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-02 19:00:32 +00:00
										 |  |  | /* ************************* iterator ************************** */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | /* *************** (replaces old WHILE_SEQ) ********************* */ | 
					
						
							| 
									
										
										
										
											2012-04-28 15:14:16 +00:00
										 |  |  | /* **************** use now SEQ_BEGIN () SEQ_END ***************** */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | /* sequence strip iterator:
 | 
					
						
							|  |  |  |  * - builds a full array, recursively into meta strips */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void seq_count(ListBase *seqbase, int *tot) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = seqbase->first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 		(*tot)++; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->seqbase.first) | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 			seq_count(&seq->seqbase, tot); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void seq_build_array(ListBase *seqbase, Sequence ***array, int depth) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = seqbase->first; seq; seq = seq->next) { | 
					
						
							|  |  |  | 		seq->depth = depth; | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->seqbase.first) | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			seq_build_array(&seq->seqbase, array, depth + 1); | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		**array = seq; | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 		(*array)++; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | void seq_array(Editing *ed, Sequence ***seqarray, int *tot, int use_pointer) | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Sequence **array; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	*seqarray = NULL; | 
					
						
							|  |  |  | 	*tot = 0; | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (ed == NULL) | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (use_pointer) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		seq_count(ed->seqbasep, tot); | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		seq_count(&ed->seqbase, tot); | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (*tot == 0) | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	*seqarray = array = MEM_mallocN(sizeof(Sequence *) * (*tot), "SeqArray"); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (use_pointer) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		seq_build_array(ed->seqbasep, &array, 0); | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		seq_build_array(&ed->seqbase, &array, 0); | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | void seq_begin(Editing *ed, SeqIterator *iter, int use_pointer) | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	memset(iter, 0, sizeof(*iter)); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	seq_array(ed, &iter->array, &iter->tot, use_pointer); | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (iter->tot) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		iter->cur = 0; | 
					
						
							|  |  |  | 		iter->seq = iter->array[iter->cur]; | 
					
						
							|  |  |  | 		iter->valid = 1; | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void seq_next(SeqIterator *iter) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (++iter->cur < iter->tot) | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		iter->seq = iter->array[iter->cur]; | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		iter->valid = 0; | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void seq_end(SeqIterator *iter) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (iter->array) | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | 		MEM_freeN(iter->array); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	iter->valid = 0; | 
					
						
							| 
									
										
										
										
											2008-12-15 05:21:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  |  * ********************************************************************** | 
					
						
							|  |  |  |  * build_seqar | 
					
						
							|  |  |  |  * ********************************************************************* | 
					
						
							|  |  |  |  * Build a complete array of _all_ sequencies (including those | 
					
						
							|  |  |  |  * in metastrips!) | 
					
						
							|  |  |  |  * ********************************************************************* | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static void do_seq_count_cb(ListBase *seqbase, int *totseq, | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  |                             int (*test_func)(Sequence *seq)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seq = seqbase->first; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (seq) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		int test = test_func(seq); | 
					
						
							|  |  |  | 		if (test & BUILD_SEQAR_COUNT_CURRENT) { | 
					
						
							|  |  |  | 			(*totseq)++; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->seqbase.first && (test & BUILD_SEQAR_COUNT_CHILDREN)) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			do_seq_count_cb(&seq->seqbase, totseq, test_func); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		seq = seq->next; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void do_build_seqar_cb(ListBase *seqbase, Sequence ***seqar, int depth, | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  |                               int (*test_func)(Sequence *seq)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seq = seqbase->first; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (seq) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		int test = test_func(seq); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		seq->depth = depth; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->seqbase.first && (test & BUILD_SEQAR_COUNT_CHILDREN)) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			do_build_seqar_cb(&seq->seqbase, seqar, depth + 1, test_func); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		if (test & BUILD_SEQAR_COUNT_CURRENT) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			**seqar = seq; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			(*seqar)++; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		seq = seq->next; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void build_seqar_cb(ListBase *seqbase, Sequence  ***seqar, int *totseq, | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  |                     int (*test_func)(Sequence *seq)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Sequence **tseqar; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	*totseq = 0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	do_seq_count_cb(seqbase, totseq, test_func); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (*totseq == 0) { | 
					
						
							|  |  |  | 		*seqar = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	*seqar = MEM_mallocN(sizeof(void *) * *totseq, "seqar"); | 
					
						
							|  |  |  | 	tseqar = *seqar; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	do_build_seqar_cb(seqbase, seqar, 0, test_func); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	*seqar = tseqar; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 13:16:29 +00:00
										 |  |  | static int metaseq_start(Sequence *metaseq) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return metaseq->start + metaseq->startofs; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 13:16:29 +00:00
										 |  |  | static int metaseq_end(Sequence *metaseq) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return metaseq->start + metaseq->len - metaseq->endofs; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void seq_update_sound_bounds_recursive_rec(Scene *scene, Sequence *metaseq, int start, int end) | 
					
						
							| 
									
										
										
										
											2012-02-13 17:31:33 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-13 20:54:36 +00:00
										 |  |  | 	Sequence *seq; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* for sound we go over full meta tree to update bounds of the sound strips,
 | 
					
						
							|  |  |  | 	 * since sound is played outside of evaluating the imbufs, */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = metaseq->seqbase.first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		if (seq->type == SEQ_TYPE_META) { | 
					
						
							| 
									
										
										
										
											2012-04-28 13:16:29 +00:00
										 |  |  | 			seq_update_sound_bounds_recursive_rec(scene, seq, MAX2(start, metaseq_start(seq)), MIN2(end, metaseq_end(seq))); | 
					
						
							| 
									
										
										
										
											2012-02-13 20:54:36 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		else if (ELEM(seq->type, SEQ_TYPE_SOUND_RAM, SEQ_TYPE_SCENE)) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (seq->scene_sound) { | 
					
						
							| 
									
										
										
										
											2012-02-13 20:54:36 +00:00
										 |  |  | 				int startofs = seq->startofs; | 
					
						
							|  |  |  | 				int endofs = seq->endofs; | 
					
						
							| 
									
										
										
										
											2012-04-28 13:16:29 +00:00
										 |  |  | 				if (seq->startofs + seq->start < start) | 
					
						
							|  |  |  | 					startofs = start - seq->start; | 
					
						
							| 
									
										
										
										
											2012-02-13 20:54:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 13:16:29 +00:00
										 |  |  | 				if (seq->start + seq->len - seq->endofs > end) | 
					
						
							|  |  |  | 					endofs = seq->start + seq->len - end; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				sound_move_scene_sound(scene, seq->scene_sound, seq->start + startofs, seq->start + seq->len - endofs, startofs); | 
					
						
							| 
									
										
										
										
											2012-02-13 20:54:36 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-02-13 17:31:33 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 13:16:29 +00:00
										 |  |  | static void seq_update_sound_bounds_recursive(Scene *scene, Sequence *metaseq) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	seq_update_sound_bounds_recursive_rec(scene, metaseq, metaseq_start(metaseq), metaseq_end(metaseq)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | void calc_sequence_disp(Scene *scene, Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (seq->startofs && seq->startstill) seq->startstill = 0; | 
					
						
							|  |  |  | 	if (seq->endofs && seq->endstill) seq->endstill = 0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seq->startdisp = seq->start + seq->startofs - seq->startstill; | 
					
						
							|  |  |  | 	seq->enddisp = seq->start + seq->len - seq->endofs + seq->endstill; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seq->handsize = 10.0;  /* 10 frames */ | 
					
						
							|  |  |  | 	if (seq->enddisp - seq->startdisp < 10) { | 
					
						
							|  |  |  | 		seq->handsize = (float)(0.5 * (seq->enddisp - seq->startdisp)); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	else if (seq->enddisp - seq->startdisp > 250) { | 
					
						
							|  |  |  | 		seq->handsize = (float)((seq->enddisp - seq->startdisp) / 25); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-08-09 21:16:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (ELEM(seq->type, SEQ_TYPE_SOUND_RAM, SEQ_TYPE_SCENE)) { | 
					
						
							| 
									
										
										
										
											2012-02-13 20:54:36 +00:00
										 |  |  | 		seq_update_sound_bounds(scene, seq); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	else if (seq->type == SEQ_TYPE_META) | 
					
						
							| 
									
										
										
										
											2012-02-13 20:54:36 +00:00
										 |  |  | 		seq_update_sound_bounds_recursive(scene, seq); | 
					
						
							| 
									
										
										
										
											2010-07-13 15:19:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | void calc_sequence(Scene *scene, Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Sequence *seqm; | 
					
						
							|  |  |  | 	int min, max; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* check all metas recursively */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seqm = seq->seqbase.first; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (seqm) { | 
					
						
							|  |  |  | 		if (seqm->seqbase.first) calc_sequence(scene, seqm); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		seqm = seqm->next; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* effects and meta: automatic start and end */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (seq->type & SEQ_TYPE_EFFECT) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		/* pointers */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		if (seq->seq2 == NULL) seq->seq2 = seq->seq1; | 
					
						
							|  |  |  | 		if (seq->seq3 == NULL) seq->seq3 = seq->seq1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* effecten go from seq1 -> seq2: test */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* we take the largest start and smallest end */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-27 19:40:36 +00:00
										 |  |  | 		// seq->start = seq->startdisp = MAX2(seq->seq1->startdisp, seq->seq2->startdisp);
 | 
					
						
							|  |  |  | 		// seq->enddisp = MIN2(seq->seq1->enddisp, seq->seq2->enddisp);
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if (seq->seq1) { | 
					
						
							| 
									
										
										
										
											2011-11-16 20:03:54 +00:00
										 |  |  | 			/* XXX These resets should not be necessary, but users used to be able to
 | 
					
						
							| 
									
										
										
										
											2012-04-11 08:15:13 +00:00
										 |  |  | 			 *     edit effect's length, leading to strange results. See [#29190] */ | 
					
						
							| 
									
										
										
										
											2011-11-16 20:03:54 +00:00
										 |  |  | 			seq->startofs = seq->endofs = seq->startstill = seq->endstill = 0; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			seq->start = seq->startdisp = MAX3(seq->seq1->startdisp, seq->seq2->startdisp, seq->seq3->startdisp); | 
					
						
							|  |  |  | 			seq->enddisp = MIN3(seq->seq1->enddisp, seq->seq2->enddisp, seq->seq3->enddisp); | 
					
						
							| 
									
										
										
										
											2011-06-04 10:39:04 +00:00
										 |  |  | 			/* we cant help if strips don't overlap, it wont give useful results.
 | 
					
						
							|  |  |  | 			 * but at least ensure 'len' is never negative which causes bad bugs elsewhere. */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (seq->enddisp < seq->startdisp) { | 
					
						
							| 
									
										
										
										
											2011-06-04 10:39:04 +00:00
										 |  |  | 				/* simple start/end swap */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				seq->start = seq->enddisp; | 
					
						
							| 
									
										
										
										
											2011-06-04 10:39:04 +00:00
										 |  |  | 				seq->enddisp = seq->startdisp; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				seq->startdisp = seq->start; | 
					
						
							| 
									
										
										
										
											2011-06-07 18:34:33 +00:00
										 |  |  | 				seq->flag |= SEQ_INVALID_EFFECT; | 
					
						
							| 
									
										
										
										
											2011-06-04 10:39:04 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-06-07 18:34:33 +00:00
										 |  |  | 			else { | 
					
						
							|  |  |  | 				seq->flag &= ~SEQ_INVALID_EFFECT; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			seq->len = seq->enddisp - seq->startdisp; | 
					
						
							| 
									
										
										
										
											2011-06-04 10:39:04 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 			calc_sequence_disp(scene, seq); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		if (seq->type == SEQ_TYPE_META) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			seqm = seq->seqbase.first; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (seqm) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				min =  MAXFRAME * 2; | 
					
						
							|  |  |  | 				max = -MAXFRAME * 2; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				while (seqm) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 					if (seqm->startdisp < min) min = seqm->startdisp; | 
					
						
							|  |  |  | 					if (seqm->enddisp > max) max = seqm->enddisp; | 
					
						
							|  |  |  | 					seqm = seqm->next; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				seq->start = min + seq->anim_startofs; | 
					
						
							|  |  |  | 				seq->len = max - min; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				seq->len -= seq->anim_startofs; | 
					
						
							|  |  |  | 				seq->len -= seq->anim_endofs; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2010-07-13 15:19:15 +00:00
										 |  |  | 			seq_update_sound_bounds_recursive(scene, seq); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 		calc_sequence_disp(scene, seq); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-10 15:41:01 +00:00
										 |  |  | /* note: caller should run calc_sequence(scene, seq) after */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | void reload_sequence_new_file(Scene *scene, Sequence *seq, int lock_range) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-11-26 04:07:38 +00:00
										 |  |  | 	char str[FILE_MAX]; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	int prev_startdisp = 0, prev_enddisp = 0; | 
					
						
							| 
									
										
										
										
											2012-03-18 07:38:51 +00:00
										 |  |  | 	/* note: don't rename the strip, will break animation curves */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | 	if (ELEM7(seq->type, | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	          SEQ_TYPE_MOVIE, SEQ_TYPE_IMAGE, SEQ_TYPE_SOUND_RAM, | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | 	          SEQ_TYPE_SCENE, SEQ_TYPE_META, SEQ_TYPE_MOVIECLIP, SEQ_TYPE_MASK) == 0) | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (lock_range) { | 
					
						
							| 
									
										
										
										
											2012-03-18 07:38:51 +00:00
										 |  |  | 		/* keep so we don't have to move the actual start and end points (only the data) */ | 
					
						
							| 
									
										
										
										
											2010-05-08 16:36:28 +00:00
										 |  |  | 		calc_sequence_disp(scene, seq); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		prev_startdisp = seq->startdisp; | 
					
						
							|  |  |  | 		prev_enddisp = seq->enddisp; | 
					
						
							| 
									
										
										
										
											2010-05-08 16:36:28 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	switch (seq->type) { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_IMAGE: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			/* Hack? */ | 
					
						
							|  |  |  | 			size_t olen = MEM_allocN_len(seq->strip->stripdata) / sizeof(struct StripElem); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			seq->len = olen; | 
					
						
							|  |  |  | 			seq->len -= seq->anim_startofs; | 
					
						
							|  |  |  | 			seq->len -= seq->anim_endofs; | 
					
						
							|  |  |  | 			if (seq->len < 0) { | 
					
						
							|  |  |  | 				seq->len = 0; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_MOVIE: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			BLI_join_dirfile(str, sizeof(str), seq->strip->dir, | 
					
						
							|  |  |  | 			                 seq->strip->stripdata->name); | 
					
						
							|  |  |  | 			BLI_path_abs(str, G.main->name); | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			if (seq->anim) IMB_free_anim(seq->anim); | 
					
						
							|  |  |  | 			seq->anim = openanim(str, IB_rect | ((seq->flag & SEQ_FILTERY) ? IB_animdeinterlace : 0), seq->streamindex); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			if (!seq->anim) { | 
					
						
							|  |  |  | 				return; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			seq->len = IMB_anim_get_duration(seq->anim, | 
					
						
							|  |  |  | 			                                 seq->strip->proxy ? | 
					
						
							|  |  |  | 			                                 seq->strip->proxy->tc : | 
					
						
							|  |  |  | 			                                 IMB_TC_RECORD_RUN); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			seq->anim_preseek = IMB_anim_get_preseek(seq->anim); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			seq->len -= seq->anim_startofs; | 
					
						
							|  |  |  | 			seq->len -= seq->anim_endofs; | 
					
						
							|  |  |  | 			if (seq->len < 0) { | 
					
						
							|  |  |  | 				seq->len = 0; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_MOVIECLIP: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			seq->len = BKE_movieclip_get_duration(seq->clip); | 
					
						
							| 
									
										
										
										
											2012-03-27 08:54:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | 			seq->len -= seq->anim_startofs; | 
					
						
							|  |  |  | 			seq->len -= seq->anim_endofs; | 
					
						
							|  |  |  | 			if (seq->len < 0) { | 
					
						
							|  |  |  | 				seq->len = 0; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case SEQ_TYPE_MASK: | 
					
						
							|  |  |  | 			seq->len = BKE_mask_get_duration(seq->mask); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			seq->len -= seq->anim_startofs; | 
					
						
							|  |  |  | 			seq->len -= seq->anim_endofs; | 
					
						
							|  |  |  | 			if (seq->len < 0) { | 
					
						
							|  |  |  | 				seq->len = 0; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_SOUND_RAM: | 
					
						
							| 
									
										
										
										
											2011-06-23 09:27:56 +00:00
										 |  |  | #ifdef WITH_AUDASPACE
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			if (!seq->sound) | 
					
						
							|  |  |  | 				return; | 
					
						
							|  |  |  | 			seq->len = ceil(AUD_getInfo(seq->sound->playback_handle).length * FPS); | 
					
						
							|  |  |  | 			seq->len -= seq->anim_startofs; | 
					
						
							|  |  |  | 			seq->len -= seq->anim_endofs; | 
					
						
							|  |  |  | 			if (seq->len < 0) { | 
					
						
							|  |  |  | 				seq->len = 0; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-06-23 09:27:56 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			return; | 
					
						
							| 
									
										
										
										
											2011-06-23 09:27:56 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_SCENE: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			seq->len = (seq->scene) ? seq->scene->r.efra - seq->scene->r.sfra + 1 : 0; | 
					
						
							|  |  |  | 			seq->len -= seq->anim_startofs; | 
					
						
							|  |  |  | 			seq->len -= seq->anim_endofs; | 
					
						
							|  |  |  | 			if (seq->len < 0) { | 
					
						
							|  |  |  | 				seq->len = 0; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 	free_proxy_seq(seq); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (lock_range) { | 
					
						
							| 
									
										
										
										
											2010-05-08 16:36:28 +00:00
										 |  |  | 		seq_tx_set_final_left(seq, prev_startdisp); | 
					
						
							|  |  |  | 		seq_tx_set_final_right(seq, prev_enddisp); | 
					
						
							|  |  |  | 		seq_single_fix(seq); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 	calc_sequence(scene, seq); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | void BKE_sequencer_sort(Scene *scene) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* all strips together per kind, and in order of y location ("machine") */ | 
					
						
							|  |  |  | 	ListBase seqbase, effbase; | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | 	Editing *ed = BKE_sequencer_editing_get(scene, FALSE); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	Sequence *seq, *seqt; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-28 22:36:34 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (ed == NULL) return; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seqbase.first = seqbase.last = NULL; | 
					
						
							|  |  |  | 	effbase.first = effbase.last = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	while ( (seq = ed->seqbasep->first) ) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		BLI_remlink(ed->seqbasep, seq); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		if (seq->type & SEQ_TYPE_EFFECT) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			seqt = effbase.first; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			while (seqt) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				if (seqt->machine >= seq->machine) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 					BLI_insertlinkbefore(&effbase, seqt, seq); | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				seqt = seqt->next; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			if (seqt == NULL) BLI_addtail(&effbase, seq); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			seqt = seqbase.first; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			while (seqt) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				if (seqt->machine >= seq->machine) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 					BLI_insertlinkbefore(&seqbase, seqt, seq); | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				seqt = seqt->next; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			if (seqt == NULL) BLI_addtail(&seqbase, seq); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-21 14:49:34 +00:00
										 |  |  | 	BLI_movelisttolist(&seqbase, &effbase); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	*(ed->seqbasep) = seqbase; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-18 13:28:03 +00:00
										 |  |  | static int clear_scene_in_allseqs_cb(Sequence *seq, void *arg_pt) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (seq->scene == (Scene *)arg_pt) | 
					
						
							|  |  |  | 		seq->scene = NULL; | 
					
						
							| 
									
										
										
										
											2009-12-18 13:28:03 +00:00
										 |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-13 14:23:44 +00:00
										 |  |  | void clear_scene_in_allseqs(Main *bmain, Scene *scene) | 
					
						
							| 
									
										
										
										
											2009-12-18 13:28:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Scene *scene_iter; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-18 13:28:03 +00:00
										 |  |  | 	/* when a scene is deleted: test all seqs */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (scene_iter = bmain->scene.first; scene_iter; scene_iter = scene_iter->id.next) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (scene_iter != scene && scene_iter->ed) { | 
					
						
							| 
									
										
										
										
											2009-12-18 13:28:03 +00:00
										 |  |  | 			seqbase_recursive_apply(&scene_iter->ed->seqbase, clear_scene_in_allseqs_cb, scene); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-16 17:58:50 +00:00
										 |  |  | typedef struct SeqUniqueInfo { | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							| 
									
										
										
										
											2012-01-11 08:51:06 +00:00
										 |  |  | 	char name_src[SEQ_NAME_MAXSTR]; | 
					
						
							|  |  |  | 	char name_dest[SEQ_NAME_MAXSTR]; | 
					
						
							| 
									
										
										
										
											2010-02-16 17:58:50 +00:00
										 |  |  | 	int count; | 
					
						
							|  |  |  | 	int match; | 
					
						
							|  |  |  | } SeqUniqueInfo; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2010-02-16 17:58:50 +00:00
										 |  |  | static void seqbase_unique_name(ListBase *seqbasep, Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-04-21 15:53:30 +00:00
										 |  |  | 	BLI_uniquename(seqbasep, seq, "Sequence", '.', offsetof(Sequence, name), SEQ_NAME_MAXSTR); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2010-02-16 17:58:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static void seqbase_unique_name(ListBase *seqbasep, SeqUniqueInfo *sui) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = seqbasep->first; seq; seq = seq->next) { | 
					
						
							|  |  |  | 		if (sui->seq != seq && strcmp(sui->name_dest, seq->name + 2) == 0) { | 
					
						
							| 
									
										
										
										
											2012-01-11 12:33:51 +00:00
										 |  |  | 			/* SEQ_NAME_MAXSTR - 2 for prefix, -1 for \0, -4 for the number */ | 
					
						
							|  |  |  | 			BLI_snprintf(sui->name_dest, sizeof(sui->name_dest), "%.59s.%03d",  sui->name_src, sui->count++); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			sui->match = 1; /* be sure to re-scan */ | 
					
						
							| 
									
										
										
										
											2010-02-16 17:58:50 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int seqbase_unique_name_recursive_cb(Sequence *seq, void *arg_pt) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->seqbase.first) | 
					
						
							| 
									
										
										
										
											2010-02-16 17:58:50 +00:00
										 |  |  | 		seqbase_unique_name(&seq->seqbase, (SeqUniqueInfo *)arg_pt); | 
					
						
							|  |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void seqbase_unique_name_recursive(ListBase *seqbasep, struct Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	SeqUniqueInfo sui; | 
					
						
							|  |  |  | 	char *dot; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	sui.seq = seq; | 
					
						
							|  |  |  | 	BLI_strncpy(sui.name_src, seq->name + 2, sizeof(sui.name_src)); | 
					
						
							|  |  |  | 	BLI_strncpy(sui.name_dest, seq->name + 2, sizeof(sui.name_dest)); | 
					
						
							| 
									
										
										
										
											2010-02-16 17:58:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	sui.count = 1; | 
					
						
							|  |  |  | 	sui.match = 1; /* assume the worst to start the loop */ | 
					
						
							| 
									
										
										
										
											2010-07-14 12:16:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-16 17:58:50 +00:00
										 |  |  | 	/* Strip off the suffix */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if ((dot = strrchr(sui.name_src, '.'))) { | 
					
						
							|  |  |  | 		*dot = '\0'; | 
					
						
							| 
									
										
										
										
											2010-07-14 12:16:23 +00:00
										 |  |  | 		dot++; | 
					
						
							| 
									
										
										
										
											2010-02-16 17:58:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (*dot) | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			sui.count = atoi(dot) + 1; | 
					
						
							| 
									
										
										
										
											2010-07-14 12:16:23 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-02-16 17:58:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (sui.match) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		sui.match = 0; | 
					
						
							| 
									
										
										
										
											2010-02-16 17:58:50 +00:00
										 |  |  | 		seqbase_unique_name(seqbasep, &sui); | 
					
						
							|  |  |  | 		seqbase_recursive_apply(seqbasep, seqbase_unique_name_recursive_cb, &sui); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	BLI_strncpy(seq->name + 2, sui.name_dest, sizeof(seq->name) - 2); | 
					
						
							| 
									
										
										
										
											2010-02-16 17:58:50 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 17:05:21 +00:00
										 |  |  | static const char *give_seqname_by_type(int type) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	switch (type) { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_META:       return "Meta"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_IMAGE:      return "Image"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_SCENE:      return "Scene"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_MOVIE:      return "Movie"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_MOVIECLIP:  return "Clip"; | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | 		case SEQ_TYPE_MASK:       return "Mask"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_SOUND_RAM:  return "Audio"; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_CROSS:      return "Cross"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_GAMCROSS:   return "Gamma Cross"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_ADD:        return "Add"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_SUB:        return "Sub"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_MUL:        return "Mul"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_ALPHAOVER:  return "Alpha Over"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_ALPHAUNDER: return "Alpha Under"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_OVERDROP:   return "Over Drop"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_WIPE:       return "Wipe"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_GLOW:       return "Glow"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_TRANSFORM:  return "Transform"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_COLOR:      return "Color"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_MULTICAM:   return "Multicam"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_ADJUSTMENT: return "Adjustment"; | 
					
						
							|  |  |  | 		case SEQ_TYPE_SPEED:      return "Speed"; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		default: | 
					
						
							|  |  |  | 			return NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 17:05:21 +00:00
										 |  |  | const char *give_seqname(Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-12-03 17:05:21 +00:00
										 |  |  | 	const char *name = give_seqname_by_type(seq->type); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (!name) { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		if (seq->type < SEQ_TYPE_EFFECT) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			return seq->strip->dir; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			return "Effect"; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return name; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ***************** DO THE SEQUENCE ***************** */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void make_black_ibuf(ImBuf *ibuf) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	unsigned int *rect; | 
					
						
							|  |  |  | 	float *rect_float; | 
					
						
							|  |  |  | 	int tot; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:35:12 +00:00
										 |  |  | 	if (ibuf == NULL || (ibuf->rect == NULL && ibuf->rect_float == NULL)) { | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	tot = ibuf->x * ibuf->y; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	rect = ibuf->rect; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	rect_float = ibuf->rect_float; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (rect) { | 
					
						
							|  |  |  | 		memset(rect,       0, tot * sizeof(char) * 4); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (rect_float) { | 
					
						
							|  |  |  | 		memset(rect_float, 0, tot * sizeof(float) * 4); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void multibuf(ImBuf *ibuf, float fmul) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	char *rt; | 
					
						
							|  |  |  | 	float *rt_float; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	int a, mul, icol; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	mul = (int)(256.0f * fmul); | 
					
						
							|  |  |  | 	rt = (char *)ibuf->rect; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	rt_float = ibuf->rect_float; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (rt) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		a = ibuf->x * ibuf->y; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (a--) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			icol = (mul * rt[0]) >> 8; | 
					
						
							|  |  |  | 			if (icol > 254) rt[0] = 255; else rt[0] = icol; | 
					
						
							|  |  |  | 			icol = (mul * rt[1]) >> 8; | 
					
						
							|  |  |  | 			if (icol > 254) rt[1] = 255; else rt[1] = icol; | 
					
						
							|  |  |  | 			icol = (mul * rt[2]) >> 8; | 
					
						
							|  |  |  | 			if (icol > 254) rt[2] = 255; else rt[2] = icol; | 
					
						
							|  |  |  | 			icol = (mul * rt[3]) >> 8; | 
					
						
							|  |  |  | 			if (icol > 254) rt[3] = 255; else rt[3] = icol; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (rt_float) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		a = ibuf->x * ibuf->y; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (a--) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			rt_float[0] *= fmul; | 
					
						
							|  |  |  | 			rt_float[1] *= fmul; | 
					
						
							|  |  |  | 			rt_float[2] *= fmul; | 
					
						
							|  |  |  | 			rt_float[3] *= fmul; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			rt_float += 4; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | static float give_stripelem_index(Sequence *seq, float cfra) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	float nr; | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	int sta = seq->start; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	int end = seq->start + seq->len - 1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (seq->type & SEQ_TYPE_EFFECT) { | 
					
						
							| 
									
										
										
										
											2011-05-17 18:37:44 +00:00
										 |  |  | 		end = seq->enddisp; | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (end < sta) { | 
					
						
							| 
									
										
										
										
											2011-05-17 18:37:44 +00:00
										 |  |  | 		return -1; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (seq->flag & SEQ_REVERSE_FRAMES) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		/*reverse frame in this sequence */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		if (cfra <= sta) nr = end - sta; | 
					
						
							|  |  |  | 		else if (cfra >= end) nr = 0; | 
					
						
							|  |  |  | 		else nr = end - cfra; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		if (cfra <= sta) nr = 0; | 
					
						
							|  |  |  | 		else if (cfra >= end) nr = end - sta; | 
					
						
							|  |  |  | 		else nr = cfra - sta; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 	if (seq->strobe < 1.0f) seq->strobe = 1.0f; | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 	if (seq->strobe > 1.0f) { | 
					
						
							| 
									
										
										
										
											2011-04-02 02:08:33 +00:00
										 |  |  | 		nr -= fmodf((double)nr, (double)seq->strobe); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return nr; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | StripElem *give_stripelem(Sequence *seq, int cfra) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	StripElem *se = seq->strip->stripdata; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (seq->type == SEQ_TYPE_IMAGE) { /* only
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		                           * IMAGE strips use the whole array, | 
					
						
							|  |  |  | 		                           * MOVIE strips use only | 
					
						
							|  |  |  | 		                           * the first element, all other strips | 
					
						
							|  |  |  | 		                           * don't use this... */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:35:12 +00:00
										 |  |  | 		int nr = (int)give_stripelem_index(seq, cfra); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 		if (nr == -1 || se == NULL) return NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-01-18 11:22:32 +00:00
										 |  |  | 		se += nr + seq->anim_startofs; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	return se; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static int evaluate_seq_frame_gen(Sequence **seq_arr, ListBase *seqbase, int cfra) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	int totseq = 0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	memset(seq_arr, 0, sizeof(Sequence *) * (MAXSEQ + 1)); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seq = seqbase->first; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (seq) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		if (seq->startdisp <= cfra && seq->enddisp > cfra) { | 
					
						
							|  |  |  | 			seq_arr[seq->machine] = seq; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			totseq++; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		seq = seq->next; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return totseq; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int evaluate_seq_frame(Scene *scene, int cfra) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | 	Editing *ed = BKE_sequencer_editing_get(scene, FALSE); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	Sequence *seq_arr[MAXSEQ + 1]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (ed == NULL) return 0; | 
					
						
							| 
									
										
										
										
											2009-01-28 22:36:34 +00:00
										 |  |  | 	return evaluate_seq_frame_gen(seq_arr, ed->seqbasep, cfra); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static int video_seq_is_rendered(Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	return (seq && !(seq->flag & SEQ_MUTE) && seq->type != SEQ_TYPE_SOUND_RAM); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static int get_shown_sequences(ListBase *seqbasep, int cfra, int chanshown, Sequence **seq_arr_out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	Sequence *seq_arr[MAXSEQ + 1]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	int b = chanshown; | 
					
						
							|  |  |  | 	int cnt = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (b > MAXSEQ) { | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (evaluate_seq_frame_gen(seq_arr, seqbasep, cfra)) { | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 		if (b == 0) { | 
					
						
							|  |  |  | 			b = MAXSEQ; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		for (; b > 0; b--) { | 
					
						
							|  |  |  | 			if (video_seq_is_rendered(seq_arr[b])) { | 
					
						
							|  |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	chanshown = b; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (; b > 0; b--) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		if (video_seq_is_rendered(seq_arr[b])) { | 
					
						
							|  |  |  | 			if (seq_arr[b]->blend_mode == SEQ_BLEND_REPLACE) { | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (; b <= chanshown && b >= 0; b++) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		if (video_seq_is_rendered(seq_arr[b])) { | 
					
						
							|  |  |  | 			seq_arr_out[cnt++] = seq_arr[b]; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return cnt; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* **********************************************************************
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  |  * proxy management | 
					
						
							|  |  |  |  * ********************************************************************** */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | typedef struct SeqIndexBuildContext { | 
					
						
							|  |  |  | 	struct IndexBuildContext *index_context; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	int tc_flags; | 
					
						
							|  |  |  | 	int size_flags; | 
					
						
							|  |  |  | 	int quality; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Main *bmain; | 
					
						
							|  |  |  | 	Scene *scene; | 
					
						
							|  |  |  | 	Sequence *seq, *orig_seq; | 
					
						
							|  |  |  | } SeqIndexBuildContext; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | #define PROXY_MAXFILE (2 * FILE_MAXDIR + FILE_MAXFILE)
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | static IMB_Proxy_Size seq_rendersize_to_proxysize(int size) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (size >= 100) { | 
					
						
							|  |  |  | 		return IMB_PROXY_NONE; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (size >= 99) { | 
					
						
							|  |  |  | 		return IMB_PROXY_100; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (size >= 75) { | 
					
						
							|  |  |  | 		return IMB_PROXY_75; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (size >= 50) { | 
					
						
							|  |  |  | 		return IMB_PROXY_50; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return IMB_PROXY_25; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-17 19:31:28 +00:00
										 |  |  | static double seq_rendersize_to_scale_factor(int size) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (size >= 99) { | 
					
						
							|  |  |  | 		return 1.0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (size >= 75) { | 
					
						
							|  |  |  | 		return 0.75; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (size >= 50) { | 
					
						
							|  |  |  | 		return 0.50; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return 0.25; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static void seq_open_anim_file(Sequence *seq) | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-11-26 04:07:38 +00:00
										 |  |  | 	char name[FILE_MAX]; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	StripProxy *proxy; | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->anim != NULL) { | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-11 13:09:14 +00:00
										 |  |  | 	BLI_join_dirfile(name, sizeof(name), | 
					
						
							|  |  |  | 	                 seq->strip->dir, seq->strip->stripdata->name); | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	BLI_path_abs(name, G.main->name); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	seq->anim = openanim(name, IB_rect | | 
					
						
							| 
									
										
										
										
											2011-11-11 13:09:14 +00:00
										 |  |  | 	                     ((seq->flag & SEQ_FILTERY) ? | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	                      IB_animdeinterlace : 0), seq->streamindex); | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (seq->anim == NULL) { | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	proxy = seq->strip->proxy; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (proxy == NULL) { | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (seq->flag & SEQ_USE_PROXY_CUSTOM_DIR) { | 
					
						
							| 
									
										
										
										
											2012-06-28 07:58:34 +00:00
										 |  |  | 		char dir[FILE_MAX]; | 
					
						
							|  |  |  | 		BLI_strncpy(dir, seq->strip->proxy->dir, sizeof(dir)); | 
					
						
							|  |  |  | 		BLI_path_abs(dir, G.main->name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		IMB_anim_set_index_dir(seq->anim, dir); | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static int seq_proxy_get_fname(Sequence *seq, int cfra, int render_size, char *name) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int frameno; | 
					
						
							| 
									
										
										
										
											2011-08-30 10:07:50 +00:00
										 |  |  | 	char dir[PROXY_MAXFILE]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (!seq->strip->proxy) { | 
					
						
							|  |  |  | 		return FALSE; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	/* MOVIE tracks (only exception: custom files) are now handled 
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  | 	 * internally by ImBuf module for various reasons: proper time code | 
					
						
							|  |  |  | 	 * support, quicker index build, using one file instead | 
					
						
							|  |  |  | 	 * of a full directory of jpeg files, etc. Trying to support old | 
					
						
							|  |  |  | 	 * and new method at once could lead to funny effects, if people | 
					
						
							|  |  |  | 	 * have both, a directory full of jpeg files and proxy avis, so | 
					
						
							|  |  |  | 	 * sorry folks, please rebuild your proxies... */ | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (seq->flag & (SEQ_USE_PROXY_CUSTOM_DIR | SEQ_USE_PROXY_CUSTOM_FILE)) { | 
					
						
							| 
									
										
										
										
											2011-10-19 23:10:54 +00:00
										 |  |  | 		BLI_strncpy(dir, seq->strip->proxy->dir, sizeof(dir)); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	else if (seq->type == SEQ_TYPE_IMAGE) { | 
					
						
							| 
									
										
										
										
											2011-08-30 10:07:50 +00:00
										 |  |  | 		BLI_snprintf(dir, PROXY_MAXFILE, "%s/BL_proxy", seq->strip->dir); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 		return FALSE; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 	if (seq->flag & SEQ_USE_PROXY_CUSTOM_FILE) { | 
					
						
							| 
									
										
										
										
											2011-11-11 13:09:14 +00:00
										 |  |  | 		BLI_join_dirfile(name, PROXY_MAXFILE, | 
					
						
							|  |  |  | 		                 dir, seq->strip->proxy->file); | 
					
						
							| 
									
										
										
										
											2010-10-18 06:41:16 +00:00
										 |  |  | 		BLI_path_abs(name, G.main->name); | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		return TRUE; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-02 17:25:15 +00:00
										 |  |  | 	/* generate a separate proxy directory for each preview size */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (seq->type == SEQ_TYPE_IMAGE) { | 
					
						
							| 
									
										
										
										
											2011-08-30 10:07:50 +00:00
										 |  |  | 		BLI_snprintf(name, PROXY_MAXFILE, "%s/images/%d/%s_proxy", dir, | 
					
						
							| 
									
										
										
										
											2012-02-17 07:32:18 +00:00
										 |  |  | 		             render_size, | 
					
						
							| 
									
										
										
										
											2011-11-11 13:09:14 +00:00
										 |  |  | 		             give_stripelem(seq, cfra)->name); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		frameno = 1; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:35:12 +00:00
										 |  |  | 		frameno = (int)give_stripelem_index(seq, cfra) + seq->anim_startofs; | 
					
						
							| 
									
										
										
										
											2011-08-30 10:07:50 +00:00
										 |  |  | 		BLI_snprintf(name, PROXY_MAXFILE, "%s/proxy_misc/%d/####", dir,  | 
					
						
							| 
									
										
										
										
											2012-02-17 07:32:18 +00:00
										 |  |  | 		             render_size); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-18 06:41:16 +00:00
										 |  |  | 	BLI_path_abs(name, G.main->name); | 
					
						
							| 
									
										
										
										
											2010-03-09 17:36:23 +00:00
										 |  |  | 	BLI_path_frame(name, frameno, 0); | 
					
						
							| 
									
										
										
										
											2010-01-30 22:33:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	strcat(name, ".jpg"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return TRUE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static ImBuf *seq_proxy_fetch(SeqRenderData context, Sequence *seq, int cfra) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	char name[PROXY_MAXFILE]; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	IMB_Proxy_Size psize = seq_rendersize_to_proxysize(context.preview_render_size); | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	int size_flags; | 
					
						
							| 
									
										
										
										
											2012-02-17 07:32:18 +00:00
										 |  |  | 	int render_size = context.preview_render_size; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* dirty hack to distinguish 100% render size from PROXY_100 */ | 
					
						
							|  |  |  | 	if (render_size == 99) { | 
					
						
							|  |  |  | 		render_size = 100; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (!(seq->flag & SEQ_USE_PROXY)) { | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 		return NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	size_flags = seq->strip->proxy->build_size_flags; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* only use proxies, if they are enabled (even if present!) */ | 
					
						
							| 
									
										
										
										
											2011-09-11 21:46:24 +00:00
										 |  |  | 	if (psize == IMB_PROXY_NONE || ((size_flags & psize) != psize)) { | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 		return NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 	if (seq->flag & SEQ_USE_PROXY_CUSTOM_FILE) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:35:12 +00:00
										 |  |  | 		int frameno = (int)give_stripelem_index(seq, cfra) + seq->anim_startofs; | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 		if (seq->strip->proxy->anim == NULL) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			if (seq_proxy_get_fname(seq, cfra, render_size, name) == 0) { | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 				return NULL; | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  |   | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 			seq->strip->proxy->anim = openanim(name, IB_rect, 0); | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		if (seq->strip->proxy->anim == NULL) { | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 			return NULL; | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  |   | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 		seq_open_anim_file(seq); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		frameno = IMB_anim_index_get_frame_index(seq->anim, seq->strip->proxy->tc, | 
					
						
							|  |  |  | 		                                         frameno); | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		return IMB_anim_absolute(seq->strip->proxy->anim, frameno, | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		                         IMB_TC_NONE, IMB_PROXY_NONE); | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  |   | 
					
						
							| 
									
										
										
										
											2012-02-17 07:32:18 +00:00
										 |  |  | 	if (seq_proxy_get_fname(seq, cfra, render_size, name) == 0) { | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 		return NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (BLI_exists(name)) { | 
					
						
							|  |  |  | 		return IMB_loadiffname(name, IB_rect); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 		return NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | static void seq_proxy_build_frame(SeqRenderData context, | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  |                                   Sequence *seq, int cfra, | 
					
						
							|  |  |  |                                   int proxy_render_size) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	char name[PROXY_MAXFILE]; | 
					
						
							|  |  |  | 	int quality; | 
					
						
							|  |  |  | 	int rectx, recty; | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	int ok; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	ImBuf *ibuf; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-17 07:32:18 +00:00
										 |  |  | 	if (!seq_proxy_get_fname(seq, cfra, proxy_render_size, name)) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	ibuf = seq_render_strip(context, seq, cfra); | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	rectx = (proxy_render_size * context.scene->r.xsch) / 100; | 
					
						
							|  |  |  | 	recty = (proxy_render_size * context.scene->r.ysch) / 100; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (ibuf->x != rectx || ibuf->y != recty) { | 
					
						
							|  |  |  | 		IMB_scalefastImBuf(ibuf, (short)rectx, (short)recty); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	/* depth = 32 is intentionally left in, otherwise ALPHA channels
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  | 	 * won't work... */ | 
					
						
							| 
									
										
										
										
											2009-06-14 18:54:35 +00:00
										 |  |  | 	quality = seq->strip->proxy->quality; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	ibuf->ftype = JPG | quality; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-23 17:52:20 +00:00
										 |  |  | 	/* unsupported feature only confuses other s/w */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (ibuf->planes == 32) | 
					
						
							|  |  |  | 		ibuf->planes = 24; | 
					
						
							| 
									
										
										
										
											2011-10-23 17:52:20 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	BLI_make_existing_file(name); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	ok = IMB_saveiff(ibuf, name, IB_rect | IB_zbuf | IB_zbuffloat); | 
					
						
							|  |  |  | 	if (ok == 0) { | 
					
						
							|  |  |  | 		perror(name); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	IMB_freeImBuf(ibuf); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-21 12:51:47 +00:00
										 |  |  | struct SeqIndexBuildContext *seq_proxy_rebuild_context(Main *bmain, Scene *scene, Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | 	SeqIndexBuildContext *context; | 
					
						
							|  |  |  | 	Sequence *nseq; | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (!seq->strip || !seq->strip->proxy) { | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | 		return NULL; | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!(seq->flag & SEQ_USE_PROXY)) { | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | 		return NULL; | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | 	context = MEM_callocN(sizeof(SeqIndexBuildContext), "seq proxy rebuild context"); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | 	nseq = seq_dupli_recursive(scene, scene, seq, 0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	context->tc_flags   = nseq->strip->proxy->build_tc_flags; | 
					
						
							|  |  |  | 	context->size_flags = nseq->strip->proxy->build_size_flags; | 
					
						
							|  |  |  | 	context->quality    = nseq->strip->proxy->quality; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | 	context->bmain = bmain; | 
					
						
							|  |  |  | 	context->scene = scene; | 
					
						
							|  |  |  | 	context->orig_seq = seq; | 
					
						
							|  |  |  | 	context->seq = nseq; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (nseq->type == SEQ_TYPE_MOVIE) { | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | 		seq_open_anim_file(nseq); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (nseq->anim) { | 
					
						
							|  |  |  | 			context->index_context = IMB_anim_index_rebuild_context(nseq->anim, | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			        context->tc_flags, context->size_flags, context->quality); | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return context; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void seq_proxy_rebuild(SeqIndexBuildContext *context, short *stop, short *do_update, float *progress) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	SeqRenderData render_context; | 
					
						
							|  |  |  | 	Sequence *seq = context->seq; | 
					
						
							|  |  |  | 	Scene *scene = context->scene; | 
					
						
							|  |  |  | 	int cfra; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (seq->type == SEQ_TYPE_MOVIE) { | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | 		if (context->index_context) { | 
					
						
							|  |  |  | 			IMB_anim_index_rebuild(context->index_context, stop, do_update, progress); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	if (!(seq->flag & SEQ_USE_PROXY)) { | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	/* that's why it is called custom... */ | 
					
						
							|  |  |  | 	if (seq->flag & SEQ_USE_PROXY_CUSTOM_FILE) { | 
					
						
							|  |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	/* fail safe code */ | 
					
						
							| 
									
										
										
										
											2009-06-14 18:54:35 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | 	render_context = seq_new_render_data( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	        context->bmain, context->scene, | 
					
						
							| 
									
										
										
										
											2012-03-29 22:35:12 +00:00
										 |  |  | 	        (scene->r.size * (float)scene->r.xsch) / 100.0f + 0.5f, | 
					
						
							|  |  |  | 	        (scene->r.size * (float)scene->r.ysch) / 100.0f + 0.5f, | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	        100); | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	for (cfra = seq->startdisp + seq->startstill;  | 
					
						
							| 
									
										
										
										
											2012-05-20 19:49:27 +00:00
										 |  |  | 	     cfra < seq->enddisp - seq->endstill; cfra++) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | 		if (context->size_flags & IMB_PROXY_25) { | 
					
						
							|  |  |  | 			seq_proxy_build_frame(render_context, seq, cfra, 25); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | 		if (context->size_flags & IMB_PROXY_50) { | 
					
						
							|  |  |  | 			seq_proxy_build_frame(render_context, seq, cfra, 50); | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | 		if (context->size_flags & IMB_PROXY_75) { | 
					
						
							|  |  |  | 			seq_proxy_build_frame(render_context, seq, cfra, 75); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | 		if (context->size_flags & IMB_PROXY_100) { | 
					
						
							|  |  |  | 			seq_proxy_build_frame(render_context, seq, cfra, 100); | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		*progress = (float)cfra / (seq->enddisp - seq->endstill - | 
					
						
							|  |  |  | 		                           seq->startdisp + seq->startstill); | 
					
						
							| 
									
										
										
										
											2012-05-19 13:28:19 +00:00
										 |  |  | 		*do_update = TRUE; | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (*stop || G.afbreek) | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-29 12:08:26 +00:00
										 |  |  | void seq_proxy_rebuild_finish(SeqIndexBuildContext *context, short stop) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (context->index_context) { | 
					
						
							|  |  |  | 		IMB_close_anim_proxies(context->seq->anim); | 
					
						
							|  |  |  | 		IMB_close_anim_proxies(context->orig_seq->anim); | 
					
						
							|  |  |  | 		IMB_anim_index_rebuild_finish(context->index_context, stop); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	seq_free_sequence_recurse(context->scene, context->seq); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	MEM_freeN(context); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* **********************************************************************
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  |  * color balance | 
					
						
							|  |  |  |  * ********************************************************************** */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static StripColorBalance calc_cb(StripColorBalance *cb_) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	StripColorBalance cb = *cb_; | 
					
						
							|  |  |  | 	int c; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-05 09:56:06 +00:00
										 |  |  | 	for (c = 0; c < 3; c++) { | 
					
						
							| 
									
										
										
										
											2010-07-06 10:21:28 +00:00
										 |  |  | 		cb.lift[c] = 2.0f - cb.lift[c]; | 
					
						
							| 
									
										
										
										
											2010-07-05 09:56:06 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (cb.flag & SEQ_COLOR_BALANCE_INVERSE_LIFT) { | 
					
						
							| 
									
										
										
										
											2010-07-05 14:53:11 +00:00
										 |  |  | 		for (c = 0; c < 3; c++) { | 
					
						
							| 
									
										
										
										
											2010-07-12 16:20:51 +00:00
										 |  |  | 			/* tweak to give more subtle results
 | 
					
						
							|  |  |  | 			 * values above 1.0 are scaled */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (cb.lift[c] > 1.0f) | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 				cb.lift[c] = pow(cb.lift[c] - 1.0f, 2.0) + 1.0; | 
					
						
							| 
									
										
										
										
											2010-07-12 16:20:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-05 14:53:11 +00:00
										 |  |  | 			cb.lift[c] = 2.0f - cb.lift[c]; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-05 09:56:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	if (cb.flag & SEQ_COLOR_BALANCE_INVERSE_GAIN) { | 
					
						
							|  |  |  | 		for (c = 0; c < 3; c++) { | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 			if (cb.gain[c] != 0.0f) { | 
					
						
							|  |  |  | 				cb.gain[c] = 1.0f / cb.gain[c]; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				cb.gain[c] = 1000000; /* should be enough :) */ | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!(cb.flag & SEQ_COLOR_BALANCE_INVERSE_GAMMA)) { | 
					
						
							|  |  |  | 		for (c = 0; c < 3; c++) { | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 			if (cb.gamma[c] != 0.0f) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				cb.gamma[c] = 1.0f / cb.gamma[c]; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				cb.gamma[c] = 1000000; /* should be enough :) */ | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return cb; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-06 10:21:28 +00:00
										 |  |  | /* note: lift is actually 2-lift */ | 
					
						
							| 
									
										
										
										
											2010-07-07 15:06:57 +00:00
										 |  |  | MINLINE float color_balance_fl(float in, const float lift, const float gain, const float gamma, const float mul) | 
					
						
							| 
									
										
										
										
											2010-07-05 09:56:06 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	float x = (((in - 1.0f) * lift) + 1.0f) * gain; | 
					
						
							| 
									
										
										
										
											2010-07-07 15:06:57 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* prevent NaN */ | 
					
						
							|  |  |  | 	if (x < 0.f) x = 0.f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return powf(x, gamma) * mul; | 
					
						
							| 
									
										
										
										
											2010-07-05 09:56:06 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | static void make_cb_table_byte(float lift, float gain, float gamma, | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  |                                unsigned char *table, float mul) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int y; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (y = 0; y < 256; y++) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		float v = color_balance_fl((float)y * (1.0f / 255.0f), lift, gain, gamma, mul); | 
					
						
							| 
									
										
										
										
											2012-05-28 10:39:22 +00:00
										 |  |  | 		table[y] = FTOCHAR(v); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void make_cb_table_float(float lift, float gain, float gamma, | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  |                                 float *table, float mul) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int y; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (y = 0; y < 256; y++) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		float v = color_balance_fl((float)y * (1.0f / 255.0f), lift, gain, gamma, mul); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		table[y] = v; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static void color_balance_byte_byte(Sequence *seq, ImBuf *ibuf, float mul) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	unsigned char cb_tab[3][256]; | 
					
						
							|  |  |  | 	int c; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	unsigned char *p = (unsigned char *) ibuf->rect; | 
					
						
							|  |  |  | 	unsigned char *e = p + ibuf->x * 4 * ibuf->y; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	StripColorBalance cb = calc_cb(seq->strip->color_balance); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (c = 0; c < 3; c++) { | 
					
						
							|  |  |  | 		make_cb_table_byte(cb.lift[c], cb.gain[c], cb.gamma[c], | 
					
						
							| 
									
										
										
										
											2011-11-11 13:09:14 +00:00
										 |  |  | 		                   cb_tab[c], mul); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	while (p < e) { | 
					
						
							|  |  |  | 		p[0] = cb_tab[0][p[0]]; | 
					
						
							|  |  |  | 		p[1] = cb_tab[1][p[1]]; | 
					
						
							|  |  |  | 		p[2] = cb_tab[2][p[2]]; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		p += 4; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static void color_balance_byte_float(Sequence *seq, ImBuf *ibuf, float mul) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float cb_tab[4][256]; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	int c, i; | 
					
						
							|  |  |  | 	unsigned char *p = (unsigned char *) ibuf->rect; | 
					
						
							|  |  |  | 	unsigned char *e = p + ibuf->x * 4 * ibuf->y; | 
					
						
							|  |  |  | 	float *o; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	StripColorBalance cb; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	imb_addrectfloatImBuf(ibuf); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	o = ibuf->rect_float; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	cb = calc_cb(seq->strip->color_balance); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (c = 0; c < 3; c++) { | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 		make_cb_table_float(cb.lift[c], cb.gain[c], cb.gamma[c], cb_tab[c], mul); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (i = 0; i < 256; i++) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		cb_tab[3][i] = ((float)i) * (1.0f / 255.0f); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	while (p < e) { | 
					
						
							|  |  |  | 		o[0] = cb_tab[0][p[0]]; | 
					
						
							|  |  |  | 		o[1] = cb_tab[1][p[1]]; | 
					
						
							|  |  |  | 		o[2] = cb_tab[2][p[2]]; | 
					
						
							|  |  |  | 		o[3] = cb_tab[3][p[3]]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		p += 4; o += 4; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static void color_balance_float_float(Sequence *seq, ImBuf *ibuf, float mul) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	float *p = ibuf->rect_float; | 
					
						
							|  |  |  | 	float *e = ibuf->rect_float + ibuf->x * 4 * ibuf->y; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	StripColorBalance cb = calc_cb(seq->strip->color_balance); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	while (p < e) { | 
					
						
							|  |  |  | 		int c; | 
					
						
							|  |  |  | 		for (c = 0; c < 3; c++) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			p[c] = color_balance_fl(p[c], cb.lift[c], cb.gain[c], cb.gamma[c], mul); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		p += 4; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static void color_balance(Sequence *seq, ImBuf *ibuf, float mul) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	if (ibuf->rect_float) { | 
					
						
							|  |  |  | 		color_balance_float_float(seq, ibuf, mul); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if (seq->flag & SEQ_MAKE_FLOAT) { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		color_balance_byte_float(seq, ibuf, mul); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		color_balance_byte_byte(seq, ibuf, mul); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  |  *  input preprocessing for SEQ_TYPE_IMAGE, SEQ_TYPE_MOVIE, SEQ_TYPE_MOVIECLIP and SEQ_TYPE_SCENE | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  *  Do all the things you can't really do afterwards using sequence effects | 
					
						
							|  |  |  |  *  (read: before rescaling to render resolution has been done) | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  Order is important! | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  - Deinterlace | 
					
						
							|  |  |  |  *  - Crop and transform in image source coordinate space | 
					
						
							|  |  |  |  *  - Flip X + Flip Y (could be done afterwards, backward compatibility) | 
					
						
							|  |  |  |  *  - Promote image to float data (affects pipeline operations afterwards) | 
					
						
							|  |  |  |  *  - Color balance (is most efficient in the byte -> float | 
					
						
							|  |  |  |  *    (future: half -> float should also work fine!) | 
					
						
							|  |  |  |  *    case, if done on load, since we can use lookup tables) | 
					
						
							|  |  |  |  *  - Premultiply | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | int input_have_to_preprocess( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:35:12 +00:00
										 |  |  |         SeqRenderData UNUSED(context), Sequence *seq, float UNUSED(cfra)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float mul; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (seq->flag & (SEQ_FILTERY | SEQ_USE_CROP | SEQ_USE_TRANSFORM | SEQ_FLIPX | | 
					
						
							| 
									
										
										
										
											2012-05-20 19:49:27 +00:00
										 |  |  | 	                 SEQ_FLIPY | SEQ_USE_COLOR_BALANCE | SEQ_MAKE_PREMUL)) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		return TRUE; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	mul = seq->mul; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->blend_mode == SEQ_BLEND_REPLACE) { | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 		mul *= seq->blend_opacity / 100.0f; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 	if (mul != 1.0f) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		return TRUE; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 	if (seq->sat != 1.0f) { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		return TRUE; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 	return FALSE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static ImBuf *input_preprocess( | 
					
						
							|  |  |  |         SeqRenderData context, Sequence *seq, float UNUSED(cfra), ImBuf *ibuf, | 
					
						
							|  |  |  |         int is_proxy_image, int is_preprocessed) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float mul; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	ibuf = IMB_makeSingleUser(ibuf); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if ((seq->flag & SEQ_FILTERY) && | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	    !ELEM(seq->type, SEQ_TYPE_MOVIE, SEQ_TYPE_MOVIECLIP)) | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		IMB_filtery(ibuf); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (seq->flag & (SEQ_USE_CROP | SEQ_USE_TRANSFORM)) { | 
					
						
							|  |  |  | 		StripCrop c = {0}; | 
					
						
							|  |  |  | 		StripTransform t = {0}; | 
					
						
							|  |  |  | 		int sx, sy, dx, dy; | 
					
						
							| 
									
										
										
										
											2012-03-18 11:13:28 +00:00
										 |  |  | 		double xscale = 1.0; | 
					
						
							|  |  |  | 		double yscale = 1.0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-18 11:13:28 +00:00
										 |  |  | 		if (is_proxy_image) { | 
					
						
							|  |  |  | 			double f = seq_rendersize_to_scale_factor( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			        context.preview_render_size); | 
					
						
							| 
									
										
										
										
											2012-03-17 19:31:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-18 11:13:28 +00:00
										 |  |  | 			if (f != 1.0) { | 
					
						
							|  |  |  | 				IMB_scalefastImBuf( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				        ibuf, ibuf->x / f, ibuf->y / f); | 
					
						
							| 
									
										
										
										
											2012-03-18 11:13:28 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-03-17 19:31:28 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->flag & SEQ_USE_CROP && seq->strip->crop) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			c = *seq->strip->crop; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->flag & SEQ_USE_TRANSFORM && seq->strip->transform) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			t = *seq->strip->transform; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-18 11:13:28 +00:00
										 |  |  | 		xscale = context.scene->r.xsch ?  | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		         ((double) context.rectx / | 
					
						
							|  |  |  | 		          (double) context.scene->r.xsch) : 1.0; | 
					
						
							| 
									
										
										
										
											2012-03-18 11:13:28 +00:00
										 |  |  | 		yscale = context.scene->r.ysch ?  | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		         ((double) context.recty / | 
					
						
							|  |  |  | 		          (double) context.scene->r.ysch) : 1.0; | 
					
						
							| 
									
										
										
										
											2012-03-18 11:13:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-18 19:32:26 +00:00
										 |  |  | 		c.left *= xscale; c.right *= xscale; | 
					
						
							| 
									
										
										
										
											2012-03-18 11:13:28 +00:00
										 |  |  | 		c.top *= yscale; c.bottom *= yscale; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		t.xofs *= xscale; t.yofs *= yscale; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		sx = ibuf->x - c.left - c.right; | 
					
						
							|  |  |  | 		sy = ibuf->y - c.top - c.bottom; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		dx = sx; | 
					
						
							|  |  |  | 		dy = sy; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (seq->flag & SEQ_USE_TRANSFORM) { | 
					
						
							| 
									
										
										
										
											2012-03-18 11:13:28 +00:00
										 |  |  | 			if (is_preprocessed) { | 
					
						
							|  |  |  | 				dx = context.rectx; | 
					
						
							|  |  |  | 				dy = context.recty; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2012-03-18 11:13:28 +00:00
										 |  |  | 				dx = context.scene->r.xsch; | 
					
						
							|  |  |  | 				dy = context.scene->r.ysch; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 19:49:27 +00:00
										 |  |  | 		if (c.top  + c.bottom >= ibuf->y || | 
					
						
							|  |  |  | 		    c.left + c.right  >= ibuf->x || | 
					
						
							|  |  |  | 		    t.xofs >= dx || t.yofs >= dy) | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 			make_black_ibuf(ibuf); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			ImBuf *i = IMB_allocImBuf( | 
					
						
							|  |  |  | 			        dx, dy, 32, | 
					
						
							|  |  |  | 			        ibuf->rect_float ? IB_rectfloat : IB_rect); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-18 11:13:28 +00:00
										 |  |  | 			IMB_rectcpy(i, ibuf,  | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			            t.xofs, t.yofs, c.left, c.bottom, sx, sy); | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			IMB_freeImBuf(ibuf); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 			ibuf = i; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->flag & SEQ_FLIPX) { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		IMB_flipx(ibuf); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-16 15:45:35 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->flag & SEQ_FLIPY) { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		IMB_flipy(ibuf); | 
					
						
							| 
									
										
										
										
											2010-07-16 15:45:35 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->sat != 1.0f) { | 
					
						
							| 
									
										
										
										
											2012-03-17 19:31:28 +00:00
										 |  |  | 		IMB_saturation(ibuf, seq->sat); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	mul = seq->mul; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->blend_mode == SEQ_BLEND_REPLACE) { | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 		mul *= seq->blend_opacity / 100.0f; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->flag & SEQ_USE_COLOR_BALANCE && seq->strip->color_balance) { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		color_balance(seq, ibuf, mul); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		mul = 1.0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->flag & SEQ_MAKE_FLOAT) { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		if (!ibuf->rect_float) | 
					
						
							|  |  |  | 			IMB_float_from_rect_simple(ibuf); | 
					
						
							| 
									
										
										
										
											2010-04-01 03:58:20 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		if (ibuf->rect) { | 
					
						
							|  |  |  | 			imb_freerectImBuf(ibuf); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (mul != 1.0f) { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		multibuf(ibuf, mul); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->flag & SEQ_MAKE_PREMUL) { | 
					
						
							|  |  |  | 		if (ibuf->planes == 32 && ibuf->zbuf == NULL) { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 			IMB_premultiply_alpha(ibuf); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (ibuf->x != context.rectx || ibuf->y != context.recty) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (context.scene->r.mode & R_OSA) { | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 			IMB_scaleImBuf(ibuf, (short)context.rectx, (short)context.recty); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 			IMB_scalefastImBuf(ibuf, (short)context.rectx, (short)context.recty); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	return ibuf; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static ImBuf *copy_from_ibuf_still(SeqRenderData context, Sequence *seq, | 
					
						
							|  |  |  |                                    float nr) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	ImBuf *rval = NULL; | 
					
						
							|  |  |  | 	ImBuf *ibuf = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	if (nr == 0) { | 
					
						
							|  |  |  | 		ibuf = seq_stripelem_cache_get( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		        context, seq, seq->start, | 
					
						
							|  |  |  | 		        SEQ_STRIPELEM_IBUF_STARTSTILL); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if (nr == seq->len - 1) { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		ibuf = seq_stripelem_cache_get( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		        context, seq, seq->start, | 
					
						
							|  |  |  | 		        SEQ_STRIPELEM_IBUF_ENDSTILL); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	if (ibuf) { | 
					
						
							|  |  |  | 		rval = IMB_dupImBuf(ibuf); | 
					
						
							|  |  |  | 		IMB_freeImBuf(ibuf); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return rval; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static void copy_to_ibuf_still(SeqRenderData context, Sequence *seq, float nr, | 
					
						
							|  |  |  |                                ImBuf *ibuf) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-04-17 10:05:27 +00:00
										 |  |  | 	if (nr == 0 || nr == seq->len - 1) { | 
					
						
							|  |  |  | 		/* we have to store a copy, since the passed ibuf
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  | 		 * could be preprocessed afterwards (thereby silently | 
					
						
							|  |  |  | 		 * changing the cached image... */ | 
					
						
							| 
									
										
										
										
											2011-04-17 10:05:27 +00:00
										 |  |  | 		ibuf = IMB_dupImBuf(ibuf); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (nr == 0) { | 
					
						
							|  |  |  | 			seq_stripelem_cache_put( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			        context, seq, seq->start, | 
					
						
							|  |  |  | 			        SEQ_STRIPELEM_IBUF_STARTSTILL, ibuf); | 
					
						
							| 
									
										
										
										
											2011-04-17 10:05:27 +00:00
										 |  |  | 		}  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (nr == seq->len - 1) { | 
					
						
							|  |  |  | 			seq_stripelem_cache_put( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			        context, seq, seq->start, | 
					
						
							|  |  |  | 			        SEQ_STRIPELEM_IBUF_ENDSTILL, ibuf); | 
					
						
							| 
									
										
										
										
											2011-04-17 10:05:27 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-12-17 08:08:35 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-17 10:05:27 +00:00
										 |  |  | 		IMB_freeImBuf(ibuf); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | /* **********************************************************************
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  |  * strip rendering functions | 
					
						
							|  |  |  |  * ********************************************************************** */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static ImBuf *seq_render_strip_stack( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:35:12 +00:00
										 |  |  |         SeqRenderData context, ListBase *seqbasep, float cfra, int chanshown); | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static ImBuf *seq_render_strip( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:35:12 +00:00
										 |  |  |         SeqRenderData context, Sequence *seq, float cfra); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static ImBuf *seq_render_effect_strip_impl( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:35:12 +00:00
										 |  |  |         SeqRenderData context, Sequence *seq, float cfra) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	float fac, facf; | 
					
						
							|  |  |  | 	int early_out; | 
					
						
							|  |  |  | 	int i; | 
					
						
							|  |  |  | 	struct SeqEffectHandle sh = get_sequence_effect(seq); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	FCurve *fcu = NULL; | 
					
						
							|  |  |  | 	ImBuf *ibuf[3]; | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	Sequence *input[3]; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	ImBuf *out = NULL; | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	ibuf[0] = ibuf[1] = ibuf[2] = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	input[0] = seq->seq1; input[1] = seq->seq2; input[2] = seq->seq3; | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (!sh.execute) { /* effect not supported in this version... */ | 
					
						
							| 
									
										
										
										
											2012-06-07 18:33:36 +00:00
										 |  |  | 		out = IMB_allocImBuf(context.rectx, context.recty, 32, IB_rect); | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 		return out; | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	if (seq->flag & SEQ_USE_EFFECT_DEFAULT_FADE) { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		sh.get_default_fac(seq, cfra, &fac, &facf); | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		if ((context.scene->r.mode & R_FIELDS) == 0) | 
					
						
							|  |  |  | 			facf = fac; | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
											
												3D Audio GSoC:
Implemented basic audio animation.
* AnimatableProperty: Propper cache writing and spline interpolation for reading (the solution for stair steps in audio animation)
* Animatable properties so far are: volume, pitch, panning
* Users note: Changing the pitch of a sound results in wrong seeking, due to the resulting playback length difference.
* Users note: Panning only works for mono sources, values are in the range [-2..2], this basically controls the angle of the sound, 0 is front, -1 left, 1 right and 2 and -2 are back. Typical stereo panning only supports [-1..1].
* Disabled animation of audio related ffmpeg output parameters.
* Scene Audio Panel: 3D Listener settings also for Renderer, new Volume property (animatable!), Update/Bake buttons for animation problems, moved sampling rate and channel count here
											
										 
											2011-07-28 13:58:59 +00:00
										 |  |  | 		fcu = id_data_find_fcurve(&context.scene->id, seq, &RNA_Sequence, "effect_fader", 0, NULL); | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		if (fcu) { | 
					
						
							|  |  |  | 			fac = facf = evaluate_fcurve(fcu, cfra); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			if (context.scene->r.mode & R_FIELDS) { | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 				facf = evaluate_fcurve(fcu, cfra + 0.5f); | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 			fac = facf = seq->effect_fader; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	early_out = sh.early_out(seq, fac, facf); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	switch (early_out) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		case EARLY_NO_INPUT: | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 			out = sh.execute(context, seq, cfra, fac, facf,   | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			                 NULL, NULL, NULL); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case EARLY_DO_EFFECT: | 
					
						
							|  |  |  | 			for (i = 0; i < 3; i++) { | 
					
						
							|  |  |  | 				if (input[i]) | 
					
						
							|  |  |  | 					ibuf[i] = seq_render_strip( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:35:12 +00:00
										 |  |  | 					        context, input[i], cfra); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			if (ibuf[0] && ibuf[1]) { | 
					
						
							|  |  |  | 				out = sh.execute(context, seq, cfra, fac, facf, | 
					
						
							|  |  |  | 				                 ibuf[0], ibuf[1], ibuf[2]); | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		case EARLY_USE_INPUT_1: | 
					
						
							|  |  |  | 			if (input[0]) { | 
					
						
							|  |  |  | 				ibuf[0] = seq_render_strip(context, input[0], cfra); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			if (ibuf[0]) { | 
					
						
							|  |  |  | 				if (input_have_to_preprocess(context, seq, cfra)) { | 
					
						
							|  |  |  | 					out = IMB_dupImBuf(ibuf[0]); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							|  |  |  | 					out = ibuf[0]; | 
					
						
							|  |  |  | 					IMB_refImBuf(out); | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		case EARLY_USE_INPUT_2: | 
					
						
							|  |  |  | 			if (input[1]) { | 
					
						
							|  |  |  | 				ibuf[1] = seq_render_strip(context, input[1], cfra); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			if (ibuf[1]) { | 
					
						
							|  |  |  | 				if (input_have_to_preprocess(context, seq, cfra)) { | 
					
						
							|  |  |  | 					out = IMB_dupImBuf(ibuf[1]); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							|  |  |  | 					out = ibuf[1]; | 
					
						
							|  |  |  | 					IMB_refImBuf(out); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	for (i = 0; i < 3; i++) { | 
					
						
							|  |  |  | 		IMB_freeImBuf(ibuf[i]); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	if (out == NULL) { | 
					
						
							| 
									
										
										
										
											2012-06-07 18:33:36 +00:00
										 |  |  | 		out = IMB_allocImBuf(context.rectx, context.recty, 32, IB_rect); | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	return out; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static ImBuf *seq_render_movieclip_strip( | 
					
						
							|  |  |  |         SeqRenderData context, Sequence *seq, float nr) | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	ImBuf *ibuf = NULL; | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 	MovieClipUser user; | 
					
						
							|  |  |  | 	float tloc[2], tscale, tangle; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (!seq->clip) { | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	memset(&user, 0, sizeof(MovieClipUser)); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	BKE_movieclip_user_set_frame(&user, nr + seq->anim_startofs); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	user.render_size = MCLIP_PROXY_RENDER_SIZE_FULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	switch (seq_rendersize_to_proxysize(context.preview_render_size)) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		case IMB_PROXY_NONE: | 
					
						
							|  |  |  | 			user.render_size = MCLIP_PROXY_RENDER_SIZE_FULL; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case IMB_PROXY_100: | 
					
						
							|  |  |  | 			user.render_size = MCLIP_PROXY_RENDER_SIZE_100; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case IMB_PROXY_75: | 
					
						
							|  |  |  | 			user.render_size = MCLIP_PROXY_RENDER_SIZE_75; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case IMB_PROXY_50: | 
					
						
							|  |  |  | 			user.render_size = MCLIP_PROXY_RENDER_SIZE_50; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case IMB_PROXY_25: | 
					
						
							|  |  |  | 			user.render_size = MCLIP_PROXY_RENDER_SIZE_25; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (seq->clip_flag & SEQ_MOVIECLIP_RENDER_UNDISTORTED) { | 
					
						
							|  |  |  | 		user.render_flag = MCLIP_PROXY_RENDER_UNDISTORT; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (seq->clip_flag & SEQ_MOVIECLIP_RENDER_STABILIZED) { | 
					
						
							|  |  |  | 		ibuf = BKE_movieclip_get_stable_ibuf( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		        seq->clip, &user, tloc, &tscale, &tangle, | 
					
						
							|  |  |  | 		        0); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 		ibuf = BKE_movieclip_get_ibuf_flag( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		        seq->clip, &user, 0, MOVIECLIP_CACHE_SKIP); | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return ibuf; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static ImBuf *seq_render_mask_strip( | 
					
						
							|  |  |  |         SeqRenderData context, Sequence *seq, float nr) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* TODO - add option to rasterize to alpha imbuf? */ | 
					
						
							|  |  |  | 	ImBuf *ibuf = NULL; | 
					
						
							|  |  |  | 	float *maskbuf; | 
					
						
							|  |  |  | 	int i; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!seq->mask) { | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-08 09:35:51 +00:00
										 |  |  | 	BKE_mask_evaluate(seq->mask, seq->mask->sfra + nr, TRUE); | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	maskbuf = MEM_callocN(sizeof(float) * context.rectx * context.recty, __func__); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (seq->flag & SEQ_MAKE_FLOAT) { | 
					
						
							|  |  |  | 		/* pixels */ | 
					
						
							|  |  |  | 		float *fp_src; | 
					
						
							|  |  |  | 		float *fp_dst; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		ibuf = IMB_allocImBuf(context.rectx, context.recty, 32, IB_rectfloat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		BKE_mask_rasterize(seq->mask, | 
					
						
							|  |  |  | 		                   context.rectx, context.recty, | 
					
						
							|  |  |  | 		                   maskbuf, | 
					
						
							| 
									
										
										
										
											2012-06-13 19:57:23 +00:00
										 |  |  | 		                   TRUE, | 
					
						
							| 
									
										
										
										
											2012-06-21 12:27:57 +00:00
										 |  |  | 		                   FALSE, /*XXX- TODO: make on/off for anti-aliasing */ | 
					
						
							|  |  |  | 		                   TRUE   /*XXX- TODO: make on/off for feather */ | 
					
						
							|  |  |  | 		                   ); | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		fp_src = maskbuf; | 
					
						
							|  |  |  | 		fp_dst = ibuf->rect_float; | 
					
						
							|  |  |  | 		i = context.rectx * context.recty; | 
					
						
							| 
									
										
										
										
											2012-06-27 18:29:47 +00:00
										 |  |  | 		while (--i) { | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | 			fp_dst[0] = fp_dst[1] = fp_dst[2] = *fp_src; | 
					
						
							|  |  |  | 			fp_dst[3] = 1.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			fp_src += 1; | 
					
						
							|  |  |  | 			fp_dst += 4; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* pixels */ | 
					
						
							|  |  |  | 		float *fp_src; | 
					
						
							|  |  |  | 		unsigned char *ub_dst; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		ibuf = IMB_allocImBuf(context.rectx, context.recty, 32, IB_rect); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		BKE_mask_rasterize(seq->mask, | 
					
						
							|  |  |  | 		                   context.rectx, context.recty, | 
					
						
							|  |  |  | 		                   maskbuf, | 
					
						
							| 
									
										
										
										
											2012-06-13 19:57:23 +00:00
										 |  |  | 		                   TRUE, | 
					
						
							| 
									
										
										
										
											2012-06-21 12:27:57 +00:00
										 |  |  | 		                   FALSE, /*XXX- TODO: make on/off for anti-aliasing */ | 
					
						
							|  |  |  | 		                   TRUE   /*XXX- TODO: make on/off for feather */ | 
					
						
							|  |  |  | 		                   ); | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		fp_src = maskbuf; | 
					
						
							|  |  |  | 		ub_dst = (unsigned char *)ibuf->rect; | 
					
						
							|  |  |  | 		i = context.rectx * context.recty; | 
					
						
							| 
									
										
										
										
											2012-06-27 18:29:47 +00:00
										 |  |  | 		while (--i) { | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | 			ub_dst[0] = ub_dst[1] = ub_dst[2] = (unsigned char)(*fp_src * 255.0f); /* already clamped */ | 
					
						
							|  |  |  | 			ub_dst[3] = 255; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			fp_src += 1; | 
					
						
							|  |  |  | 			ub_dst += 4; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	MEM_freeN(maskbuf); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return ibuf; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static ImBuf *seq_render_scene_strip( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:35:12 +00:00
										 |  |  |         SeqRenderData context, Sequence *seq, float nr) | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	ImBuf *ibuf = NULL; | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 	float frame; | 
					
						
							| 
									
										
										
										
											2010-07-30 11:40:23 +00:00
										 |  |  | 	float oldcfra; | 
					
						
							| 
									
										
										
										
											2011-04-30 05:42:37 +00:00
										 |  |  | 	Object *camera; | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	ListBase oldmarkers; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-10-21 17:00:38 +00:00
										 |  |  | 	/* Old info:
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  | 	 * Hack! This function can be called from do_render_seq(), in that case | 
					
						
							|  |  |  | 	 * the seq->scene can already have a Render initialized with same name, | 
					
						
							|  |  |  | 	 * so we have to use a default name. (compositor uses scene name to | 
					
						
							|  |  |  | 	 * find render). | 
					
						
							|  |  |  | 	 * However, when called from within the UI (image preview in sequencer) | 
					
						
							|  |  |  | 	 * we do want to use scene Render, that way the render result is defined | 
					
						
							|  |  |  | 	 * for display in render/imagewindow | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * Hmm, don't see, why we can't do that all the time, | 
					
						
							|  |  |  | 	 * and since G.rendering is uhm, gone... (Peter) | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-21 17:00:38 +00:00
										 |  |  | 	/* New info:
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  | 	 * Using the same name for the renders works just fine as the do_render_seq() | 
					
						
							|  |  |  | 	 * render is not used while the scene strips are rendered. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * However rendering from UI (through sequencer_preview_area_draw) can crash in | 
					
						
							|  |  |  | 	 * very many cases since other renders (material preview, an actual render etc.) | 
					
						
							|  |  |  | 	 * can be started while this sequence preview render is running. The only proper | 
					
						
							|  |  |  | 	 * solution is to make the sequencer preview render a proper job, which can be | 
					
						
							|  |  |  | 	 * stopped when needed. This would also give a nice progress bar for the preview | 
					
						
							|  |  |  | 	 * space so that users know there's something happening. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * As a result the active scene now only uses OpenGL rendering for the sequencer | 
					
						
							|  |  |  | 	 * preview. This is far from nice, but is the only way to prevent crashes at this | 
					
						
							|  |  |  | 	 * time. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * -jahka | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2010-10-21 17:00:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	int rendering = G.rendering; | 
					
						
							|  |  |  | 	int doseq; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	int doseq_gl = G.rendering ? /*(scene->r.seq_flag & R_SEQ_GL_REND)*/ 0 : /*(scene->r.seq_flag & R_SEQ_GL_PREV)*/ 1; | 
					
						
							|  |  |  | 	int have_seq = FALSE; | 
					
						
							| 
									
										
										
										
											2011-04-30 06:22:02 +00:00
										 |  |  | 	Scene *scene; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-18 07:38:51 +00:00
										 |  |  | 	/* don't refer to seq->scene above this point!, it can be NULL */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->scene == NULL) { | 
					
						
							| 
									
										
										
										
											2011-04-30 06:22:02 +00:00
										 |  |  | 		return NULL; | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	scene = seq->scene; | 
					
						
							|  |  |  | 	frame = scene->r.sfra + nr + seq->anim_startofs; | 
					
						
							| 
									
										
										
										
											2010-07-30 11:40:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	have_seq = (scene->r.scemode & R_DOSEQ) && scene->ed && scene->ed->seqbase.first; | 
					
						
							| 
									
										
										
										
											2011-04-30 06:22:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	oldcfra = scene->r.cfra; | 
					
						
							|  |  |  | 	scene->r.cfra = frame; | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->scene_camera)	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		camera = seq->scene_camera; | 
					
						
							| 
									
										
										
										
											2011-04-30 05:42:37 +00:00
										 |  |  | 	else {	 | 
					
						
							| 
									
										
										
										
											2012-05-05 14:33:36 +00:00
										 |  |  | 		BKE_scene_camera_switch_update(scene); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		camera = scene->camera; | 
					
						
							| 
									
										
										
										
											2011-04-30 05:42:37 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-04-30 06:22:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (have_seq == FALSE && camera == NULL) { | 
					
						
							|  |  |  | 		scene->r.cfra = oldcfra; | 
					
						
							| 
									
										
										
										
											2011-04-30 06:22:02 +00:00
										 |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* prevent eternal loop */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	doseq = context.scene->r.scemode & R_DOSEQ; | 
					
						
							| 
									
										
										
										
											2011-04-30 06:22:02 +00:00
										 |  |  | 	context.scene->r.scemode &= ~R_DOSEQ; | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | #ifdef DURIAN_CAMERA_SWITCH
 | 
					
						
							|  |  |  | 	/* stooping to new low's in hackyness :( */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	oldmarkers = scene->markers; | 
					
						
							|  |  |  | 	scene->markers.first = scene->markers.last = NULL; | 
					
						
							| 
									
										
										
										
											2011-11-05 14:26:18 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | 	(void)oldmarkers; | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (sequencer_view3d_cb && BLI_thread_is_main() && doseq_gl && (scene == context.scene || have_seq == 0) && camera) { | 
					
						
							|  |  |  | 		char err_out[256] = "unknown"; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		/* for old scened this can be uninitialized,
 | 
					
						
							|  |  |  | 		 * should probably be added to do_versions at some point if the functionality stays */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		if (context.scene->r.seq_prev_type == 0) | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 			context.scene->r.seq_prev_type = 3 /* ==OB_SOLID */;  | 
					
						
							| 
									
										
										
										
											2010-10-21 17:00:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		/* opengl offscreen render */ | 
					
						
							| 
									
										
										
										
											2012-05-05 14:33:36 +00:00
										 |  |  | 		BKE_scene_update_for_newframe(context.bmain, scene, scene->lay); | 
					
						
							| 
									
										
										
										
											2012-03-07 19:19:56 +00:00
										 |  |  | 		ibuf = sequencer_view3d_cb(scene, camera, context.rectx, context.recty, | 
					
						
							| 
									
										
										
										
											2012-03-08 16:27:53 +00:00
										 |  |  | 		                           IB_rect, context.scene->r.seq_prev_type, TRUE, err_out); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (ibuf == NULL) { | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 			fprintf(stderr, "seq_render_scene_strip failed to get opengl buffer: %s\n", err_out); | 
					
						
							| 
									
										
										
										
											2011-03-06 23:12:12 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2011-04-30 06:22:02 +00:00
										 |  |  | 		Render *re = RE_GetRender(scene->id.name); | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		RenderResult rres; | 
					
						
							| 
									
										
										
										
											2010-10-21 17:00:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* XXX: this if can be removed when sequence preview rendering uses the job system */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (rendering || context.scene != scene) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			if (re == NULL) | 
					
						
							|  |  |  | 				re = RE_NewRender(scene->id.name); | 
					
						
							| 
									
										
										
										
											2010-10-21 17:00:38 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2011-04-30 06:22:02 +00:00
										 |  |  | 			RE_BlenderFrame(re, context.bmain, scene, NULL, camera, scene->lay, frame, FALSE); | 
					
						
							| 
									
										
										
										
											2010-10-21 17:00:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			/* restore previous state after it was toggled on & off by RE_BlenderFrame */ | 
					
						
							|  |  |  | 			G.rendering = rendering; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		RE_AcquireResultImage(re, &rres); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (rres.rectf) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			ibuf = IMB_allocImBuf(rres.rectx, rres.recty, 32, IB_rectfloat); | 
					
						
							|  |  |  | 			memcpy(ibuf->rect_float, rres.rectf, 4 * sizeof(float) * rres.rectx * rres.recty); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (rres.rectz) { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 				addzbuffloatImBuf(ibuf); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				memcpy(ibuf->zbuf_float, rres.rectz, sizeof(float) * rres.rectx * rres.recty); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2010-07-30 11:55:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			/* float buffers in the sequencer are not linear */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (scene->r.color_mgt_flag & R_COLOR_MANAGEMENT) | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				ibuf->profile = IB_PROFILE_LINEAR_RGB; | 
					
						
							| 
									
										
										
										
											2011-12-28 20:11:36 +00:00
										 |  |  | 			else | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				ibuf->profile = IB_PROFILE_NONE; | 
					
						
							| 
									
										
										
										
											2010-07-30 11:55:41 +00:00
										 |  |  | 			IMB_convert_profile(ibuf, IB_PROFILE_SRGB);			 | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else if (rres.rect32) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			ibuf = IMB_allocImBuf(rres.rectx, rres.recty, 32, IB_rect); | 
					
						
							|  |  |  | 			memcpy(ibuf->rect, rres.rect32, 4 * rres.rectx * rres.recty); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		RE_ReleaseResultImage(re); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		// BIF_end_render_callbacks();
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* restore */ | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	context.scene->r.scemode |= doseq; | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-04-30 06:22:02 +00:00
										 |  |  | 	scene->r.cfra = oldcfra; | 
					
						
							| 
									
										
										
										
											2011-04-30 05:42:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (frame != oldcfra) | 
					
						
							| 
									
										
										
										
											2012-05-05 14:33:36 +00:00
										 |  |  | 		BKE_scene_update_for_newframe(context.bmain, scene, scene->lay); | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-03-10 08:17:18 +00:00
										 |  |  | #ifdef DURIAN_CAMERA_SWITCH
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	/* stooping to new low's in hackyness :( */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	scene->markers = oldmarkers; | 
					
						
							| 
									
										
										
										
											2010-03-10 08:17:18 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2010-03-08 21:33:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	return ibuf; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static ImBuf *seq_render_strip(SeqRenderData context, Sequence *seq, float cfra) | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	ImBuf *ibuf = NULL; | 
					
						
							| 
									
										
										
										
											2011-11-26 04:07:38 +00:00
										 |  |  | 	char name[FILE_MAX]; | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	int use_preprocess = input_have_to_preprocess(context, seq, cfra); | 
					
						
							| 
									
										
										
										
											2012-03-18 11:13:28 +00:00
										 |  |  | 	int is_proxy_image = FALSE; | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	float nr = give_stripelem_index(seq, cfra); | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	/* all effects are handled similarly with the exception of speed effect */ | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	int type = (seq->type & SEQ_TYPE_EFFECT && seq->type != SEQ_TYPE_SPEED) ? SEQ_TYPE_EFFECT : seq->type; | 
					
						
							|  |  |  | 	int is_preprocessed = !ELEM3(type, SEQ_TYPE_IMAGE, SEQ_TYPE_MOVIE, SEQ_TYPE_SCENE); | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	ibuf = seq_stripelem_cache_get(context, seq, cfra, SEQ_STRIPELEM_IBUF); | 
					
						
							| 
									
										
										
										
											2010-03-10 08:17:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-17 08:08:35 +00:00
										 |  |  | 	/* currently, we cache preprocessed images in SEQ_STRIPELEM_IBUF,
 | 
					
						
							| 
									
										
										
										
											2012-04-22 11:54:53 +00:00
										 |  |  | 	 * but not(!) on SEQ_STRIPELEM_IBUF_ENDSTILL and ..._STARTSTILL */ | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	if (ibuf) | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		use_preprocess = FALSE; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-17 08:08:35 +00:00
										 |  |  | 	if (ibuf == NULL) | 
					
						
							|  |  |  | 		ibuf = copy_from_ibuf_still(context, seq, nr); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 	/* MOVIECLIPs have their own proxy management */ | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (ibuf == NULL && seq->type != SEQ_TYPE_MOVIECLIP) { | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 		ibuf = seq_proxy_fetch(context, seq, cfra); | 
					
						
							| 
									
										
										
										
											2012-03-18 11:13:28 +00:00
										 |  |  | 		is_proxy_image = (ibuf != NULL); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (ibuf == NULL) switch (type) { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 			case SEQ_TYPE_META: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			{ | 
					
						
							|  |  |  | 				ImBuf *meta_ibuf = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				if (seq->seqbase.first) | 
					
						
							|  |  |  | 					meta_ibuf = seq_render_strip_stack( | 
					
						
							|  |  |  | 					        context, &seq->seqbase, | 
					
						
							|  |  |  | 					        seq->start + nr, 0); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				if (meta_ibuf) { | 
					
						
							|  |  |  | 					ibuf = meta_ibuf; | 
					
						
							|  |  |  | 					if (ibuf && use_preprocess) { | 
					
						
							|  |  |  | 						ImBuf *i = IMB_dupImBuf(ibuf); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 						IMB_freeImBuf(ibuf); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 						ibuf = i; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2012-03-18 11:13:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 			case SEQ_TYPE_SPEED: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			{ | 
					
						
							|  |  |  | 				ImBuf *child_ibuf = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				float f_cfra; | 
					
						
							|  |  |  | 				SpeedControlVars *s = (SpeedControlVars *)seq->effectdata; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				sequence_effect_speed_rebuild_map(context.scene, seq, 0); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				/* weeek! */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:35:12 +00:00
										 |  |  | 				f_cfra = seq->start + s->frameMap[(int)nr]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				child_ibuf = seq_render_strip(context, seq->seq1, f_cfra); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				if (child_ibuf) { | 
					
						
							|  |  |  | 					ibuf = child_ibuf; | 
					
						
							|  |  |  | 					if (ibuf && use_preprocess) { | 
					
						
							|  |  |  | 						ImBuf *i = IMB_dupImBuf(ibuf); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 						IMB_freeImBuf(ibuf); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 						ibuf = i; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 			case SEQ_TYPE_EFFECT: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			{ | 
					
						
							|  |  |  | 				ibuf = seq_render_effect_strip_impl( | 
					
						
							|  |  |  | 				        context, seq, seq->start + nr); | 
					
						
							|  |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 			case SEQ_TYPE_IMAGE: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			{ | 
					
						
							|  |  |  | 				StripElem *s_elem = give_stripelem(seq, cfra); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if (s_elem) { | 
					
						
							|  |  |  | 					BLI_join_dirfile(name, sizeof(name), seq->strip->dir, s_elem->name); | 
					
						
							|  |  |  | 					BLI_path_abs(name, G.main->name); | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				if (s_elem && (ibuf = IMB_loadiffname(name, IB_rect))) { | 
					
						
							|  |  |  | 					/* we don't need both (speed reasons)! */ | 
					
						
							|  |  |  | 					if (ibuf->rect_float && ibuf->rect) | 
					
						
							|  |  |  | 						imb_freerectImBuf(ibuf); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 					/* all sequencer color is done in SRGB space, linear gives odd crossfades */ | 
					
						
							|  |  |  | 					if (ibuf->profile == IB_PROFILE_LINEAR_RGB) | 
					
						
							|  |  |  | 						IMB_convert_profile(ibuf, IB_PROFILE_NONE); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 					copy_to_ibuf_still(context, seq, nr, ibuf); | 
					
						
							| 
									
										
										
										
											2010-11-28 18:23:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 					s_elem->orig_width  = ibuf->x; | 
					
						
							|  |  |  | 					s_elem->orig_height = ibuf->y; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 			case SEQ_TYPE_MOVIE: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			{ | 
					
						
							|  |  |  | 				seq_open_anim_file(seq); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if (seq->anim) { | 
					
						
							|  |  |  | 					IMB_anim_set_preseek(seq->anim, | 
					
						
							|  |  |  | 					                     seq->anim_preseek); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					ibuf = IMB_anim_absolute( | 
					
						
							|  |  |  | 					        seq->anim, nr + seq->anim_startofs, | 
					
						
							|  |  |  | 					        seq->strip->proxy ? | 
					
						
							|  |  |  | 					            seq->strip->proxy->tc : | 
					
						
							|  |  |  | 					            IMB_TC_RECORD_RUN, | 
					
						
							|  |  |  | 					        seq_rendersize_to_proxysize( | 
					
						
							|  |  |  | 					            context.preview_render_size)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					/* we don't need both (speed reasons)! */ | 
					
						
							|  |  |  | 					if (ibuf && ibuf->rect_float && ibuf->rect) | 
					
						
							|  |  |  | 						imb_freerectImBuf(ibuf); | 
					
						
							|  |  |  | 					if (ibuf) { | 
					
						
							|  |  |  | 						seq->strip->stripdata->orig_width = ibuf->x; | 
					
						
							|  |  |  | 						seq->strip->stripdata->orig_height = ibuf->y; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2010-11-28 18:23:21 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				copy_to_ibuf_still(context, seq, nr, ibuf); | 
					
						
							|  |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 			case SEQ_TYPE_SCENE: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			{ // scene can be NULL after deletions
 | 
					
						
							|  |  |  | 				ibuf = seq_render_scene_strip(context, seq, nr); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				/* Scene strips update all animation, so we need to restore original state.*/ | 
					
						
							|  |  |  | 				BKE_animsys_evaluate_all_animation(context.bmain, context.scene, cfra); | 
					
						
							| 
									
										
										
										
											2010-12-03 12:08:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				copy_to_ibuf_still(context, seq, nr, ibuf); | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 			case SEQ_TYPE_MOVIECLIP: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			{ | 
					
						
							|  |  |  | 				ibuf = seq_render_movieclip_strip(context, seq, nr); | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				if (ibuf && use_preprocess) { | 
					
						
							|  |  |  | 					ImBuf *i = IMB_dupImBuf(ibuf); | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 					IMB_freeImBuf(ibuf); | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 					ibuf = i; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				copy_to_ibuf_still(context, seq, nr, ibuf); | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | 		case SEQ_TYPE_MASK: | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			/* ibuf is alwats new */ | 
					
						
							|  |  |  | 			ibuf = seq_render_mask_strip(context, seq, nr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			copy_to_ibuf_still(context, seq, nr, ibuf); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	if (ibuf == NULL) | 
					
						
							| 
									
										
										
										
											2012-06-07 18:33:36 +00:00
										 |  |  | 		ibuf = IMB_allocImBuf(context.rectx, context.recty, 32, IB_rect); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	if (ibuf->x != context.rectx || ibuf->y != context.recty) | 
					
						
							| 
									
										
										
										
											2010-07-24 19:42:29 +00:00
										 |  |  | 		use_preprocess = TRUE; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	if (use_preprocess) | 
					
						
							| 
									
										
										
										
											2012-03-18 11:13:28 +00:00
										 |  |  | 		ibuf = input_preprocess(context, seq, cfra, ibuf,  | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		                        is_proxy_image, is_preprocessed); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	seq_stripelem_cache_put(context, seq, cfra, SEQ_STRIPELEM_IBUF, ibuf); | 
					
						
							| 
									
										
										
										
											2009-02-13 06:24:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	return ibuf; | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-02-13 06:24:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | /* **********************************************************************
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  |  * strip stack rendering functions | 
					
						
							|  |  |  |  * ********************************************************************** */ | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static int seq_must_swap_input_in_blend_mode(Sequence *seq) | 
					
						
							| 
									
										
										
										
											2010-03-14 16:36:41 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int swap_input = FALSE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* bad hack, to fix crazy input ordering of 
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  | 	 * those two effects */ | 
					
						
							| 
									
										
										
										
											2010-03-14 16:36:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (ELEM3(seq->blend_mode, SEQ_TYPE_ALPHAOVER, SEQ_TYPE_ALPHAUNDER, SEQ_TYPE_OVERDROP)) { | 
					
						
							| 
									
										
										
										
											2010-03-14 16:36:41 +00:00
										 |  |  | 		swap_input = TRUE; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return swap_input; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static int seq_get_early_out_for_blend_mode(Sequence *seq) | 
					
						
							| 
									
										
										
										
											2010-03-14 16:36:41 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	struct SeqEffectHandle sh = get_sequence_blend(seq); | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 	float facf = seq->blend_opacity / 100.0f; | 
					
						
							| 
									
										
										
										
											2010-03-14 16:36:41 +00:00
										 |  |  | 	int early_out = sh.early_out(seq, facf, facf); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	if (ELEM(early_out, EARLY_DO_EFFECT, EARLY_NO_INPUT)) { | 
					
						
							| 
									
										
										
										
											2010-03-14 16:36:41 +00:00
										 |  |  | 		return early_out; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (seq_must_swap_input_in_blend_mode(seq)) { | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 		if (early_out == EARLY_USE_INPUT_2) { | 
					
						
							|  |  |  | 			return EARLY_USE_INPUT_1; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else if (early_out == EARLY_USE_INPUT_1) { | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 			return EARLY_USE_INPUT_2; | 
					
						
							| 
									
										
										
										
											2010-03-14 16:36:41 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return early_out; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static ImBuf *seq_render_strip_stack( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:35:12 +00:00
										 |  |  |         SeqRenderData context, ListBase *seqbasep, float cfra, int chanshown) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	Sequence *seq_arr[MAXSEQ + 1]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	int count; | 
					
						
							|  |  |  | 	int i; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	ImBuf *out = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	count = get_shown_sequences(seqbasep, cfra, chanshown, (Sequence **)&seq_arr); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	if (count == 0) { | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-10 19:17:52 +00:00
										 |  |  | #if 0 /* commentind since this breaks keyframing, since it resets the value on draw */
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (scene->r.cfra != cfra) { | 
					
						
							| 
									
										
										
										
											2010-07-10 19:17:52 +00:00
										 |  |  | 		// XXX for prefetch and overlay offset!..., very bad!!!
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		AnimData *adt = BKE_animdata_from_id(&scene->id); | 
					
						
							| 
									
										
											  
											
												== RNA Property Updates get called by Animation System now ==
This fixes bug #26764 and several others like it, where modifier
properties (and others, but most visibly modifiers) would not do
anything when animated or driven, as modifier properties require the
RNA update calls to tag the modifiers to get recalculated.
While just adding a call to RNA_property_update() could have gotten
this working (as per the Campbell's patch attached in the report, and
also my own attempt #25881). However, on production rigs, the
performance cost of this is untenatable (on my own tests, without
these updates, I was getting ~5fps on such a rig, but only 0.9fps or
possibly even worse with the updates added).
Hence, this commit adds a property-update caching system to the RNA
level, which aims to reduce to the number of times that the update
functions end up needing to get called.
While this is much faster than without the caching, I also added an
optimisation for pose bones (which are numerous in production rigs) so
that their property updates are skipped, since they are useless to the
animsys (they only tag the depsgraph for updating). This gets things
moving at a more acceptable framerate.
											
										 
											2011-07-24 04:34:46 +00:00
										 |  |  | 		BKE_animsys_evaluate_animdata(scene, &scene->id, adt, cfra, ADT_RECALC_ANIM); | 
					
						
							| 
									
										
										
										
											2010-07-10 19:17:52 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	out = seq_stripelem_cache_get(context, seq_arr[count - 1],  | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	                              cfra, SEQ_STRIPELEM_IBUF_COMP); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	if (out) { | 
					
						
							|  |  |  | 		return out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (count == 1) { | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 		out = seq_render_strip(context, seq_arr[0], cfra); | 
					
						
							|  |  |  | 		seq_stripelem_cache_put(context, seq_arr[0], cfra,  | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		                        SEQ_STRIPELEM_IBUF_COMP, out); | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		return out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (i = count - 1; i >= 0; i--) { | 
					
						
							|  |  |  | 		int early_out; | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 		Sequence *seq = seq_arr[i]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 		out = seq_stripelem_cache_get( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		        context, seq, cfra, SEQ_STRIPELEM_IBUF_COMP); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		if (out) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		if (seq->blend_mode == SEQ_BLEND_REPLACE) { | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 			out = seq_render_strip(context, seq, cfra); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-14 16:36:41 +00:00
										 |  |  | 		early_out = seq_get_early_out_for_blend_mode(seq); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		switch (early_out) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			case EARLY_NO_INPUT: | 
					
						
							|  |  |  | 			case EARLY_USE_INPUT_2: | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 				out = seq_render_strip(context, seq, cfra); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				break; | 
					
						
							|  |  |  | 			case EARLY_USE_INPUT_1: | 
					
						
							|  |  |  | 				if (i == 0) { | 
					
						
							| 
									
										
										
										
											2012-06-07 18:33:36 +00:00
										 |  |  | 					out = IMB_allocImBuf(context.rectx, context.recty, 32, IB_rect); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case EARLY_DO_EFFECT: | 
					
						
							|  |  |  | 				if (i == 0) { | 
					
						
							|  |  |  | 					out = seq_render_strip(context, seq, cfra); | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		if (out) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	seq_stripelem_cache_put(context, seq_arr[i], cfra,  | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	                        SEQ_STRIPELEM_IBUF_COMP, out); | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	i++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (; i < count; i++) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		Sequence *seq = seq_arr[i]; | 
					
						
							| 
									
										
										
										
											2009-11-22 20:22:35 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 		if (seq_get_early_out_for_blend_mode(seq) == EARLY_DO_EFFECT) { | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 			struct SeqEffectHandle sh = get_sequence_blend(seq); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			ImBuf *ibuf1 = out; | 
					
						
							|  |  |  | 			ImBuf *ibuf2 = seq_render_strip(context, seq, cfra); | 
					
						
							| 
									
										
										
										
											2010-02-10 17:28:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 			float facf = seq->blend_opacity / 100.0f; | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 			int swap_input = seq_must_swap_input_in_blend_mode(seq); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			if (swap_input) { | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 				out = sh.execute(context, seq, cfra,  | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				                 facf, facf, | 
					
						
							|  |  |  | 				                 ibuf2, ibuf1, NULL); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 				out = sh.execute(context, seq, cfra,  | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				                 facf, facf, | 
					
						
							|  |  |  | 				                 ibuf1, ibuf2, NULL); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 			IMB_freeImBuf(ibuf1); | 
					
						
							|  |  |  | 			IMB_freeImBuf(ibuf2); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 		seq_stripelem_cache_put(context, seq_arr[i], cfra, | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		                        SEQ_STRIPELEM_IBUF_COMP, out); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	return out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * returned ImBuf is refed! | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  |  * you have to free after usage! | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | ImBuf *give_ibuf_seq(SeqRenderData context, float cfra, int chanshown) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | 	Editing *ed = BKE_sequencer_editing_get(context.scene, FALSE); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	int count; | 
					
						
							|  |  |  | 	ListBase *seqbasep; | 
					
						
							| 
									
										
										
										
											2009-01-28 22:36:34 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (ed == NULL) return NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	count = BLI_countlist(&ed->metastack); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if ((chanshown < 0) && (count > 0)) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		count = MAX2(count + chanshown, 0); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		seqbasep = ((MetaStack *)BLI_findlink(&ed->metastack, count))->oldbasep; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		seqbasep = ed->seqbasep; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	return seq_render_strip_stack(context, seqbasep, cfra, chanshown); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | ImBuf *give_ibuf_seqbase(SeqRenderData context, float cfra, int chanshown, ListBase *seqbasep) | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This adds MULTICAM-editing support for blender. (Well, the beginning of.)
There is now a new effect track, named MULTICAM, which just selects
one of the lower tracks.
Doesn't sound that exciting, but if you combine this with A/B-Trim (moving
split points of two directly connected tracks around, while magically
resizing both strips, something to be added), you just do:
* add several tracks for your camera angles
* (optionally) sync those tracks
* add one multicam track on top
Use that multicam-track to edit your movie. (Either using fcurves on the
multicam source selector or using knife-tool and A/B-Trim.)
Compare that to:
* add several tracks
* add cross fades between them
* do some python scripting to add several fcurves to make that beast
  somewhat work.
* cry out loud, using it, if you have to move cut points around
Alternatively, even harder:
* just edit the old way and put strip after strip
You might think, that this isn't really helpfull for animators, but
consider using scene-strips (in OpenGL-mode) for input, that are set for
different camera angles and can now be intercut a lot more easily...
Also: small fix on the way: the speed effect can now be used in cascade.
(Don't know, if anyone used it that way, but now it works.)
											
										 
											2010-04-25 12:53:39 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	return seq_render_strip_stack(context, seqbasep, cfra, chanshown); | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This adds MULTICAM-editing support for blender. (Well, the beginning of.)
There is now a new effect track, named MULTICAM, which just selects
one of the lower tracks.
Doesn't sound that exciting, but if you combine this with A/B-Trim (moving
split points of two directly connected tracks around, while magically
resizing both strips, something to be added), you just do:
* add several tracks for your camera angles
* (optionally) sync those tracks
* add one multicam track on top
Use that multicam-track to edit your movie. (Either using fcurves on the
multicam source selector or using knife-tool and A/B-Trim.)
Compare that to:
* add several tracks
* add cross fades between them
* do some python scripting to add several fcurves to make that beast
  somewhat work.
* cry out loud, using it, if you have to move cut points around
Alternatively, even harder:
* just edit the old way and put strip after strip
You might think, that this isn't really helpfull for animators, but
consider using scene-strips (in OpenGL-mode) for input, that are set for
different camera angles and can now be intercut a lot more easily...
Also: small fix on the way: the speed effect can now be used in cascade.
(Don't know, if anyone used it that way, but now it works.)
											
										 
											2010-04-25 12:53:39 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | ImBuf *give_ibuf_seq_direct(SeqRenderData context, float cfra, Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	return seq_render_strip(context, seq, cfra); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-11 09:59:51 +00:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | /* check used when we need to change seq->blend_mode but not to effect or audio strips */ | 
					
						
							| 
									
										
										
										
											2009-09-14 16:52:06 +00:00
										 |  |  | static int seq_can_blend(Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (ELEM4(seq->type, SEQ_TYPE_IMAGE, SEQ_TYPE_META, SEQ_TYPE_SCENE, SEQ_TYPE_MOVIE)) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		return 1; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-11-11 09:59:51 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* *********************** threading api ******************* */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static ListBase running_threads; | 
					
						
							|  |  |  | static ListBase prefetch_wait; | 
					
						
							|  |  |  | static ListBase prefetch_done; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static pthread_mutex_t queue_lock          = PTHREAD_MUTEX_INITIALIZER; | 
					
						
							|  |  |  | static pthread_mutex_t wakeup_lock         = PTHREAD_MUTEX_INITIALIZER; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static pthread_cond_t wakeup_cond          = PTHREAD_COND_INITIALIZER; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-11 09:59:51 +00:00
										 |  |  | //static pthread_mutex_t prefetch_ready_lock = PTHREAD_MUTEX_INITIALIZER;
 | 
					
						
							|  |  |  | //static pthread_cond_t  prefetch_ready_cond = PTHREAD_COND_INITIALIZER;
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static pthread_mutex_t frame_done_lock     = PTHREAD_MUTEX_INITIALIZER; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static pthread_cond_t frame_done_cond      = PTHREAD_COND_INITIALIZER; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-01 11:51:56 +00:00
										 |  |  | static volatile int seq_thread_shutdown = TRUE;  | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | static volatile int seq_last_given_monoton_cfra = 0; | 
					
						
							|  |  |  | static int monoton_cfra = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct PrefetchThread { | 
					
						
							|  |  |  | 	struct PrefetchThread *next, *prev; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	Scene *scene; | 
					
						
							|  |  |  | 	struct PrefetchQueueElem *current; | 
					
						
							|  |  |  | 	pthread_t pthread; | 
					
						
							|  |  |  | 	int running; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | } PrefetchThread; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct PrefetchQueueElem { | 
					
						
							|  |  |  | 	struct PrefetchQueueElem *next, *prev; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	int rectx; | 
					
						
							|  |  |  | 	int recty; | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	float cfra; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	int chanshown; | 
					
						
							| 
									
										
										
										
											2010-11-01 18:55:12 +00:00
										 |  |  | 	int preview_render_size; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	int monoton_cfra; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	ImBuf *ibuf; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } PrefetchQueueElem; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-11 09:59:51 +00:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static void *seq_prefetch_thread(void *This_) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	PrefetchThread *This = This_; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	while (!seq_thread_shutdown) { | 
					
						
							|  |  |  | 		PrefetchQueueElem *e; | 
					
						
							|  |  |  | 		int s_last; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		pthread_mutex_lock(&queue_lock); | 
					
						
							|  |  |  | 		e = prefetch_wait.first; | 
					
						
							|  |  |  | 		if (e) { | 
					
						
							|  |  |  | 			BLI_remlink(&prefetch_wait, e); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		s_last = seq_last_given_monoton_cfra; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		This->current = e; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		pthread_mutex_unlock(&queue_lock); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (!e) { | 
					
						
							|  |  |  | 			pthread_mutex_lock(&prefetch_ready_lock); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			This->running = FALSE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			pthread_cond_signal(&prefetch_ready_cond); | 
					
						
							|  |  |  | 			pthread_mutex_unlock(&prefetch_ready_lock); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			pthread_mutex_lock(&wakeup_lock); | 
					
						
							|  |  |  | 			if (!seq_thread_shutdown) { | 
					
						
							|  |  |  | 				pthread_cond_wait(&wakeup_cond, &wakeup_lock); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			pthread_mutex_unlock(&wakeup_lock); | 
					
						
							|  |  |  | 			continue; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		This->running = TRUE; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if (e->cfra >= s_last) {  | 
					
						
							|  |  |  | 			e->ibuf = give_ibuf_seq_impl(This->scene,  | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			                             e->rectx, e->recty, e->cfra, e->chanshown, | 
					
						
							|  |  |  | 			                             e->preview_render_size); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		pthread_mutex_lock(&queue_lock); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		BLI_addtail(&prefetch_done, e); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for (e = prefetch_wait.first; e; e = e->next) { | 
					
						
							|  |  |  | 			if (s_last > e->monoton_cfra) { | 
					
						
							|  |  |  | 				BLI_remlink(&prefetch_wait, e); | 
					
						
							|  |  |  | 				MEM_freeN(e); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for (e = prefetch_done.first; e; e = e->next) { | 
					
						
							|  |  |  | 			if (s_last > e->monoton_cfra) { | 
					
						
							|  |  |  | 				BLI_remlink(&prefetch_done, e); | 
					
						
							|  |  |  | 				MEM_freeN(e); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		pthread_mutex_unlock(&queue_lock); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		pthread_mutex_lock(&frame_done_lock); | 
					
						
							|  |  |  | 		pthread_cond_signal(&frame_done_cond); | 
					
						
							|  |  |  | 		pthread_mutex_unlock(&frame_done_lock); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-14 16:52:06 +00:00
										 |  |  | static void seq_start_threads(Scene *scene) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int i; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	running_threads.first = running_threads.last = NULL; | 
					
						
							|  |  |  | 	prefetch_wait.first = prefetch_wait.last = NULL; | 
					
						
							|  |  |  | 	prefetch_done.first = prefetch_done.last = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	seq_thread_shutdown = FALSE; | 
					
						
							|  |  |  | 	seq_last_given_monoton_cfra = monoton_cfra = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* since global structures are modified during the processing
 | 
					
						
							| 
									
										
										
										
											2012-04-22 11:54:53 +00:00
										 |  |  | 	 * of one frame, only one render thread is currently possible... | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * (but we code, in the hope, that we can remove this restriction | 
					
						
							|  |  |  | 	 * soon...) | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	fprintf(stderr, "SEQ-THREAD: seq_start_threads\n"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (i = 0; i < 1; i++) { | 
					
						
							|  |  |  | 		PrefetchThread *t = MEM_callocN(sizeof(PrefetchThread), "prefetch_thread"); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		t->scene = scene; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		t->running = TRUE; | 
					
						
							|  |  |  | 		BLI_addtail(&running_threads, t); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		pthread_create(&t->pthread, NULL, seq_prefetch_thread, t); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* init malloc mutex */ | 
					
						
							|  |  |  | 	BLI_init_threads(0, 0, 0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-14 16:52:06 +00:00
										 |  |  | static void seq_stop_threads() | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PrefetchThread *tslot; | 
					
						
							|  |  |  | 	PrefetchQueueElem *e; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	fprintf(stderr, "SEQ-THREAD: seq_stop_threads()\n"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (seq_thread_shutdown) { | 
					
						
							|  |  |  | 		fprintf(stderr, "SEQ-THREAD: ... already stopped\n"); | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	pthread_mutex_lock(&wakeup_lock); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	seq_thread_shutdown = TRUE; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-13 20:54:36 +00:00
										 |  |  | 	pthread_cond_broadcast(&wakeup_cond); | 
					
						
							|  |  |  | 	pthread_mutex_unlock(&wakeup_lock); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (tslot = running_threads.first; tslot; tslot = tslot->next) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		pthread_join(tslot->pthread, NULL); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (e = prefetch_wait.first; e; e = e->next) { | 
					
						
							|  |  |  | 		BLI_remlink(&prefetch_wait, e); | 
					
						
							|  |  |  | 		MEM_freeN(e); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (e = prefetch_done.first; e; e = e->next) { | 
					
						
							|  |  |  | 		BLI_remlink(&prefetch_done, e); | 
					
						
							|  |  |  | 		MEM_freeN(e); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	BLI_freelistN(&running_threads); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* deinit malloc mutex */ | 
					
						
							|  |  |  | 	BLI_end_threads(0); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-11-11 09:59:51 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | void give_ibuf_prefetch_request(SeqRenderData context, float cfra, int chanshown) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PrefetchQueueElem *e; | 
					
						
							|  |  |  | 	if (seq_thread_shutdown) { | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	e = MEM_callocN(sizeof(PrefetchQueueElem), "prefetch_queue_elem"); | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	e->rectx = context.rectx; | 
					
						
							|  |  |  | 	e->recty = context.recty; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	e->cfra = cfra; | 
					
						
							|  |  |  | 	e->chanshown = chanshown; | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	e->preview_render_size = context.preview_render_size; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	e->monoton_cfra = monoton_cfra++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	pthread_mutex_lock(&queue_lock); | 
					
						
							|  |  |  | 	BLI_addtail(&prefetch_wait, e); | 
					
						
							|  |  |  | 	pthread_mutex_unlock(&queue_lock); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	pthread_mutex_lock(&wakeup_lock); | 
					
						
							|  |  |  | 	pthread_cond_signal(&wakeup_cond); | 
					
						
							|  |  |  | 	pthread_mutex_unlock(&wakeup_lock); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-11 09:59:51 +00:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2009-09-14 16:52:06 +00:00
										 |  |  | static void seq_wait_for_prefetch_ready() | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PrefetchThread *tslot; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (seq_thread_shutdown) { | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	fprintf(stderr, "SEQ-THREAD: rendering prefetch frames...\n"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	pthread_mutex_lock(&prefetch_ready_lock); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (;; ) { | 
					
						
							|  |  |  | 		for (tslot = running_threads.first; tslot; tslot = tslot->next) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			if (tslot->running) { | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		if (!tslot) { | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		pthread_cond_wait(&prefetch_ready_cond, &prefetch_ready_lock); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	pthread_mutex_unlock(&prefetch_ready_lock); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	fprintf(stderr, "SEQ-THREAD: prefetch done\n"); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-11-11 09:59:51 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | ImBuf *give_ibuf_seq_threaded(SeqRenderData context, float cfra, int chanshown) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PrefetchQueueElem *e = NULL; | 
					
						
							|  |  |  | 	int found_something = FALSE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (seq_thread_shutdown) { | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 		return give_ibuf_seq(context, cfra, chanshown); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	while (!e) { | 
					
						
							|  |  |  | 		int success = FALSE; | 
					
						
							|  |  |  | 		pthread_mutex_lock(&queue_lock); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for (e = prefetch_done.first; e; e = e->next) { | 
					
						
							|  |  |  | 			if (cfra == e->cfra && | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			    chanshown == e->chanshown && | 
					
						
							|  |  |  | 			    context.rectx == e->rectx && | 
					
						
							|  |  |  | 			    context.recty == e->recty && | 
					
						
							|  |  |  | 			    context.preview_render_size == e->preview_render_size) | 
					
						
							|  |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				success = TRUE; | 
					
						
							|  |  |  | 				found_something = TRUE; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (!e) { | 
					
						
							|  |  |  | 			for (e = prefetch_wait.first; e; e = e->next) { | 
					
						
							|  |  |  | 				if (cfra == e->cfra && | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				    chanshown == e->chanshown && | 
					
						
							|  |  |  | 				    context.rectx == e->rectx && | 
					
						
							|  |  |  | 				    context.recty == e->recty && | 
					
						
							|  |  |  | 				    context.preview_render_size == e->preview_render_size) | 
					
						
							|  |  |  | 				{ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 					found_something = TRUE; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (!e) { | 
					
						
							|  |  |  | 			PrefetchThread *tslot; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-23 02:17:50 +00:00
										 |  |  | 			for (tslot = running_threads.first; | 
					
						
							|  |  |  | 			     tslot; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			     tslot = tslot->next) | 
					
						
							| 
									
										
										
										
											2012-02-23 02:17:50 +00:00
										 |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				if (tslot->current && | 
					
						
							| 
									
										
										
										
											2012-02-23 02:17:50 +00:00
										 |  |  | 				    cfra == tslot->current->cfra && | 
					
						
							|  |  |  | 				    chanshown == tslot->current->chanshown && | 
					
						
							|  |  |  | 				    context.rectx == tslot->current->rectx && | 
					
						
							|  |  |  | 				    context.recty == tslot->current->recty && | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				    context.preview_render_size == tslot->current->preview_render_size) | 
					
						
							| 
									
										
										
										
											2012-02-23 02:17:50 +00:00
										 |  |  | 				{ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 					found_something = TRUE; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* e->ibuf is unrefed by render thread on next round. */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (e) { | 
					
						
							|  |  |  | 			seq_last_given_monoton_cfra = e->monoton_cfra; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		pthread_mutex_unlock(&queue_lock); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (!success) { | 
					
						
							|  |  |  | 			e = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if (!found_something) { | 
					
						
							|  |  |  | 				fprintf(stderr,  | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				        "SEQ-THREAD: Requested frame " | 
					
						
							|  |  |  | 				        "not in queue ???\n"); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			pthread_mutex_lock(&frame_done_lock); | 
					
						
							|  |  |  | 			pthread_cond_wait(&frame_done_cond, &frame_done_lock); | 
					
						
							|  |  |  | 			pthread_mutex_unlock(&frame_done_lock); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 	return e ? e->ibuf : NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Functions to free imbuf and anim data on changes */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void free_anim_seq(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->anim) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		IMB_free_anim(seq->anim); | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 		seq->anim = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | void free_imbuf_seq(Scene *scene, ListBase *seqbase, int check_mem_usage, | 
					
						
							|  |  |  |                     int keep_file_handles) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							| 
									
										
										
										
											2009-08-02 23:02:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (check_mem_usage) { | 
					
						
							|  |  |  | 		/* Let the cache limitor take care of this (schlaile) */ | 
					
						
							|  |  |  | 		/* While render let's keep all memory available for render 
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  | 		 * (ton) | 
					
						
							|  |  |  | 		 * At least if free memory is tight... | 
					
						
							|  |  |  | 		 * This can make a big difference in encoding speed | 
					
						
							|  |  |  | 		 * (it is around 4 times(!) faster, if we do not waste time | 
					
						
							|  |  |  | 		 * on freeing _all_ buffers every time on long timelines...) | 
					
						
							|  |  |  | 		 * (schlaile) | 
					
						
							|  |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2009-08-02 23:02:59 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 		uintptr_t mem_in_use; | 
					
						
							|  |  |  | 		uintptr_t mmap_in_use; | 
					
						
							|  |  |  | 		uintptr_t max; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		mem_in_use = MEM_get_memory_in_use(); | 
					
						
							|  |  |  | 		mmap_in_use = MEM_get_mapped_memory_in_use(); | 
					
						
							| 
									
										
										
										
											2009-08-02 23:02:59 +00:00
										 |  |  | 		max = MEM_CacheLimiter_get_maximum(); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		if (max == 0 || mem_in_use + mmap_in_use <= max) { | 
					
						
							|  |  |  | 			return; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	seq_stripelem_cache_cleanup(); | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = seqbase->first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->strip) { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 			if (seq->type == SEQ_TYPE_MOVIE && !keep_file_handles) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				free_anim_seq(seq); | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 			if (seq->type == SEQ_TYPE_SPEED) { | 
					
						
							| 
									
										
										
										
											2009-11-14 14:58:19 +00:00
										 |  |  | 				sequence_effect_speed_rebuild_map(scene, seq, 1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		if (seq->type == SEQ_TYPE_META) { | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 			free_imbuf_seq(scene, &seq->seqbase, FALSE, keep_file_handles); | 
					
						
							| 
									
										
										
										
											2009-08-02 23:02:59 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		if (seq->type == SEQ_TYPE_SCENE) { | 
					
						
							| 
									
										
										
										
											2009-08-02 23:02:59 +00:00
										 |  |  | 			/* FIXME: recurs downwards, 
 | 
					
						
							| 
									
										
										
										
											2012-04-22 11:54:53 +00:00
										 |  |  | 			 * but do recurs protection somehow! */ | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int update_changed_seq_recurs(Scene *scene, Sequence *seq, Sequence *changed_seq, int len_change, int ibuf_change) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Sequence *subseq; | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	int free_imbuf = 0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* recurs downwards to see if this seq depends on the changed seq */ | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq == NULL) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq == changed_seq) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		free_imbuf = 1; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (subseq = seq->seqbase.first; subseq; subseq = subseq->next) | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (update_changed_seq_recurs(scene, subseq, changed_seq, len_change, ibuf_change)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			free_imbuf = TRUE; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->seq1) | 
					
						
							|  |  |  | 		if (update_changed_seq_recurs(scene, seq->seq1, changed_seq, len_change, ibuf_change)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			free_imbuf = TRUE; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->seq2 && (seq->seq2 != seq->seq1)) | 
					
						
							|  |  |  | 		if (update_changed_seq_recurs(scene, seq->seq2, changed_seq, len_change, ibuf_change)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			free_imbuf = TRUE; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq->seq3 && (seq->seq3 != seq->seq1) && (seq->seq3 != seq->seq2)) | 
					
						
							|  |  |  | 		if (update_changed_seq_recurs(scene, seq->seq3, changed_seq, len_change, ibuf_change)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			free_imbuf = TRUE; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (free_imbuf) { | 
					
						
							|  |  |  | 		if (ibuf_change) { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 			if (seq->type == SEQ_TYPE_MOVIE) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				free_anim_seq(seq); | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 			if (seq->type == SEQ_TYPE_SPEED) { | 
					
						
							| 
									
										
										
										
											2009-11-14 14:58:19 +00:00
										 |  |  | 				sequence_effect_speed_rebuild_map(scene, seq, 1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (len_change) | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 			calc_sequence(scene, seq); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return free_imbuf; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void update_changed_seq_and_deps(Scene *scene, Sequence *changed_seq, int len_change, int ibuf_change) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | 	Editing *ed = BKE_sequencer_editing_get(scene, FALSE); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	Sequence *seq; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (ed == NULL) return; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = ed->seqbase.first; seq; seq = seq->next) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		update_changed_seq_recurs(scene, seq, changed_seq, len_change, ibuf_change); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | /* seq funcs's for transforming internally
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  |  * notice the difference between start/end and left/right. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * left and right are the bounds at which the sequence is rendered, | 
					
						
							|  |  |  |  * start and end are from the start and fixed length of the sequence. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-09-28 05:53:40 +00:00
										 |  |  | int seq_tx_get_start(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 	return seq->start; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | int seq_tx_get_end(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	return seq->start + seq->len; | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int seq_tx_get_final_left(Sequence *seq, int metaclip) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (metaclip && seq->tmp) { | 
					
						
							|  |  |  | 		/* return the range clipped by the parents range */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		return MAX2(seq_tx_get_final_left(seq, 0), seq_tx_get_final_left((Sequence *)seq->tmp, 1) ); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 		return (seq->start - seq->startstill) + seq->startofs; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | int seq_tx_get_final_right(Sequence *seq, int metaclip) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (metaclip && seq->tmp) { | 
					
						
							|  |  |  | 		/* return the range clipped by the parents range */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		return MIN2(seq_tx_get_final_right(seq, 0), seq_tx_get_final_right((Sequence *)seq->tmp, 1) ); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		return ((seq->start + seq->len) + seq->endstill) - seq->endofs; | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void seq_tx_set_final_left(Sequence *seq, int val) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (val < (seq)->start) { | 
					
						
							|  |  |  | 		seq->startstill = abs(val - (seq)->start); | 
					
						
							| 
									
										
										
										
											2009-10-19 10:07:19 +00:00
										 |  |  | 		seq->startofs = 0; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 		seq->startofs = abs(val - (seq)->start); | 
					
						
							|  |  |  | 		seq->startstill = 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void seq_tx_set_final_right(Sequence *seq, int val) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (val > (seq)->start + (seq)->len) { | 
					
						
							|  |  |  | 		seq->endstill = abs(val - (seq->start + (seq)->len)); | 
					
						
							| 
									
										
										
										
											2009-10-19 10:07:19 +00:00
										 |  |  | 		seq->endofs = 0; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 		seq->endofs = abs(val - ((seq)->start + (seq)->len)); | 
					
						
							|  |  |  | 		seq->endstill = 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* used so we can do a quick check for single image seq
 | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  |  * since they work a bit differently to normal image seq's (during transform) */ | 
					
						
							| 
									
										
										
										
											2009-12-15 11:27:46 +00:00
										 |  |  | int seq_single_check(Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-21 15:11:03 +00:00
										 |  |  | 	return ((seq->len == 1) && | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	        (seq->type == SEQ_TYPE_IMAGE || | 
					
						
							|  |  |  | 	         ((seq->type & SEQ_TYPE_EFFECT) && | 
					
						
							| 
									
										
										
										
											2012-04-21 15:11:03 +00:00
										 |  |  | 	          get_sequence_effect_num_inputs(seq->type) == 0))); | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-17 23:29:11 +00:00
										 |  |  | /* check if the selected seq's reference unselected seq's */ | 
					
						
							|  |  |  | int seqbase_isolated_sel_check(ListBase *seqbase) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							|  |  |  | 	/* is there more than 1 select */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	int ok = FALSE; | 
					
						
							| 
									
										
										
										
											2009-12-17 23:29:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = seqbase->first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->flag & SELECT) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			ok = TRUE; | 
					
						
							| 
									
										
										
										
											2009-12-17 23:29:11 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (ok == FALSE) | 
					
						
							| 
									
										
										
										
											2009-12-17 23:29:11 +00:00
										 |  |  | 		return FALSE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* test relationships */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = seqbase->first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		if ((seq->type & SEQ_TYPE_EFFECT) == 0) | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 			continue; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->flag & SELECT) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			if ( (seq->seq1 && (seq->seq1->flag & SELECT) == 0) || | 
					
						
							|  |  |  | 			     (seq->seq2 && (seq->seq2->flag & SELECT) == 0) || | 
					
						
							|  |  |  | 			     (seq->seq3 && (seq->seq3->flag & SELECT) == 0) ) | 
					
						
							| 
									
										
										
										
											2012-04-28 06:31:57 +00:00
										 |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 				return FALSE; | 
					
						
							| 
									
										
										
										
											2012-04-28 06:31:57 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-12-17 23:29:11 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if ( (seq->seq1 && (seq->seq1->flag & SELECT)) || | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			     (seq->seq2 && (seq->seq2->flag & SELECT)) || | 
					
						
							|  |  |  | 			     (seq->seq3 && (seq->seq3->flag & SELECT)) ) | 
					
						
							| 
									
										
										
										
											2012-04-28 06:31:57 +00:00
										 |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 				return FALSE; | 
					
						
							| 
									
										
										
										
											2012-04-28 06:31:57 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-12-17 23:29:11 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return TRUE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-18 07:38:51 +00:00
										 |  |  | /* use to impose limits when dragging/extending - so impossible situations don't happen
 | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  |  * Cant use the SEQ_LEFTSEL and SEQ_LEFTSEL directly because the strip may be in a metastrip */ | 
					
						
							|  |  |  | void seq_tx_handle_xlimits(Sequence *seq, int leftflag, int rightflag) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (leftflag) { | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 		if (seq_tx_get_final_left(seq, 0) >= seq_tx_get_final_right(seq, 0)) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			seq_tx_set_final_left(seq, seq_tx_get_final_right(seq, 0) - 1); | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		if (seq_single_check(seq) == 0) { | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 			if (seq_tx_get_final_left(seq, 0) >= seq_tx_get_end(seq)) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				seq_tx_set_final_left(seq, seq_tx_get_end(seq) - 1); | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/* dosnt work now - TODO */ | 
					
						
							| 
									
										
										
										
											2012-03-03 20:19:11 +00:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 			if (seq_tx_get_start(seq) >= seq_tx_get_final_right(seq, 0)) { | 
					
						
							|  |  |  | 				int ofs; | 
					
						
							|  |  |  | 				ofs = seq_tx_get_start(seq) - seq_tx_get_final_right(seq, 0); | 
					
						
							|  |  |  | 				seq->start -= ofs; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				seq_tx_set_final_left(seq, seq_tx_get_final_left(seq, 0) + ofs); | 
					
						
							| 
									
										
										
										
											2012-03-03 20:19:11 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (rightflag) { | 
					
						
							| 
									
										
										
										
											2012-05-20 19:49:27 +00:00
										 |  |  | 		if (seq_tx_get_final_right(seq, 0) <= seq_tx_get_final_left(seq, 0)) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			seq_tx_set_final_right(seq, seq_tx_get_final_left(seq, 0) + 1); | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		if (seq_single_check(seq) == 0) { | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 			if (seq_tx_get_final_right(seq, 0) <= seq_tx_get_start(seq)) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				seq_tx_set_final_right(seq, seq_tx_get_start(seq) + 1); | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* sounds cannot be extended past their endpoints */ | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (seq->type == SEQ_TYPE_SOUND_RAM) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		seq->startstill = 0; | 
					
						
							|  |  |  | 		seq->endstill = 0; | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-15 11:27:46 +00:00
										 |  |  | void seq_single_fix(Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int left, start, offset; | 
					
						
							| 
									
										
										
										
											2009-12-15 11:27:46 +00:00
										 |  |  | 	if (!seq_single_check(seq)) | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* make sure the image is always at the start since there is only one,
 | 
					
						
							| 
									
										
										
										
											2012-03-03 20:19:11 +00:00
										 |  |  | 	 * adjusting its start should be ok */ | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 	left = seq_tx_get_final_left(seq, 0); | 
					
						
							|  |  |  | 	start = seq->start; | 
					
						
							|  |  |  | 	if (start != left) { | 
					
						
							|  |  |  | 		offset = left - start; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		seq_tx_set_final_left(seq, seq_tx_get_final_left(seq, 0) - offset); | 
					
						
							|  |  |  | 		seq_tx_set_final_right(seq, seq_tx_get_final_right(seq, 0) - offset); | 
					
						
							| 
									
										
										
										
											2009-01-21 07:01:20 +00:00
										 |  |  | 		seq->start += offset; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-23 23:14:02 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | int seq_tx_test(Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-01-23 23:14:02 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	return (seq->type < SEQ_TYPE_EFFECT) || (get_sequence_effect_num_inputs(seq->type) == 0); | 
					
						
							| 
									
										
										
										
											2009-01-23 23:14:02 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | static int seq_overlap(Sequence *seq1, Sequence *seq2) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-10-30 21:55:17 +00:00
										 |  |  | 	return (seq1 != seq2 && seq1->machine == seq2->machine && | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	        ((seq1->enddisp <= seq2->startdisp) || (seq1->startdisp >= seq2->enddisp)) == 0); | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | int seq_test_overlap(ListBase *seqbasep, Sequence *test) | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seq = seqbasep->first; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (seq) { | 
					
						
							|  |  |  | 		if (seq_overlap(test, seq)) | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | 			return 1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		seq = seq->next; | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-04 17:02:32 +00:00
										 |  |  | void seq_translate(Scene *evil_scene, Sequence *seq, int delta) | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-12-21 16:57:39 +00:00
										 |  |  | 	seq_offset_animdata(evil_scene, seq, delta); | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 	seq->start += delta; | 
					
						
							| 
									
										
										
										
											2009-12-21 16:57:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (seq->type == SEQ_TYPE_META) { | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 		Sequence *seq_child; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		for (seq_child = seq->seqbase.first; seq_child; seq_child = seq_child->next) { | 
					
						
							| 
									
										
										
										
											2009-12-21 16:57:39 +00:00
										 |  |  | 			seq_translate(evil_scene, seq_child, delta); | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 	calc_sequence_disp(evil_scene, seq); | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-01 08:51:12 +00:00
										 |  |  | void seq_sound_init(Scene *scene, Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (seq->type == SEQ_TYPE_META) { | 
					
						
							| 
									
										
										
										
											2011-04-01 08:51:12 +00:00
										 |  |  | 		Sequence *seq_child; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		for (seq_child = seq->seqbase.first; seq_child; seq_child = seq_child->next) { | 
					
						
							| 
									
										
										
										
											2011-04-01 08:51:12 +00:00
										 |  |  | 			seq_sound_init(scene, seq_child); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->sound) { | 
					
						
							| 
									
										
										
										
											2012-01-05 10:34:50 +00:00
										 |  |  | 			seq->scene_sound = sound_add_scene_sound_defaults(scene, seq); | 
					
						
							| 
									
										
										
										
											2011-04-01 08:51:12 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->scene) { | 
					
						
							| 
									
										
										
										
											2012-01-05 10:34:50 +00:00
										 |  |  | 			sound_scene_add_scene_sound_defaults(scene, seq); | 
					
						
							| 
									
										
										
										
											2011-04-01 08:51:12 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-17 22:34:41 +00:00
										 |  |  | Sequence *seq_foreground_frame_get(Scene *scene, int frame) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | 	Editing *ed = BKE_sequencer_editing_get(scene, FALSE); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	Sequence *seq, *best_seq = NULL; | 
					
						
							| 
									
										
										
										
											2011-02-17 22:34:41 +00:00
										 |  |  | 	int best_machine = -1; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (!ed) return NULL; | 
					
						
							| 
									
										
										
										
											2011-02-17 22:34:41 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = ed->seqbasep->first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->flag & SEQ_MUTE || seq->startdisp > frame || seq->enddisp <= frame) | 
					
						
							| 
									
										
										
										
											2011-02-17 22:34:41 +00:00
										 |  |  | 			continue; | 
					
						
							|  |  |  | 		/* only use elements you can see - not */ | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		if (ELEM5(seq->type, SEQ_TYPE_IMAGE, SEQ_TYPE_META, SEQ_TYPE_SCENE, SEQ_TYPE_MOVIE, SEQ_TYPE_COLOR)) { | 
					
						
							| 
									
										
										
										
											2011-02-17 22:34:41 +00:00
										 |  |  | 			if (seq->machine > best_machine) { | 
					
						
							|  |  |  | 				best_seq = seq; | 
					
						
							|  |  |  | 				best_machine = seq->machine; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return best_seq; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | /* return 0 if there werent enough space */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | int shuffle_seq(ListBase *seqbasep, Sequence *test, Scene *evil_scene) | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	int orig_machine = test->machine; | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 	test->machine++; | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 	calc_sequence(evil_scene, test); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	while (seq_test_overlap(seqbasep, test) ) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (test->machine >= MAXSEQ) { | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		test->machine++; | 
					
						
							| 
									
										
										
										
											2012-03-18 07:38:51 +00:00
										 |  |  | 		calc_sequence(evil_scene, test); // XXX - I don't think this is needed since were only moving vertically, Campbell.
 | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (test->machine >= MAXSEQ) { | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 		/* Blender 2.4x would remove the strip.
 | 
					
						
							|  |  |  | 		 * nicer to move it to the end */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		Sequence *seq; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		int new_frame = test->enddisp; | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		for (seq = seqbasep->first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 			if (seq->machine == orig_machine) | 
					
						
							|  |  |  | 				new_frame = MAX2(new_frame, seq->enddisp); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		test->machine = orig_machine; | 
					
						
							|  |  |  | 		new_frame = new_frame + (test->start - test->startdisp); /* adjust by the startdisp */ | 
					
						
							| 
									
										
										
										
											2009-12-21 16:57:39 +00:00
										 |  |  | 		seq_translate(evil_scene, test, new_frame - test->start); | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 		calc_sequence(evil_scene, test); | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 		return 0; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2009-01-25 14:53:41 +00:00
										 |  |  | 		return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-08-09 21:16:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static int shuffle_seq_time_offset_test(ListBase *seqbasep, char dir) | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	int offset = 0; | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | 	Sequence *seq, *seq_other; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = seqbasep->first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->tmp) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			for (seq_other = seqbasep->first; seq_other; seq_other = seq_other->next) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				if (!seq_other->tmp && seq_overlap(seq, seq_other)) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 					if (dir == 'L') { | 
					
						
							|  |  |  | 						offset = MIN2(offset, seq_other->startdisp - seq->enddisp); | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | 					} | 
					
						
							|  |  |  | 					else { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 						offset = MAX2(offset, seq_other->enddisp - seq->startdisp); | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return offset; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | static int shuffle_seq_time_offset(Scene *scene, ListBase *seqbasep, char dir) | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	int ofs = 0; | 
					
						
							|  |  |  | 	int tot_ofs = 0; | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | 	Sequence *seq; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	while ( (ofs = shuffle_seq_time_offset_test(seqbasep, dir)) ) { | 
					
						
							|  |  |  | 		for (seq = seqbasep->first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (seq->tmp) { | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | 				/* seq_test_overlap only tests display values */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				seq->startdisp +=   ofs; | 
					
						
							|  |  |  | 				seq->enddisp +=     ofs; | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		tot_ofs += ofs; | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = seqbasep->first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->tmp) | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			calc_sequence_disp(scene, seq);  /* corrects dummy startdisp/enddisp values */ | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return tot_ofs; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | int shuffle_seq_time(ListBase *seqbasep, Scene *evil_scene) | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* note: seq->tmp is used to tag strips to move */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 	int offset_l = shuffle_seq_time_offset(evil_scene, seqbasep, 'L'); | 
					
						
							|  |  |  | 	int offset_r = shuffle_seq_time_offset(evil_scene, seqbasep, 'R'); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	int offset = (-offset_l < offset_r) ?  offset_l : offset_r; | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (offset) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		for (seq = seqbasep->first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (seq->tmp) { | 
					
						
							| 
									
										
										
										
											2009-12-21 16:57:39 +00:00
										 |  |  | 				seq_translate(evil_scene, seq, offset); | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | 				seq->flag &= ~SEQ_OVERLAP; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	return offset ? 0 : 1; | 
					
						
							| 
									
										
										
										
											2009-10-22 14:40:32 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-07 11:54:58 +00:00
										 |  |  | void seq_update_sound_bounds_all(Scene *scene) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Editing *ed = scene->ed; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (ed) { | 
					
						
							| 
									
										
										
										
											2011-08-07 11:54:58 +00:00
										 |  |  | 		Sequence *seq; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		for (seq = ed->seqbase.first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 			if (seq->type == SEQ_TYPE_META) { | 
					
						
							| 
									
										
										
										
											2011-08-07 11:54:58 +00:00
										 |  |  | 				seq_update_sound_bounds_recursive(scene, seq); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 			else if (ELEM(seq->type, SEQ_TYPE_SOUND_RAM, SEQ_TYPE_SCENE)) { | 
					
						
							| 
									
										
										
										
											2011-08-07 11:54:58 +00:00
										 |  |  | 				seq_update_sound_bounds(scene, seq); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | void seq_update_sound_bounds(Scene *scene, Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-08-09 21:16:39 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-13 20:54:36 +00:00
										 |  |  | 	sound_move_scene_sound_defaults(scene, seq); | 
					
						
							| 
									
										
										
										
											2012-01-05 10:34:50 +00:00
										 |  |  | 	/* mute is set in seq_update_muting_recursive */ | 
					
						
							| 
									
										
										
										
											2009-12-08 13:57:51 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-07 11:54:58 +00:00
										 |  |  | static void seq_update_muting_recursive(ListBase *seqbasep, Sequence *metaseq, int mute) | 
					
						
							| 
									
										
										
										
											2009-12-08 13:57:51 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							|  |  |  | 	int seqmute; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* for sound we go over full meta tree to update muted state,
 | 
					
						
							| 
									
										
										
										
											2012-04-22 11:54:53 +00:00
										 |  |  | 	 * since sound is played outside of evaluating the imbufs, */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = seqbasep->first; seq; seq = seq->next) { | 
					
						
							|  |  |  | 		seqmute = (mute || (seq->flag & SEQ_MUTE)); | 
					
						
							| 
									
										
										
										
											2009-12-08 13:57:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		if (seq->type == SEQ_TYPE_META) { | 
					
						
							| 
									
										
										
										
											2009-12-08 13:57:51 +00:00
										 |  |  | 			/* if this is the current meta sequence, unmute because
 | 
					
						
							| 
									
										
										
										
											2012-03-03 20:19:11 +00:00
										 |  |  | 			 * all sequences above this were set to mute */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (seq == metaseq) | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				seqmute = 0; | 
					
						
							| 
									
										
										
										
											2009-12-08 13:57:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-07 11:54:58 +00:00
										 |  |  | 			seq_update_muting_recursive(&seq->seqbase, metaseq, seqmute); | 
					
						
							| 
									
										
										
										
											2009-12-08 13:57:51 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		else if (ELEM(seq->type, SEQ_TYPE_SOUND_RAM, SEQ_TYPE_SCENE)) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (seq->scene_sound) { | 
					
						
							| 
									
										
										
										
											2011-08-07 11:54:58 +00:00
										 |  |  | 				sound_mute_scene_sound(seq->scene_sound, seqmute); | 
					
						
							| 
									
										
										
										
											2009-12-08 13:57:51 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-07 11:54:58 +00:00
										 |  |  | void seq_update_muting(Editing *ed) | 
					
						
							| 
									
										
										
										
											2009-12-08 13:57:51 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (ed) { | 
					
						
							| 
									
										
										
										
											2009-12-08 13:57:51 +00:00
										 |  |  | 		/* mute all sounds up to current metastack list */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		MetaStack *ms = ed->metastack.last; | 
					
						
							| 
									
										
										
										
											2009-12-08 13:57:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (ms) | 
					
						
							| 
									
										
										
										
											2011-08-07 11:54:58 +00:00
										 |  |  | 			seq_update_muting_recursive(&ed->seqbase, ms->parseq, 1); | 
					
						
							| 
									
										
										
										
											2009-12-08 13:57:51 +00:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2011-08-07 11:54:58 +00:00
										 |  |  | 			seq_update_muting_recursive(&ed->seqbase, NULL, 0); | 
					
						
							| 
									
										
										
										
											2009-08-09 21:16:39 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-26 13:56:31 +00:00
										 |  |  | static void seq_update_sound_recursive(Scene *scene, ListBase *seqbasep, bSound *sound) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = seqbasep->first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		if (seq->type == SEQ_TYPE_META) { | 
					
						
							| 
									
										
										
										
											2011-07-26 13:56:31 +00:00
										 |  |  | 			seq_update_sound_recursive(scene, &seq->seqbase, sound); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		else if (seq->type == SEQ_TYPE_SOUND_RAM) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (seq->scene_sound && sound == seq->sound) { | 
					
						
							| 
									
										
										
										
											2011-07-26 13:56:31 +00:00
										 |  |  | 				sound_update_scene_sound(seq->scene_sound, sound); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void seq_update_sound(struct Scene *scene, struct bSound *sound) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (scene->ed) { | 
					
						
							| 
									
										
										
										
											2011-07-26 13:56:31 +00:00
										 |  |  | 		seq_update_sound_recursive(scene, &scene->ed->seqbase, sound); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-16 16:35:31 +00:00
										 |  |  | /* in cases where we done know the sequence's listbase */ | 
					
						
							|  |  |  | ListBase *seq_seqbase(ListBase *seqbase, Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Sequence *iseq; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	ListBase *lb = NULL; | 
					
						
							| 
									
										
										
										
											2009-12-16 16:35:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (iseq = seqbase->first; iseq; iseq = iseq->next) { | 
					
						
							|  |  |  | 		if (seq == iseq) { | 
					
						
							| 
									
										
										
										
											2009-12-16 16:35:31 +00:00
										 |  |  | 			return seqbase; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		else if (iseq->seqbase.first && (lb = seq_seqbase(&iseq->seqbase, seq))) { | 
					
						
							| 
									
										
										
										
											2009-12-16 16:35:31 +00:00
										 |  |  | 			return lb; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return NULL; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-12-09 16:46:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | Sequence *seq_metastrip(ListBase *seqbase, Sequence *meta, Sequence *seq) | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	Sequence *iseq; | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	for (iseq = seqbase->first; iseq; iseq = iseq->next) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		Sequence *rval; | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if (seq == iseq) { | 
					
						
							|  |  |  | 			return meta; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else if (iseq->seqbase.first && | 
					
						
							| 
									
										
										
										
											2012-05-20 19:49:27 +00:00
										 |  |  | 		         (rval = seq_metastrip(&iseq->seqbase, iseq, seq))) | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 			return rval; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-28 09:59:34 +00:00
										 |  |  | int seq_swap(Sequence *seq_a, Sequence *seq_b, const char **error_str) | 
					
						
							| 
									
										
										
										
											2010-06-21 17:37:50 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-07-07 13:14:51 +00:00
										 |  |  | 	char name[sizeof(seq_a->name)]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq_a->len != seq_b->len) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		*error_str = "Strips must be the same length"; | 
					
						
							| 
									
										
										
										
											2010-06-21 17:37:50 +00:00
										 |  |  | 		return 0; | 
					
						
							| 
									
										
										
										
											2011-07-19 01:36:59 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-06-21 17:37:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* type checking, could be more advanced but disalow sound vs non-sound copy */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq_a->type != seq_b->type) { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		if (seq_a->type == SEQ_TYPE_SOUND_RAM || seq_b->type == SEQ_TYPE_SOUND_RAM) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			*error_str = "Strips were not compatible"; | 
					
						
							| 
									
										
										
										
											2010-06-21 17:37:50 +00:00
										 |  |  | 			return 0; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-07-07 13:14:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* disallow effects to swap with non-effects strips */ | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		if ((seq_a->type & SEQ_TYPE_EFFECT) != (seq_b->type & SEQ_TYPE_EFFECT)) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			*error_str = "Strips were not compatible"; | 
					
						
							| 
									
										
										
										
											2010-07-07 13:14:51 +00:00
										 |  |  | 			return 0; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		if ((seq_a->type & SEQ_TYPE_EFFECT) && (seq_b->type & SEQ_TYPE_EFFECT)) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (get_sequence_effect_num_inputs(seq_a->type) != get_sequence_effect_num_inputs(seq_b->type)) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				*error_str = "Strips must have the same number of inputs"; | 
					
						
							| 
									
										
										
										
											2010-07-07 13:14:51 +00:00
										 |  |  | 				return 0; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-06-21 17:37:50 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	SWAP(Sequence, *seq_a, *seq_b); | 
					
						
							| 
									
										
										
										
											2010-07-07 13:14:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-18 07:38:51 +00:00
										 |  |  | 	/* swap back names so animation fcurves don't get swapped */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	BLI_strncpy(name, seq_a->name + 2, sizeof(name)); | 
					
						
							|  |  |  | 	BLI_strncpy(seq_a->name + 2, seq_b->name + 2, sizeof(seq_b->name) - 2); | 
					
						
							|  |  |  | 	BLI_strncpy(seq_b->name + 2, name, sizeof(seq_b->name) - 2); | 
					
						
							| 
									
										
										
										
											2010-07-07 13:14:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* swap back opacity, and overlay mode */ | 
					
						
							|  |  |  | 	SWAP(int, seq_a->blend_mode, seq_b->blend_mode); | 
					
						
							|  |  |  | 	SWAP(float, seq_a->blend_opacity, seq_b->blend_opacity); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-21 17:37:50 +00:00
										 |  |  | 	SWAP(void *, seq_a->prev, seq_b->prev); | 
					
						
							|  |  |  | 	SWAP(void *, seq_a->next, seq_b->next); | 
					
						
							|  |  |  | 	SWAP(int, seq_a->start, seq_b->start); | 
					
						
							|  |  |  | 	SWAP(int, seq_a->startofs, seq_b->startofs); | 
					
						
							|  |  |  | 	SWAP(int, seq_a->endofs, seq_b->endofs); | 
					
						
							|  |  |  | 	SWAP(int, seq_a->startstill, seq_b->startstill); | 
					
						
							|  |  |  | 	SWAP(int, seq_a->endstill, seq_b->endstill); | 
					
						
							|  |  |  | 	SWAP(int, seq_a->machine, seq_b->machine); | 
					
						
							| 
									
										
										
										
											2010-06-21 22:05:34 +00:00
										 |  |  | 	SWAP(int, seq_a->startdisp, seq_b->startdisp); | 
					
						
							|  |  |  | 	SWAP(int, seq_a->enddisp, seq_b->enddisp); | 
					
						
							| 
									
										
										
										
											2010-06-21 17:37:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-09 16:46:41 +00:00
										 |  |  | /* XXX - hackish function needed for transforming strips! TODO - have some better solution */ | 
					
						
							|  |  |  | void seq_offset_animdata(Scene *scene, Sequence *seq, int ofs) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	char str[SEQ_NAME_MAXSTR + 3]; | 
					
						
							| 
									
										
										
										
											2009-12-09 18:08:14 +00:00
										 |  |  | 	FCurve *fcu; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (scene->adt == NULL || ofs == 0 || scene->adt->action == NULL) | 
					
						
							| 
									
										
										
										
											2009-12-09 16:46:41 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	BLI_snprintf(str, sizeof(str), "[\"%s\"]", seq->name + 2); | 
					
						
							| 
									
										
										
										
											2009-12-09 16:46:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (fcu = scene->adt->action->curves.first; fcu; fcu = fcu->next) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (strstr(fcu->rna_path, "sequence_editor.sequences_all[") && strstr(fcu->rna_path, str)) { | 
					
						
							| 
									
										
										
										
											2010-10-21 08:32:53 +00:00
										 |  |  | 			unsigned int i; | 
					
						
							| 
									
										
										
										
											2009-12-09 16:46:41 +00:00
										 |  |  | 			for (i = 0; i < fcu->totvert; i++) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 				BezTriple *bezt = &fcu->bezt[i]; | 
					
						
							| 
									
										
										
										
											2009-12-09 16:46:41 +00:00
										 |  |  | 				bezt->vec[0][0] += ofs; | 
					
						
							|  |  |  | 				bezt->vec[1][0] += ofs; | 
					
						
							|  |  |  | 				bezt->vec[2][0] += ofs; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-05 11:04:28 +00:00
										 |  |  | void seq_dupe_animdata(Scene *scene, const char *name_src, const char *name_dst) | 
					
						
							| 
									
										
										
										
											2010-07-07 16:17:18 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	char str_from[SEQ_NAME_MAXSTR + 3]; | 
					
						
							| 
									
										
										
										
											2010-07-07 16:17:18 +00:00
										 |  |  | 	FCurve *fcu; | 
					
						
							|  |  |  | 	FCurve *fcu_last; | 
					
						
							|  |  |  | 	FCurve *fcu_cpy; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	ListBase lb = {NULL, NULL}; | 
					
						
							| 
									
										
										
										
											2010-07-07 16:17:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (scene->adt == NULL || scene->adt->action == NULL) | 
					
						
							| 
									
										
										
										
											2010-07-07 16:17:18 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-11 08:51:06 +00:00
										 |  |  | 	BLI_snprintf(str_from, sizeof(str_from), "[\"%s\"]", name_src); | 
					
						
							| 
									
										
										
										
											2010-07-07 16:17:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	fcu_last = scene->adt->action->curves.last; | 
					
						
							| 
									
										
										
										
											2010-07-07 16:17:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (fcu = scene->adt->action->curves.first; fcu && fcu->prev != fcu_last; fcu = fcu->next) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (strstr(fcu->rna_path, "sequence_editor.sequences_all[") && strstr(fcu->rna_path, str_from)) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			fcu_cpy = copy_fcurve(fcu); | 
					
						
							| 
									
										
										
										
											2010-07-07 16:17:18 +00:00
										 |  |  | 			BLI_addtail(&lb, fcu_cpy); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* notice validate is 0, keep this because the seq may not be added to the scene yet */ | 
					
						
							| 
									
										
										
										
											2012-03-30 13:04:29 +00:00
										 |  |  | 	BKE_animdata_fix_paths_rename(&scene->id, scene->adt, NULL, "sequence_editor.sequences_all", name_src, name_dst, 0, 0, 0); | 
					
						
							| 
									
										
										
										
											2010-07-07 16:17:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* add the original fcurves back */ | 
					
						
							| 
									
										
										
										
											2010-12-21 14:49:34 +00:00
										 |  |  | 	BLI_movelisttolist(&scene->adt->action->curves, &lb); | 
					
						
							| 
									
										
										
										
											2010-07-07 16:17:18 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-03 21:13:08 +00:00
										 |  |  | /* XXX - hackish function needed to remove all fcurves belonging to a sequencer strip */ | 
					
						
							|  |  |  | static void seq_free_animdata(Scene *scene, Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	char str[SEQ_NAME_MAXSTR + 3]; | 
					
						
							| 
									
										
										
										
											2010-07-03 21:13:08 +00:00
										 |  |  | 	FCurve *fcu; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (scene->adt == NULL || scene->adt->action == NULL) | 
					
						
							| 
									
										
										
										
											2010-07-03 21:13:08 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	BLI_snprintf(str, sizeof(str), "[\"%s\"]", seq->name + 2); | 
					
						
							| 
									
										
										
										
											2010-07-03 21:13:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	fcu = scene->adt->action->curves.first; | 
					
						
							| 
									
										
										
										
											2010-07-03 21:13:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	while (fcu) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (strstr(fcu->rna_path, "sequence_editor.sequences_all[") && strstr(fcu->rna_path, str)) { | 
					
						
							| 
									
										
										
										
											2010-07-03 21:13:08 +00:00
										 |  |  | 			FCurve *next_fcu = fcu->next; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			BLI_remlink(&scene->adt->action->curves, fcu); | 
					
						
							|  |  |  | 			free_fcurve(fcu); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			fcu = next_fcu; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2010-07-03 21:13:08 +00:00
										 |  |  | 			fcu = fcu->next; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-09 16:46:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-17 11:16:28 +00:00
										 |  |  | Sequence *get_seq_by_name(ListBase *seqbase, const char *name, int recursive) | 
					
						
							| 
									
										
										
										
											2009-12-17 04:55:15 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	Sequence *iseq = NULL; | 
					
						
							|  |  |  | 	Sequence *rseq = NULL; | 
					
						
							| 
									
										
										
										
											2009-12-17 11:16:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (iseq = seqbase->first; iseq; iseq = iseq->next) { | 
					
						
							|  |  |  | 		if (strcmp(name, iseq->name + 2) == 0) | 
					
						
							| 
									
										
										
										
											2009-12-17 11:16:28 +00:00
										 |  |  | 			return iseq; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		else if (recursive && (iseq->seqbase.first) && (rseq = get_seq_by_name(&iseq->seqbase, name, 1))) { | 
					
						
							| 
									
										
										
										
											2009-12-17 11:16:28 +00:00
										 |  |  | 			return rseq; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-12-17 04:55:15 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-12-17 11:16:28 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return NULL; | 
					
						
							| 
									
										
										
										
											2009-12-17 04:55:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | Sequence *BKE_sequencer_active_get(Scene *scene) | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | 	Editing *ed = BKE_sequencer_editing_get(scene, FALSE); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (ed == NULL) return NULL; | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 	return ed->act_seq; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | void BKE_sequencer_active_set(Scene *scene, Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | 	Editing *ed = BKE_sequencer_editing_get(scene, FALSE); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (ed == NULL) return; | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	ed->act_seq = seq; | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | int BKE_sequencer_active_get_pair(Scene *scene, Sequence **seq_act, Sequence **seq_other) | 
					
						
							| 
									
										
										
										
											2010-06-21 17:37:50 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | 	Editing *ed = BKE_sequencer_editing_get(scene, FALSE); | 
					
						
							| 
									
										
										
										
											2010-06-21 17:37:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | 	*seq_act = BKE_sequencer_active_get(scene); | 
					
						
							| 
									
										
										
										
											2010-06-21 17:37:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (*seq_act == NULL) { | 
					
						
							| 
									
										
										
										
											2010-06-21 17:37:50 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		Sequence *seq; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		*seq_other = NULL; | 
					
						
							| 
									
										
										
										
											2010-06-21 17:37:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		for (seq = ed->seqbasep->first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (seq->flag & SELECT && (seq != (*seq_act))) { | 
					
						
							|  |  |  | 				if (*seq_other) { | 
					
						
							| 
									
										
										
										
											2010-06-21 17:37:50 +00:00
										 |  |  | 					return 0; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 					*seq_other = seq; | 
					
						
							| 
									
										
										
										
											2010-06-21 17:37:50 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return (*seq_other != NULL); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | /* api like funcs for adding */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void seq_load_apply(Scene *scene, Sequence *seq, SeqLoadInfo *seq_load) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		BLI_strncpy(seq->name + 2, seq_load->name, sizeof(seq->name) - 2); | 
					
						
							| 
									
										
										
										
											2010-02-16 17:58:50 +00:00
										 |  |  | 		seqbase_unique_name_recursive(&scene->ed->seqbase, seq); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq_load->flag & SEQ_LOAD_FRAME_ADVANCE) { | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 			seq_load->start_frame += (seq->enddisp - seq->startdisp); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq_load->flag & SEQ_LOAD_REPLACE_SEL) { | 
					
						
							| 
									
										
										
										
											2009-12-17 23:29:11 +00:00
										 |  |  | 			seq_load->flag |= SELECT; | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | 			BKE_sequencer_active_set(scene, seq); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq_load->flag & SEQ_LOAD_SOUND_CACHE) { | 
					
						
							|  |  |  | 			if (seq->sound) | 
					
						
							| 
									
										
										
										
											2011-08-07 11:54:58 +00:00
										 |  |  | 				sound_cache(seq->sound); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		seq_load->tot_success++; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		seq_load->tot_error++; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Sequence *alloc_sequence(ListBase *lb, int cfra, int machine) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seq = MEM_callocN(sizeof(Sequence), "addseq"); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 	BLI_addtail(lb, seq); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	*( (short *)seq->name) = ID_SEQ; | 
					
						
							|  |  |  | 	seq->name[2] = 0; | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seq->flag = SELECT; | 
					
						
							|  |  |  | 	seq->start = cfra; | 
					
						
							|  |  |  | 	seq->machine = machine; | 
					
						
							|  |  |  | 	seq->sat = 1.0; | 
					
						
							|  |  |  | 	seq->mul = 1.0; | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 	seq->blend_opacity = 100.0; | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 	seq->volume = 1.0f; | 
					
						
							| 
									
										
										
											
												3D Audio GSoC:
Implemented basic audio animation.
* AnimatableProperty: Propper cache writing and spline interpolation for reading (the solution for stair steps in audio animation)
* Animatable properties so far are: volume, pitch, panning
* Users note: Changing the pitch of a sound results in wrong seeking, due to the resulting playback length difference.
* Users note: Panning only works for mono sources, values are in the range [-2..2], this basically controls the angle of the sound, 0 is front, -1 left, 1 right and 2 and -2 are back. Typical stereo panning only supports [-1..1].
* Disabled animation of audio related ffmpeg output parameters.
* Scene Audio Panel: 3D Listener settings also for Renderer, new Volume property (animatable!), Update/Bake buttons for animation problems, moved sampling rate and channel count here
											
										 
											2011-07-28 13:58:59 +00:00
										 |  |  | 	seq->pitch = 1.0f; | 
					
						
							| 
									
										
										
										
											2011-02-22 16:32:05 +00:00
										 |  |  | 	seq->scene_sound = NULL; | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return seq; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-28 19:18:35 +00:00
										 |  |  | /* NOTE: this function doesn't fill in image names */ | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | Sequence *sequencer_add_image_strip(bContext *C, ListBase *seqbasep, SeqLoadInfo *seq_load) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	Scene *scene = CTX_data_scene(C); /* only for active seq */ | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 	Sequence *seq; | 
					
						
							|  |  |  | 	Strip *strip; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	seq = alloc_sequence(seqbasep, seq_load->start_frame, seq_load->channel); | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	seq->type = SEQ_TYPE_IMAGE; | 
					
						
							|  |  |  | 	seq->blend_mode = SEQ_TYPE_CROSS; /* so alpha adjustment fade to the strip below */ | 
					
						
							| 
									
										
										
										
											2009-11-19 03:21:37 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 	/* basic defaults */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seq->strip = strip = MEM_callocN(sizeof(Strip), "strip"); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 	seq->len = seq_load->len ? seq_load->len : 1; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	strip->us = 1; | 
					
						
							|  |  |  | 	strip->stripdata = MEM_callocN(seq->len * sizeof(StripElem), "stripelem"); | 
					
						
							| 
									
										
										
										
											2010-07-02 20:09:42 +00:00
										 |  |  | 	BLI_strncpy(strip->dir, seq_load->path, sizeof(strip->dir)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 	seq_load_apply(scene, seq, seq_load); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return seq; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-23 09:27:56 +00:00
										 |  |  | #ifdef WITH_AUDASPACE
 | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | Sequence *sequencer_add_sound_strip(bContext *C, ListBase *seqbasep, SeqLoadInfo *seq_load) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	Main *bmain = CTX_data_main(C); | 
					
						
							|  |  |  | 	Scene *scene = CTX_data_scene(C); /* only for sound */ | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | 	Editing *ed = BKE_sequencer_editing_get(scene, TRUE); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 	bSound *sound; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	Sequence *seq;  /* generic strip vars */ | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 	Strip *strip; | 
					
						
							|  |  |  | 	StripElem *se; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	AUD_SoundInfo info; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-25 12:04:04 +00:00
										 |  |  | 	sound = sound_new_file(CTX_data_main(C), seq_load->path); /* handles relative paths */ | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (sound == NULL || sound->playback_handle == NULL) { | 
					
						
							| 
									
										
										
										
											2012-04-21 12:51:47 +00:00
										 |  |  | 		//if (op)
 | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 		//	BKE_report(op->reports, RPT_ERROR, "Unsupported audio format");
 | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 	info = AUD_getInfo(sound->playback_handle); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-01 05:09:30 +00:00
										 |  |  | 	if (info.specs.channels == AUD_CHANNELS_INVALID) { | 
					
						
							| 
									
										
										
										
											2011-09-05 19:34:27 +00:00
										 |  |  | 		sound_delete(bmain, sound); | 
					
						
							| 
									
										
										
										
											2012-04-21 12:51:47 +00:00
										 |  |  | 		//if (op)
 | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 		//	BKE_report(op->reports, RPT_ERROR, "Unsupported audio format");
 | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	seq = alloc_sequence(seqbasep, seq_load->start_frame, seq_load->channel); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	seq->type = SEQ_TYPE_SOUND_RAM; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seq->sound = sound; | 
					
						
							|  |  |  | 	BLI_strncpy(seq->name + 2, "Sound", SEQ_NAME_MAXSTR - 2); | 
					
						
							| 
									
										
										
										
											2010-02-16 17:58:50 +00:00
										 |  |  | 	seqbase_unique_name_recursive(&scene->ed->seqbase, seq); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* basic defaults */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seq->strip = strip = MEM_callocN(sizeof(Strip), "strip"); | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 	seq->len = ceil(info.length * FPS); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	strip->us = 1; | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-16 17:54:55 +00:00
										 |  |  | 	/* we only need 1 element to store the filename */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	strip->stripdata = se = MEM_callocN(sizeof(StripElem), "stripelem"); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-15 03:56:05 +00:00
										 |  |  | 	BLI_split_dirfile(seq_load->path, strip->dir, se->name, sizeof(strip->dir), sizeof(se->name)); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 	seq->scene_sound = sound_add_scene_sound(scene, seq, seq_load->start_frame, seq_load->start_frame + seq->len, 0); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 	calc_sequence_disp(scene, seq); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* last active name */ | 
					
						
							| 
									
										
										
										
											2011-09-26 18:51:10 +00:00
										 |  |  | 	BLI_strncpy(ed->act_sounddir, strip->dir, FILE_MAXDIR); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	seq_load_apply(scene, seq, seq_load); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return seq; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2011-06-23 09:27:56 +00:00
										 |  |  | #else // WITH_AUDASPACE
 | 
					
						
							|  |  |  | Sequence *sequencer_add_sound_strip(bContext *C, ListBase *seqbasep, SeqLoadInfo *seq_load) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	(void)C; | 
					
						
							|  |  |  | 	(void)seqbasep; | 
					
						
							|  |  |  | 	(void)seq_load; | 
					
						
							|  |  |  | 	return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif // WITH_AUDASPACE
 | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | Sequence *sequencer_add_movie_strip(bContext *C, ListBase *seqbasep, SeqLoadInfo *seq_load) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	Scene *scene = CTX_data_scene(C); /* only for sound */ | 
					
						
							| 
									
										
										
										
											2010-06-25 12:04:04 +00:00
										 |  |  | 	char path[sizeof(seq_load->path)]; | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	Sequence *seq;  /* generic strip vars */ | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 	Strip *strip; | 
					
						
							|  |  |  | 	StripElem *se; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	struct anim *an; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-25 12:04:04 +00:00
										 |  |  | 	BLI_strncpy(path, seq_load->path, sizeof(path)); | 
					
						
							| 
									
										
										
										
											2010-10-18 06:41:16 +00:00
										 |  |  | 	BLI_path_abs(path, G.main->name); | 
					
						
							| 
									
										
										
										
											2010-06-25 12:04:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Sequencer ==
This patch adds:
* support for proxy building again (missing feature from Blender 2.49)
  additionally to the way, Blender 2.49 worked, you can select several
  strips at once and make Blender build proxies in the background (using
  the job system)
  Also a new thing: movie proxies are now build into AVI files, and
  the proxy system is moved into ImBuf-library, so that other parts
  of blender can also benefit from it.
  
* Timecode support: to fix seeking issues with files, that have
  a) varying frame rates
  b) very large GOP lengths
  c) are broken inbetween
  d) use different time code tracks
  
  the proxy builder can now also build timecode indices, which are
  used (optionally) for seeking.
  
  For the first time, it is possible, to do frame exact seeking on
  all file types.
  
* Support for different video-streams in one video file (can be
  selected in sequencer, other parts of blender can also use it,
  but UI has to be added accordingly)
* IMPORTANT: this patch *requires* ffmpeg 0.7 or newer, since
  older versions don't support the pkt_pts field, that is essential
  for building timecode indices.
  
  Windows and Mac libs are already updated, Linux-users have to build
  their own ffmpeg verions until distros keep up.
											
										 
											2011-08-28 14:46:03 +00:00
										 |  |  | 	an = openanim(path, IB_rect, 0); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (an == NULL) | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 		return NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	seq = alloc_sequence(seqbasep, seq_load->start_frame, seq_load->channel); | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	seq->type = SEQ_TYPE_MOVIE; | 
					
						
							|  |  |  | 	seq->blend_mode = SEQ_TYPE_CROSS; /* so alpha adjustment fade to the strip below */ | 
					
						
							| 
									
										
										
										
											2010-07-04 08:49:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seq->anim = an; | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 	seq->anim_preseek = IMB_anim_get_preseek(an); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	BLI_strncpy(seq->name + 2, "Movie", SEQ_NAME_MAXSTR - 2); | 
					
						
							| 
									
										
										
										
											2010-02-16 17:58:50 +00:00
										 |  |  | 	seqbase_unique_name_recursive(&scene->ed->seqbase, seq); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* basic defaults */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seq->strip = strip = MEM_callocN(sizeof(Strip), "strip"); | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 	seq->len = IMB_anim_get_duration(an, IMB_TC_RECORD_RUN); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	strip->us = 1; | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-16 17:54:55 +00:00
										 |  |  | 	/* we only need 1 element for MOVIE strips */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	strip->stripdata = se = MEM_callocN(sizeof(StripElem), "stripelem"); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-15 03:56:05 +00:00
										 |  |  | 	BLI_split_dirfile(seq_load->path, strip->dir, se->name, sizeof(strip->dir), sizeof(se->name)); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 	calc_sequence_disp(scene, seq); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq_load->flag & SEQ_LOAD_MOVIE_SOUND) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		int start_frame_back = seq_load->start_frame; | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 		seq_load->channel++; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-11 07:40:31 +00:00
										 |  |  | 		sequencer_add_sound_strip(C, seqbasep, seq_load); | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		seq_load->start_frame = start_frame_back; | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 		seq_load->channel--; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (seq_load->name[0] == '\0') | 
					
						
							| 
									
										
										
										
											2010-07-02 20:09:42 +00:00
										 |  |  | 		BLI_strncpy(seq_load->name, se->name, sizeof(seq_load->name)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-14 19:26:58 +00:00
										 |  |  | 	/* can be NULL */ | 
					
						
							|  |  |  | 	seq_load_apply(scene, seq, seq_load); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return seq; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-04 15:31:04 +00:00
										 |  |  | static Sequence *seq_dupli(struct Scene *scene, struct Scene *scene_to, Sequence *seq, int dupe_flag) | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	Scene *sce_audio = scene_to ? scene_to : scene; | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 	Sequence *seqn = MEM_dupallocN(seq); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	seq->tmp = seqn; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seqn->strip = MEM_dupallocN(seq->strip); | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// XXX: add F-Curve duplication stuff?
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (seq->strip->crop) { | 
					
						
							|  |  |  | 		seqn->strip->crop = MEM_dupallocN(seq->strip->crop); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (seq->strip->transform) { | 
					
						
							|  |  |  | 		seqn->strip->transform = MEM_dupallocN(seq->strip->transform); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (seq->strip->proxy) { | 
					
						
							|  |  |  | 		seqn->strip->proxy = MEM_dupallocN(seq->strip->proxy); | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 		seqn->strip->proxy->anim = NULL; | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (seq->strip->color_balance) { | 
					
						
							| 
									
										
										
										
											2012-05-09 09:24:15 +00:00
										 |  |  | 		seqn->strip->color_balance = MEM_dupallocN(seq->strip->color_balance); | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (seq->type == SEQ_TYPE_META) { | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 		seqn->strip->stripdata = NULL; | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		seqn->seqbase.first = seqn->seqbase.last = NULL; | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 		/* WATCH OUT!!! - This metastrip is not recursively duplicated here - do this after!!! */ | 
					
						
							|  |  |  | 		/* - seq_dupli_recursive(&seq->seqbase,&seqn->seqbase);*/ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	else if (seq->type == SEQ_TYPE_SCENE) { | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 		seqn->strip->stripdata = NULL; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->scene_sound) | 
					
						
							| 
									
										
										
										
											2012-01-05 10:34:50 +00:00
										 |  |  | 			seqn->scene_sound = sound_scene_add_scene_sound_defaults(sce_audio, seqn); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	else if (seq->type == SEQ_TYPE_MOVIE) { | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 		seqn->strip->stripdata = | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		        MEM_dupallocN(seq->strip->stripdata); | 
					
						
							|  |  |  | 		seqn->anim = NULL; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	else if (seq->type == SEQ_TYPE_SOUND_RAM) { | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 		seqn->strip->stripdata = | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		        MEM_dupallocN(seq->strip->stripdata); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if (seq->scene_sound) | 
					
						
							| 
									
										
										
										
											2012-01-05 10:34:50 +00:00
										 |  |  | 			seqn->scene_sound = sound_add_scene_sound_defaults(sce_audio, seqn); | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		seqn->sound->id.us++; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	else if (seq->type == SEQ_TYPE_IMAGE) { | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 		seqn->strip->stripdata = | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		        MEM_dupallocN(seq->strip->stripdata); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	else if (seq->type >= SEQ_TYPE_EFFECT) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		if (seq->seq1 && seq->seq1->tmp) seqn->seq1 = seq->seq1->tmp; | 
					
						
							|  |  |  | 		if (seq->seq2 && seq->seq2->tmp) seqn->seq2 = seq->seq2->tmp; | 
					
						
							|  |  |  | 		if (seq->seq3 && seq->seq3->tmp) seqn->seq3 = seq->seq3->tmp; | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		if (seq->type & SEQ_TYPE_EFFECT) { | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 			struct SeqEffectHandle sh; | 
					
						
							|  |  |  | 			sh = get_sequence_effect(seq); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (sh.copy) | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 				sh.copy(seq, seqn); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 		seqn->strip->stripdata = NULL; | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 		fprintf(stderr, "Aiiiiekkk! sequence type not " | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		        "handled in duplicate!\nExpect a crash" | 
					
						
							|  |  |  | 		        " now...\n"); | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (dupe_flag & SEQ_DUPE_UNIQUE_NAME) | 
					
						
							| 
									
										
										
										
											2010-06-25 12:04:04 +00:00
										 |  |  | 		seqbase_unique_name_recursive(&scene->ed->seqbase, seqn); | 
					
						
							| 
									
										
										
										
											2010-07-07 16:17:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (dupe_flag & SEQ_DUPE_ANIM) | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		seq_dupe_animdata(scene, seq->name + 2, seqn->name + 2); | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return seqn; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | Sequence *seq_dupli_recursive(struct Scene *scene, struct Scene *scene_to, Sequence *seq, int dupe_flag) | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	Sequence *seqn = seq_dupli(scene, scene_to, seq, dupe_flag); | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (seq->type == SEQ_TYPE_META) { | 
					
						
							| 
									
										
										
										
											2010-06-25 12:04:04 +00:00
										 |  |  | 		Sequence *s; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		for (s = seq->seqbase.first; s; s = s->next) { | 
					
						
							| 
									
										
										
										
											2010-10-04 15:31:04 +00:00
										 |  |  | 			Sequence *n = seq_dupli_recursive(scene, scene_to, s, dupe_flag); | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 			if (n) { | 
					
						
							|  |  |  | 				BLI_addtail(&seqn->seqbase, n); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return seqn; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-04 15:31:04 +00:00
										 |  |  | void seqbase_dupli_recursive(Scene *scene, Scene *scene_to, ListBase *nseqbase, ListBase *seqbase, int dupe_flag) | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 	Sequence *seqn = NULL; | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | 	Sequence *last_seq = BKE_sequencer_active_get(scene); | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (seq = seqbase->first; seq; seq = seq->next) { | 
					
						
							|  |  |  | 		seq->tmp = NULL; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		if ((seq->flag & SELECT) || (dupe_flag & SEQ_DUPE_ALL)) { | 
					
						
							| 
									
										
										
										
											2010-10-04 15:31:04 +00:00
										 |  |  | 			seqn = seq_dupli(scene, scene_to, seq, dupe_flag); | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 			if (seqn) { /*should never fail */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				if (dupe_flag & SEQ_DUPE_CONTEXT) { | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 					seq->flag &= ~SEQ_ALLSEL; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 					seqn->flag &= ~(SEQ_LEFTSEL + SEQ_RIGHTSEL + SEQ_LOCK); | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				BLI_addtail(nseqbase, seqn); | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 				if (seq->type == SEQ_TYPE_META) | 
					
						
							| 
									
										
										
										
											2010-10-04 15:31:04 +00:00
										 |  |  | 					seqbase_dupli_recursive(scene, scene_to, &seqn->seqbase, &seq->seqbase, dupe_flag); | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				if (dupe_flag & SEQ_DUPE_CONTEXT) { | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 					if (seq == last_seq) { | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | 						BKE_sequencer_active_set(scene, seqn); | 
					
						
							| 
									
										
										
										
											2010-06-24 10:04:18 +00:00
										 |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |