| 
									
										
										
										
											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 ***** | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-27 20:40:57 +00:00
										 |  |  | /** \file blender/blenkernel/intern/seqeffects.c
 | 
					
						
							|  |  |  |  *  \ingroup bke | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #include <math.h>
 | 
					
						
							|  |  |  | #include <stdlib.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "MEM_guardedalloc.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-21 15:59:08 +00:00
										 |  |  | #include "BLI_math.h" /* windows needs for M_PI */
 | 
					
						
							| 
									
										
										
										
											2011-01-07 18:36:47 +00:00
										 |  |  | #include "BLI_utildefines.h"
 | 
					
						
							| 
									
										
										
										
											2015-07-01 20:29:18 +02:00
										 |  |  | #include "BLI_string.h"
 | 
					
						
							| 
									
										
										
										
											2010-03-21 15:59:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | #include "DNA_scene_types.h"
 | 
					
						
							|  |  |  | #include "DNA_sequence_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-14 14:58:19 +00:00
										 |  |  | #include "DNA_anim_types.h"
 | 
					
						
							| 
									
										
										
										
											2015-09-09 14:36:12 +02:00
										 |  |  | #include "DNA_space_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-14 14:58:19 +00:00
										 |  |  | #include "BKE_fcurve.h"
 | 
					
						
							| 
									
										
										
										
											2009-12-13 14:56:45 +00:00
										 |  |  | #include "BKE_sequencer.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "IMB_imbuf_types.h"
 | 
					
						
							|  |  |  | #include "IMB_imbuf.h"
 | 
					
						
							| 
									
										
											  
											
												Color Management, Stage 2: Switch color pipeline to use OpenColorIO
Replace old color pipeline which was supporting linear/sRGB color spaces
only with OpenColorIO-based pipeline.
This introduces two configurable color spaces:
- Input color space for images and movie clips. This space is used to convert
  images/movies from color space in which file is saved to Blender's linear
  space (for float images, byte images are not internally converted, only input
  space is stored for such images and used later).
  This setting could be found in image/clip data block settings.
- Display color space which defines space in which particular display is working.
  This settings could be found in scene's Color Management panel.
When render result is being displayed on the screen, apart from converting image
to display space, some additional conversions could happen.
This conversions are:
- View, which defines tone curve applying before display transformation.
  These are different ways to view the image on the same display device.
  For example it could be used to emulate film view on sRGB display.
- Exposure affects on image exposure before tone map is applied.
- Gamma is post-display gamma correction, could be used to match particular
  display gamma.
- RGB curves are user-defined curves which are applying before display
  transformation, could be used for different purposes.
All this settings by default are only applying on render result and does not
affect on other images. If some particular image needs to be affected by this
transformation, "View as Render" setting of image data block should be set to
truth. Movie clips are always affected by all display transformations.
This commit also introduces configurable color space in which sequencer is
working. This setting could be found in scene's Color Management panel and
it should be used if such stuff as grading needs to be done in color space
different from sRGB (i.e. when Film view on sRGB display is use, using VD16
space as sequencer's internal space would make grading working in space
which is close to the space using for display).
Some technical notes:
- Image buffer's float buffer is now always in linear space, even if it was
  created from 16bit byte images.
- Space of byte buffer is stored in image buffer's rect_colorspace property.
- Profile of image buffer was removed since it's not longer meaningful.
- OpenGL and GLSL is supposed to always work in sRGB space. It is possible
  to support other spaces, but it's quite large project which isn't so
  much important.
- Legacy Color Management option disabled is emulated by using None display.
  It could have some regressions, but there's no clear way to avoid them.
- If OpenColorIO is disabled on build time, it should make blender behaving
  in the same way as previous release with color management enabled.
More details could be found at this page (more details would be added soon):
http://wiki.blender.org/index.php/Dev:Ref/Release_Notes/2.64/Color_Management
--
Thanks to Xavier Thomas, Lukas Toene for initial work on OpenColorIO
integration and to Brecht van Lommel for some further development and code/
usecase review!
											
										 
											2012-09-15 10:05:07 +00:00
										 |  |  | #include "IMB_colormanagement.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-14 14:58:19 +00:00
										 |  |  | #include "RNA_access.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-19 22:16:10 +06:00
										 |  |  | #include "RE_pipeline.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-01 20:29:18 +02:00
										 |  |  | #include "BLF_api.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-26 19:36:56 +00:00
										 |  |  | static void slice_get_byte_buffers(const SeqRenderData *context, const ImBuf *ibuf1, const ImBuf *ibuf2, | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  |                                    const ImBuf *ibuf3, const ImBuf *out, int start_line, unsigned char **rect1, | 
					
						
							|  |  |  |                                    unsigned char **rect2, unsigned char **rect3, unsigned char **rect_out) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int offset = 4 * start_line * context->rectx; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-20 18:46:57 +00:00
										 |  |  | 	*rect1 = (unsigned char *)ibuf1->rect + offset; | 
					
						
							|  |  |  | 	*rect_out = (unsigned char *)out->rect + offset; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (ibuf2) | 
					
						
							| 
									
										
										
										
											2012-10-20 18:46:57 +00:00
										 |  |  | 		*rect2 = (unsigned char *)ibuf2->rect + offset; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (ibuf3) | 
					
						
							| 
									
										
										
										
											2012-10-20 18:46:57 +00:00
										 |  |  | 		*rect3 = (unsigned char *)ibuf3->rect + offset; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-26 19:36:56 +00:00
										 |  |  | static void slice_get_float_buffers(const SeqRenderData *context, const ImBuf *ibuf1, const ImBuf *ibuf2, | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  |                                     const ImBuf *ibuf3, const ImBuf *out, int start_line, | 
					
						
							|  |  |  |                                     float **rect1, float **rect2, float **rect3, float **rect_out) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int offset = 4 * start_line * context->rectx; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	*rect1 = ibuf1->rect_float + offset; | 
					
						
							|  |  |  | 	*rect_out = out->rect_float + offset; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (ibuf2) | 
					
						
							|  |  |  | 		*rect2 = ibuf2->rect_float + offset; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (ibuf3) | 
					
						
							|  |  |  | 		*rect3 = ibuf3->rect_float + offset; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** Glow effect *************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | enum { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	GlowR = 0, | 
					
						
							|  |  |  | 	GlowG = 1, | 
					
						
							|  |  |  | 	GlowB = 2, | 
					
						
							|  |  |  | 	GlowA = 3 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static ImBuf *prepare_effect_imbufs(const SeqRenderData *context, ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *ibuf3) | 
					
						
							| 
									
										
										
										
											2012-05-17 23:21:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	ImBuf *out; | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 	Scene *scene = context->scene; | 
					
						
							|  |  |  | 	int x = context->rectx; | 
					
						
							|  |  |  | 	int y = context->recty; | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (!ibuf1 && !ibuf2 && !ibuf3) { | 
					
						
							|  |  |  | 		/* hmmm, global float option ? */ | 
					
						
							| 
									
										
										
										
											2012-06-07 18:33:36 +00:00
										 |  |  | 		out = IMB_allocImBuf(x, y, 32, IB_rect); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if ((ibuf1 && ibuf1->rect_float) || | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	         (ibuf2 && ibuf2->rect_float) || | 
					
						
							|  |  |  | 	         (ibuf3 && ibuf3->rect_float)) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 		/* if any inputs are rectfloat, output is float too */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 18:33:36 +00:00
										 |  |  | 		out = IMB_allocImBuf(x, y, 32, IB_rectfloat); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-06-07 18:33:36 +00:00
										 |  |  | 		out = IMB_allocImBuf(x, y, 32, IB_rect); | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (ibuf1 && !ibuf1->rect_float && out->rect_float) { | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 		BKE_sequencer_imbuf_to_sequencer_space(scene, ibuf1, true); | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	if (ibuf2 && !ibuf2->rect_float && out->rect_float) { | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 		BKE_sequencer_imbuf_to_sequencer_space(scene, ibuf2, true); | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	if (ibuf3 && !ibuf3->rect_float && out->rect_float) { | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 		BKE_sequencer_imbuf_to_sequencer_space(scene, ibuf3, true); | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (ibuf1 && !ibuf1->rect && !out->rect_float) { | 
					
						
							|  |  |  | 		IMB_rect_from_float(ibuf1); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (ibuf2 && !ibuf2->rect && !out->rect_float) { | 
					
						
							|  |  |  | 		IMB_rect_from_float(ibuf2); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (ibuf3 && !ibuf3->rect && !out->rect_float) { | 
					
						
							|  |  |  | 		IMB_rect_from_float(ibuf3); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
											  
											
												Color Management, Stage 2: Switch color pipeline to use OpenColorIO
Replace old color pipeline which was supporting linear/sRGB color spaces
only with OpenColorIO-based pipeline.
This introduces two configurable color spaces:
- Input color space for images and movie clips. This space is used to convert
  images/movies from color space in which file is saved to Blender's linear
  space (for float images, byte images are not internally converted, only input
  space is stored for such images and used later).
  This setting could be found in image/clip data block settings.
- Display color space which defines space in which particular display is working.
  This settings could be found in scene's Color Management panel.
When render result is being displayed on the screen, apart from converting image
to display space, some additional conversions could happen.
This conversions are:
- View, which defines tone curve applying before display transformation.
  These are different ways to view the image on the same display device.
  For example it could be used to emulate film view on sRGB display.
- Exposure affects on image exposure before tone map is applied.
- Gamma is post-display gamma correction, could be used to match particular
  display gamma.
- RGB curves are user-defined curves which are applying before display
  transformation, could be used for different purposes.
All this settings by default are only applying on render result and does not
affect on other images. If some particular image needs to be affected by this
transformation, "View as Render" setting of image data block should be set to
truth. Movie clips are always affected by all display transformations.
This commit also introduces configurable color space in which sequencer is
working. This setting could be found in scene's Color Management panel and
it should be used if such stuff as grading needs to be done in color space
different from sRGB (i.e. when Film view on sRGB display is use, using VD16
space as sequencer's internal space would make grading working in space
which is close to the space using for display).
Some technical notes:
- Image buffer's float buffer is now always in linear space, even if it was
  created from 16bit byte images.
- Space of byte buffer is stored in image buffer's rect_colorspace property.
- Profile of image buffer was removed since it's not longer meaningful.
- OpenGL and GLSL is supposed to always work in sRGB space. It is possible
  to support other spaces, but it's quite large project which isn't so
  much important.
- Legacy Color Management option disabled is emulated by using None display.
  It could have some regressions, but there's no clear way to avoid them.
- If OpenColorIO is disabled on build time, it should make blender behaving
  in the same way as previous release with color management enabled.
More details could be found at this page (more details would be added soon):
http://wiki.blender.org/index.php/Dev:Ref/Release_Notes/2.64/Color_Management
--
Thanks to Xavier Thomas, Lukas Toene for initial work on OpenColorIO
integration and to Brecht van Lommel for some further development and code/
usecase review!
											
										 
											2012-09-15 10:05:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-21 10:13:52 +00:00
										 |  |  | 	if (out->rect_float) | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		IMB_colormanagement_assign_float_colorspace(out, scene->sequencer_colorspace_settings.name); | 
					
						
							| 
									
										
										
										
											2012-11-21 10:13:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 	return out; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** Alpha Over *************************/ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | static void init_alpha_over_or_under(Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	Sequence *seq1 = seq->seq1; | 
					
						
							|  |  |  | 	Sequence *seq2 = seq->seq2; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	seq->seq2 = seq1; | 
					
						
							|  |  |  | 	seq->seq1 = seq2; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | static void do_alphaover_effect_byte(float facf0, float facf1, int x, int y,  unsigned char *rect1, unsigned char *rect2, unsigned char *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	float fac2, mfac, fac, fac4; | 
					
						
							|  |  |  | 	int xo; | 
					
						
							|  |  |  | 	unsigned char *cp1, *cp2, *rt; | 
					
						
							|  |  |  | 	float tempc[4], rt1[4], rt2[4]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	xo = x; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	cp1 = rect1; | 
					
						
							|  |  |  | 	cp2 = rect2; | 
					
						
							|  |  |  | 	rt = out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	fac2 = facf0; | 
					
						
							|  |  |  | 	fac4 = facf1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (y--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			/* rt = rt1 over rt2  (alpha from rt1) */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 			straight_uchar_to_premul_float(rt1, cp1); | 
					
						
							|  |  |  | 			straight_uchar_to_premul_float(rt2, cp2); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			fac = fac2; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 			mfac = 1.0f - fac2 * rt1[3]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-09 03:46:30 +00:00
										 |  |  | 			if      (fac  <= 0.0f) *((unsigned int *) rt) = *((unsigned int *) cp2); | 
					
						
							|  |  |  | 			else if (mfac <= 0.0f) *((unsigned int *) rt) = *((unsigned int *) cp1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 				tempc[0] = fac * rt1[0] + mfac * rt2[0]; | 
					
						
							|  |  |  | 				tempc[1] = fac * rt1[1] + mfac * rt2[1]; | 
					
						
							|  |  |  | 				tempc[2] = fac * rt1[2] + mfac * rt2[2]; | 
					
						
							|  |  |  | 				tempc[3] = fac * rt1[3] + mfac * rt2[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				premul_float_to_straight_uchar(rt, tempc); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 			cp1 += 4; cp2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		if (y == 0) break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		y--; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 			straight_uchar_to_premul_float(rt1, cp1); | 
					
						
							|  |  |  | 			straight_uchar_to_premul_float(rt2, cp2); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			fac = fac4; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 			mfac = 1.0f - (fac4 * rt1[3]); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-09 03:46:30 +00:00
										 |  |  | 			if      (fac  <= 0.0f) *((unsigned int *) rt) = *((unsigned int *) cp2); | 
					
						
							|  |  |  | 			else if (mfac <= 0.0f) *((unsigned int *) rt) = *((unsigned int *) cp1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 				tempc[0] = fac * rt1[0] + mfac * rt2[0]; | 
					
						
							|  |  |  | 				tempc[1] = fac * rt1[1] + mfac * rt2[1]; | 
					
						
							|  |  |  | 				tempc[2] = fac * rt1[2] + mfac * rt2[2]; | 
					
						
							|  |  |  | 				tempc[3] = fac * rt1[3] + mfac * rt2[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				premul_float_to_straight_uchar(rt, tempc); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 			cp1 += 4; cp2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void do_alphaover_effect_float(float facf0, float facf1, int x, int y,  float *rect1, float *rect2, float *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float fac2, mfac, fac, fac4; | 
					
						
							|  |  |  | 	int xo; | 
					
						
							|  |  |  | 	float *rt1, *rt2, *rt; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	xo = x; | 
					
						
							|  |  |  | 	rt1 = rect1; | 
					
						
							|  |  |  | 	rt2 = rect2; | 
					
						
							|  |  |  | 	rt = out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	fac2 = facf0; | 
					
						
							|  |  |  | 	fac4 = facf1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (y--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			/* rt = rt1 over rt2  (alpha from rt1) */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			fac = fac2; | 
					
						
							|  |  |  | 			mfac = 1.0f - (fac2 * rt1[3]); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (fac <= 0.0f) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				memcpy(rt, rt2, 4 * sizeof(float)); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			else if (mfac <= 0) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				memcpy(rt, rt1, 4 * sizeof(float)); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 				rt[0] = fac * rt1[0] + mfac * rt2[0]; | 
					
						
							|  |  |  | 				rt[1] = fac * rt1[1] + mfac * rt2[1]; | 
					
						
							|  |  |  | 				rt[2] = fac * rt1[2] + mfac * rt2[2]; | 
					
						
							|  |  |  | 				rt[3] = fac * rt1[3] + mfac * rt2[3]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		if (y == 0) | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		y--; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			fac = fac4; | 
					
						
							|  |  |  | 			mfac = 1.0f - (fac4 * rt1[3]); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (fac <= 0.0f) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				memcpy(rt, rt2, 4 * sizeof(float)); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else if (mfac <= 0.0f) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				memcpy(rt, rt1, 4 * sizeof(float)); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 				rt[0] = fac * rt1[0] + mfac * rt2[0]; | 
					
						
							|  |  |  | 				rt[1] = fac * rt1[1] + mfac * rt2[1]; | 
					
						
							|  |  |  | 				rt[2] = fac * rt1[2] + mfac * rt2[2]; | 
					
						
							|  |  |  | 				rt[3] = fac * rt1[3] + mfac * rt2[3]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static void do_alphaover_effect(const SeqRenderData *context, Sequence *UNUSED(seq), float UNUSED(cfra), float facf0, | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  |                                 float facf1, ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *UNUSED(ibuf3), | 
					
						
							|  |  |  |                                 int start_line, int total_lines, ImBuf *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	if (out->rect_float) { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		float *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_float_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_alphaover_effect_float(facf0, facf1, context->rectx, total_lines, rect1, rect2, rect_out); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		unsigned char *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_byte_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_alphaover_effect_byte(facf0, facf1, context->rectx, total_lines, rect1, rect2, rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** Alpha Under *************************/ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | static void do_alphaunder_effect_byte(float facf0, float facf1, int x, int y, unsigned char *rect1, unsigned char *rect2, unsigned char *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 	float fac2, fac, fac4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	int xo; | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 	unsigned char *cp1, *cp2, *rt; | 
					
						
							|  |  |  | 	float tempc[4], rt1[4], rt2[4]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	xo = x; | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 	cp1 = rect1; | 
					
						
							|  |  |  | 	cp2 = rect2; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	rt = out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 	fac2 = facf0; | 
					
						
							|  |  |  | 	fac4 = facf1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (y--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			/* rt = rt1 under rt2  (alpha from rt2) */ | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 			straight_uchar_to_premul_float(rt1, cp1); | 
					
						
							|  |  |  | 			straight_uchar_to_premul_float(rt2, cp2); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-16 23:23:33 +00:00
										 |  |  | 			/* this complex optimization is because the
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			 * 'skybuf' can be crossed in | 
					
						
							|  |  |  | 			 */ | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 			if      (rt2[3] <= 0.0f && fac2 >= 1.0f) *((unsigned int *) rt) = *((unsigned int *) cp1); | 
					
						
							|  |  |  | 			else if (rt2[3] >= 1.0f)                 *((unsigned int *) rt) = *((unsigned int *) cp2); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 				fac = (fac2 * (1.0f - rt2[3])); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 				if (fac <= 0) *((unsigned int *) rt) = *((unsigned int *) cp2); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				else { | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 					tempc[0] = (fac * rt1[0] + rt2[0]); | 
					
						
							|  |  |  | 					tempc[1] = (fac * rt1[1] + rt2[1]); | 
					
						
							|  |  |  | 					tempc[2] = (fac * rt1[2] + rt2[2]); | 
					
						
							|  |  |  | 					tempc[3] = (fac * rt1[3] + rt2[3]); | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 					premul_float_to_straight_uchar(rt, tempc); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 			cp1 += 4; cp2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		if (y == 0) | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		y--; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 			straight_uchar_to_premul_float(rt1, cp1); | 
					
						
							|  |  |  | 			straight_uchar_to_premul_float(rt2, cp2); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if      (rt2[3] <= 0.0f && fac4 >= 1.0f) *((unsigned int *) rt) = *((unsigned int *) cp1); | 
					
						
							|  |  |  | 			else if (rt2[3] >= 1.0f)                 *((unsigned int *) rt) = *((unsigned int *) cp2); | 
					
						
							|  |  |  | 			else {				 | 
					
						
							|  |  |  | 				fac = (fac4 * (1.0f - rt2[3])); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 				if (fac <= 0) *((unsigned int *)rt) = *((unsigned int *)cp2); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				else { | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 					tempc[0] = (fac * rt1[0] + rt2[0]); | 
					
						
							|  |  |  | 					tempc[1] = (fac * rt1[1] + rt2[1]); | 
					
						
							|  |  |  | 					tempc[2] = (fac * rt1[2] + rt2[2]); | 
					
						
							|  |  |  | 					tempc[3] = (fac * rt1[3] + rt2[3]); | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 					premul_float_to_straight_uchar(rt, tempc); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 			cp1 += 4; cp2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void do_alphaunder_effect_float(float facf0, float facf1, int x, int y,  float *rect1, float *rect2, float *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 	float fac2, fac, fac4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	int xo; | 
					
						
							|  |  |  | 	float *rt1, *rt2, *rt; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	xo = x; | 
					
						
							|  |  |  | 	rt1 = rect1; | 
					
						
							|  |  |  | 	rt2 = rect2; | 
					
						
							|  |  |  | 	rt = out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	fac2 = facf0; | 
					
						
							|  |  |  | 	fac4 = facf1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (y--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			/* rt = rt1 under rt2  (alpha from rt2) */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-16 23:23:33 +00:00
										 |  |  | 			/* this complex optimization is because the
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			 * 'skybuf' can be crossed in | 
					
						
							|  |  |  | 			 */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			if (rt2[3] <= 0 && fac2 >= 1.0f) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				memcpy(rt, rt1, 4 * sizeof(float)); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else if (rt2[3] >= 1.0f) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				memcpy(rt, rt2, 4 * sizeof(float)); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 				fac = fac2 * (1.0f - rt2[3]); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				if (fac == 0) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 					memcpy(rt, rt2, 4 * sizeof(float)); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 					rt[0] = fac * rt1[0] + rt2[0]; | 
					
						
							|  |  |  | 					rt[1] = fac * rt1[1] + rt2[1]; | 
					
						
							|  |  |  | 					rt[2] = fac * rt1[2] + rt2[2]; | 
					
						
							|  |  |  | 					rt[3] = fac * rt1[3] + rt2[3]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		if (y == 0) | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		y--; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			if (rt2[3] <= 0 && fac4 >= 1.0f) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				memcpy(rt, rt1, 4 * sizeof(float)); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			else if (rt2[3] >= 1.0f) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				memcpy(rt, rt2, 4 * sizeof(float)); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 				fac = fac4 * (1.0f - rt2[3]); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				if (fac == 0) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 					memcpy(rt, rt2, 4 * sizeof(float)); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							| 
									
										
										
										
											2014-09-11 20:15:57 +02:00
										 |  |  | 					rt[0] = fac * rt1[0] + rt2[0]; | 
					
						
							|  |  |  | 					rt[1] = fac * rt1[1] + rt2[1]; | 
					
						
							|  |  |  | 					rt[2] = fac * rt1[2] + rt2[2]; | 
					
						
							|  |  |  | 					rt[3] = fac * rt1[3] + rt2[3]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static void do_alphaunder_effect(const SeqRenderData *context, Sequence *UNUSED(seq), float UNUSED(cfra), | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  |                                  float facf0, float facf1, ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *UNUSED(ibuf3), | 
					
						
							|  |  |  |                                  int start_line, int total_lines, ImBuf *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	if (out->rect_float) { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		float *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_float_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_alphaunder_effect_float(facf0, facf1, context->rectx, total_lines, rect1, rect2, rect_out); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		unsigned char *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_byte_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_alphaunder_effect_byte(facf0, facf1, context->rectx, total_lines, rect1, rect2, rect_out); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** Cross *************************/ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | static void do_cross_effect_byte(float facf0, float facf1, int x, int y, unsigned char *rect1, unsigned char *rect2, unsigned char *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int fac1, fac2, fac3, fac4; | 
					
						
							|  |  |  | 	int xo; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	unsigned char *rt1, *rt2, *rt; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	xo = x; | 
					
						
							|  |  |  | 	rt1 = rect1; | 
					
						
							|  |  |  | 	rt2 = rect2; | 
					
						
							|  |  |  | 	rt = out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	fac2 = (int) (256.0f * facf0); | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	fac1 = 256 - fac2; | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	fac4 = (int) (256.0f * facf1); | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	fac3 = 256 - fac4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (y--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt[0] = (fac1 * rt1[0] + fac2 * rt2[0]) >> 8; | 
					
						
							|  |  |  | 			rt[1] = (fac1 * rt1[1] + fac2 * rt2[1]) >> 8; | 
					
						
							|  |  |  | 			rt[2] = (fac1 * rt1[2] + fac2 * rt2[2]) >> 8; | 
					
						
							|  |  |  | 			rt[3] = (fac1 * rt1[3] + fac2 * rt2[3]) >> 8; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		if (y == 0) | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		y--; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt[0] = (fac3 * rt1[0] + fac4 * rt2[0]) >> 8; | 
					
						
							|  |  |  | 			rt[1] = (fac3 * rt1[1] + fac4 * rt2[1]) >> 8; | 
					
						
							|  |  |  | 			rt[2] = (fac3 * rt1[2] + fac4 * rt2[2]) >> 8; | 
					
						
							|  |  |  | 			rt[3] = (fac3 * rt1[3] + fac4 * rt2[3]) >> 8; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void do_cross_effect_float(float facf0, float facf1, int x, int y, float *rect1, float *rect2, float *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float fac1, fac2, fac3, fac4; | 
					
						
							|  |  |  | 	int xo; | 
					
						
							|  |  |  | 	float *rt1, *rt2, *rt; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	xo = x; | 
					
						
							|  |  |  | 	rt1 = rect1; | 
					
						
							|  |  |  | 	rt2 = rect2; | 
					
						
							|  |  |  | 	rt = out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	fac2 = facf0; | 
					
						
							|  |  |  | 	fac1 = 1.0f - fac2; | 
					
						
							|  |  |  | 	fac4 = facf1; | 
					
						
							|  |  |  | 	fac3 = 1.0f - fac4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (y--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt[0] = fac1 * rt1[0] + fac2 * rt2[0]; | 
					
						
							|  |  |  | 			rt[1] = fac1 * rt1[1] + fac2 * rt2[1]; | 
					
						
							|  |  |  | 			rt[2] = fac1 * rt1[2] + fac2 * rt2[2]; | 
					
						
							|  |  |  | 			rt[3] = fac1 * rt1[3] + fac2 * rt2[3]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		if (y == 0) | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		y--; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt[0] = fac3 * rt1[0] + fac4 * rt2[0]; | 
					
						
							|  |  |  | 			rt[1] = fac3 * rt1[1] + fac4 * rt2[1]; | 
					
						
							|  |  |  | 			rt[2] = fac3 * rt1[2] + fac4 * rt2[2]; | 
					
						
							|  |  |  | 			rt[3] = fac3 * rt1[3] + fac4 * rt2[3]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static void do_cross_effect(const SeqRenderData *context, Sequence *UNUSED(seq), float UNUSED(cfra), | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  |                             float facf0, float facf1, ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *UNUSED(ibuf3), | 
					
						
							|  |  |  |                             int start_line, int total_lines, ImBuf *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	if (out->rect_float) { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		float *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_float_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_cross_effect_float(facf0, facf1, context->rectx, total_lines, rect1, rect2, rect_out); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		unsigned char *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_byte_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_cross_effect_byte(facf0, facf1, context->rectx, total_lines, rect1, rect2, rect_out); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** Gamma Cross *************************/ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* copied code from initrender.c */ | 
					
						
							|  |  |  | static unsigned short gamtab[65536]; | 
					
						
							|  |  |  | static unsigned short igamtab1[256]; | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | static bool gamma_tabs_init = false; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define RE_GAMMA_TABLE_SIZE 400
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static float gamma_range_table[RE_GAMMA_TABLE_SIZE + 1]; | 
					
						
							|  |  |  | static float gamfactor_table[RE_GAMMA_TABLE_SIZE]; | 
					
						
							|  |  |  | static float inv_gamma_range_table[RE_GAMMA_TABLE_SIZE + 1]; | 
					
						
							|  |  |  | static float inv_gamfactor_table[RE_GAMMA_TABLE_SIZE]; | 
					
						
							|  |  |  | static float color_domain_table[RE_GAMMA_TABLE_SIZE + 1];  | 
					
						
							|  |  |  | static float color_step; | 
					
						
							|  |  |  | static float inv_color_step; | 
					
						
							|  |  |  | static float valid_gamma; | 
					
						
							|  |  |  | static float valid_inv_gamma; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void makeGammaTables(float gamma) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* we need two tables: one forward, one backward */ | 
					
						
							|  |  |  | 	int i; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	valid_gamma       = gamma; | 
					
						
							|  |  |  | 	valid_inv_gamma   = 1.0f / gamma; | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 	color_step        = 1.0f / RE_GAMMA_TABLE_SIZE; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	inv_color_step    = (float) RE_GAMMA_TABLE_SIZE;  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-21 05:46:41 +00:00
										 |  |  | 	/* We could squeeze out the two range tables to gain some memory */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	for (i = 0; i < RE_GAMMA_TABLE_SIZE; i++) { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		color_domain_table[i]    = i * color_step; | 
					
						
							|  |  |  | 		gamma_range_table[i]     = pow(color_domain_table[i], valid_gamma); | 
					
						
							|  |  |  | 		inv_gamma_range_table[i] = pow(color_domain_table[i], valid_inv_gamma); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* The end of the table should match 1.0 carefully. In order to avoid
 | 
					
						
							|  |  |  | 	 * rounding errors, we just set this explicitly. The last segment may | 
					
						
							| 
									
										
										
										
											2012-10-04 13:26:15 +00:00
										 |  |  | 	 * have a different length than the other segments, but our | 
					
						
							|  |  |  | 	 * interpolation is insensitive to that | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	color_domain_table[RE_GAMMA_TABLE_SIZE]    = 1.0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	gamma_range_table[RE_GAMMA_TABLE_SIZE]     = 1.0; | 
					
						
							|  |  |  | 	inv_gamma_range_table[RE_GAMMA_TABLE_SIZE] = 1.0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	/* To speed up calculations, we make these calc factor tables. They are
 | 
					
						
							|  |  |  | 	 * multiplication factors used in scaling the interpolation | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	for (i = 0; i < RE_GAMMA_TABLE_SIZE; i++) { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		gamfactor_table[i] = inv_color_step * (gamma_range_table[i + 1] - gamma_range_table[i]); | 
					
						
							|  |  |  | 		inv_gamfactor_table[i] = inv_color_step * (inv_gamma_range_table[i + 1] - inv_gamma_range_table[i]); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static float gammaCorrect(float c) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int i; | 
					
						
							| 
									
										
										
										
											2014-03-05 22:33:47 +11:00
										 |  |  | 	float res; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2014-03-05 22:33:47 +11:00
										 |  |  | 	i = floorf(c * inv_color_step); | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	/* Clip to range [0, 1]: outside, just do the complete calculation.
 | 
					
						
							|  |  |  | 	 * We may have some performance problems here. Stretching up the LUT | 
					
						
							|  |  |  | 	 * may help solve that, by exchanging LUT size for the interpolation. | 
					
						
							|  |  |  | 	 * Negative colors are explicitly handled. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2014-03-05 22:33:47 +11:00
										 |  |  | 	if      (UNLIKELY(i < 0))          res = -powf(-c, valid_gamma); | 
					
						
							|  |  |  | 	else if (i >= RE_GAMMA_TABLE_SIZE) res =  powf(c,  valid_gamma); | 
					
						
							|  |  |  | 	else                               res =  gamma_range_table[i] + | 
					
						
							|  |  |  | 	                                          ((c - color_domain_table[i]) * gamfactor_table[i]); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	return res; | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* ------------------------------------------------------------------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-05 22:33:47 +11:00
										 |  |  | static float invGammaCorrect(float c) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int i; | 
					
						
							|  |  |  | 	float res = 0.0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-05 22:33:47 +11:00
										 |  |  | 	i = floorf(c * inv_color_step); | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	/* Negative colors are explicitly handled */ | 
					
						
							| 
									
										
										
										
											2014-03-05 22:33:47 +11:00
										 |  |  | 	if      (UNLIKELY(i < 0))          res = -powf(-c, valid_inv_gamma); | 
					
						
							|  |  |  | 	else if (i >= RE_GAMMA_TABLE_SIZE) res =  powf(c,  valid_inv_gamma); | 
					
						
							|  |  |  | 	else                               res = inv_gamma_range_table[i] + | 
					
						
							|  |  |  | 	                                         ((c - color_domain_table[i]) * inv_gamfactor_table[i]); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  |   | 
					
						
							|  |  |  | 	return res; | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static void gamtabs(float gamma) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	float val, igamma = 1.0f / gamma; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	int a; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* gamtab: in short, out short */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	for (a = 0; a < 65536; a++) { | 
					
						
							|  |  |  | 		val = a; | 
					
						
							|  |  |  | 		val /= 65535.0f; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2014-03-28 14:53:37 +11:00
										 |  |  | 		if (gamma == 2.0f) | 
					
						
							|  |  |  | 			val = sqrtf(val); | 
					
						
							|  |  |  | 		else if (gamma != 1.0f) | 
					
						
							|  |  |  | 			val = powf(val, igamma); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		gamtab[a] = (65535.99f * val); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	/* inverse gamtab1 : in byte, out short */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	for (a = 1; a <= 256; a++) { | 
					
						
							| 
									
										
										
										
											2013-03-09 03:46:30 +00:00
										 |  |  | 		if      (gamma == 2.0f) igamtab1[a - 1] = a   * a - 1; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		else if (gamma == 1.0f) igamtab1[a - 1] = 256 * a - 1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			val = a / 256.0f; | 
					
						
							|  |  |  | 			igamtab1[a - 1] = (65535.0 * pow(val, gamma)) - 1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 12:30:59 +00:00
										 |  |  | static void build_gammatabs(void) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 	if (gamma_tabs_init == false) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		gamtabs(2.0f); | 
					
						
							|  |  |  | 		makeGammaTables(2.0f); | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 		gamma_tabs_init = true; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | static void init_gammacross(Sequence *UNUSED(seq)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | static void load_gammacross(Sequence *UNUSED(seq)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | static void free_gammacross(Sequence *UNUSED(seq)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void do_gammacross_effect_byte(float facf0, float UNUSED(facf1),  int x, int y, unsigned char *rect1, | 
					
						
							|  |  |  |                                       unsigned char *rect2, unsigned char *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	float fac1, fac2; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	int xo; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	unsigned char *cp1, *cp2, *rt; | 
					
						
							|  |  |  | 	float rt1[4], rt2[4], tempc[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	xo = x; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	cp1 = rect1; | 
					
						
							|  |  |  | 	cp2 = rect2; | 
					
						
							|  |  |  | 	rt = out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	fac2 = facf0; | 
					
						
							|  |  |  | 	fac1 = 1.0f - fac2; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (y--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 			straight_uchar_to_premul_float(rt1, cp1); | 
					
						
							|  |  |  | 			straight_uchar_to_premul_float(rt2, cp2); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 			tempc[0] = gammaCorrect(fac1 * invGammaCorrect(rt1[0]) + fac2 * invGammaCorrect(rt2[0])); | 
					
						
							|  |  |  | 			tempc[1] = gammaCorrect(fac1 * invGammaCorrect(rt1[1]) + fac2 * invGammaCorrect(rt2[1])); | 
					
						
							|  |  |  | 			tempc[2] = gammaCorrect(fac1 * invGammaCorrect(rt1[2]) + fac2 * invGammaCorrect(rt2[2])); | 
					
						
							|  |  |  | 			tempc[3] = gammaCorrect(fac1 * invGammaCorrect(rt1[3]) + fac2 * invGammaCorrect(rt2[3])); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			premul_float_to_straight_uchar(rt, tempc); | 
					
						
							|  |  |  | 			cp1 += 4; cp2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		if (y == 0) | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		y--; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 			straight_uchar_to_premul_float(rt1, cp1); | 
					
						
							|  |  |  | 			straight_uchar_to_premul_float(rt2, cp2); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 			tempc[0] = gammaCorrect(fac1 * invGammaCorrect(rt1[0]) + fac2 * invGammaCorrect(rt2[0])); | 
					
						
							|  |  |  | 			tempc[1] = gammaCorrect(fac1 * invGammaCorrect(rt1[1]) + fac2 * invGammaCorrect(rt2[1])); | 
					
						
							|  |  |  | 			tempc[2] = gammaCorrect(fac1 * invGammaCorrect(rt1[2]) + fac2 * invGammaCorrect(rt2[2])); | 
					
						
							|  |  |  | 			tempc[3] = gammaCorrect(fac1 * invGammaCorrect(rt1[3]) + fac2 * invGammaCorrect(rt2[3])); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			premul_float_to_straight_uchar(rt, tempc); | 
					
						
							|  |  |  | 			cp1 += 4; cp2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void do_gammacross_effect_float(float facf0, float UNUSED(facf1), int x, int y, float *rect1, | 
					
						
							|  |  |  |                                        float *rect2, float *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float fac1, fac2; | 
					
						
							|  |  |  | 	int xo; | 
					
						
							|  |  |  | 	float *rt1, *rt2, *rt; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	xo = x; | 
					
						
							|  |  |  | 	rt1 = rect1; | 
					
						
							|  |  |  | 	rt2 = rect2; | 
					
						
							|  |  |  | 	rt = out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	fac2 = facf0; | 
					
						
							|  |  |  | 	fac1 = 1.0f - fac2; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (y--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo * 4; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 			*rt = gammaCorrect(fac1 * invGammaCorrect(*rt1) + fac2 * invGammaCorrect(*rt2)); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			rt1++; rt2++; rt++; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		if (y == 0) | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		y--; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo * 4; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 			*rt = gammaCorrect(fac1 * invGammaCorrect(*rt1) + fac2 * invGammaCorrect(*rt2)); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			rt1++; rt2++; rt++; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static struct ImBuf *gammacross_init_execution(const SeqRenderData *context, ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *ibuf3) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:38 +00:00
										 |  |  | 	ImBuf *out = prepare_effect_imbufs(context, ibuf1, ibuf2, ibuf3); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	build_gammatabs(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 	return out; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static void do_gammacross_effect(const SeqRenderData *context, Sequence *UNUSED(seq), float UNUSED(cfra), | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  |                                  float facf0, float facf1, ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *UNUSED(ibuf3), | 
					
						
							|  |  |  |                                  int start_line, int total_lines, ImBuf *out) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	if (out->rect_float) { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		float *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_float_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_gammacross_effect_float(facf0, facf1, context->rectx, total_lines, rect1, rect2, rect_out); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		unsigned char *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_byte_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_gammacross_effect_byte(facf0, facf1, context->rectx, total_lines, rect1, rect2, rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** Add *************************/ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void do_add_effect_byte(float facf0, float facf1, int x, int y, unsigned char *rect1, unsigned char *rect2, | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  |                                unsigned char *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-04-09 16:20:24 +00:00
										 |  |  | 	int xo, fac1, fac3; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	unsigned char *cp1, *cp2, *rt; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	xo = x; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	cp1 = rect1; | 
					
						
							|  |  |  | 	cp2 = rect2; | 
					
						
							|  |  |  | 	rt = out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-09 16:20:24 +00:00
										 |  |  | 	fac1 = (int)(256.0f * facf0); | 
					
						
							|  |  |  | 	fac3 = (int)(256.0f * facf1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (y--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2013-04-09 16:20:24 +00:00
										 |  |  | 			rt[0] = min_ii(cp1[0] + ((fac1 * cp2[0]) >> 8), 255); | 
					
						
							|  |  |  | 			rt[1] = min_ii(cp1[1] + ((fac1 * cp2[1]) >> 8), 255); | 
					
						
							|  |  |  | 			rt[2] = min_ii(cp1[2] + ((fac1 * cp2[2]) >> 8), 255); | 
					
						
							|  |  |  | 			rt[3] = cp1[3]; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			cp1 += 4; cp2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		if (y == 0) | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		y--; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2013-04-09 16:20:24 +00:00
										 |  |  | 			rt[0] = min_ii(cp1[0] + ((fac3 * cp2[0]) >> 8), 255); | 
					
						
							|  |  |  | 			rt[1] = min_ii(cp1[1] + ((fac3 * cp2[1]) >> 8), 255); | 
					
						
							|  |  |  | 			rt[2] = min_ii(cp1[2] + ((fac3 * cp2[2]) >> 8), 255); | 
					
						
							|  |  |  | 			rt[3] = cp1[3]; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			cp1 += 4; cp2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void do_add_effect_float(float facf0, float facf1, int x, int y, float *rect1, float *rect2, float *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int xo; | 
					
						
							| 
									
										
										
										
											2013-04-09 16:20:24 +00:00
										 |  |  | 	float m, fac1, fac3; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	float *rt1, *rt2, *rt; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	xo = x; | 
					
						
							|  |  |  | 	rt1 = rect1; | 
					
						
							|  |  |  | 	rt2 = rect2; | 
					
						
							|  |  |  | 	rt = out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	fac1 = facf0; | 
					
						
							|  |  |  | 	fac3 = facf1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (y--) { | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2013-04-09 16:20:24 +00:00
										 |  |  | 			m = 1.0f - (rt1[3] * (1.0f - fac1)); | 
					
						
							|  |  |  | 			rt[0] = rt1[0] + m * rt2[0]; | 
					
						
							|  |  |  | 			rt[1] = rt1[1] + m * rt2[1]; | 
					
						
							|  |  |  | 			rt[2] = rt1[2] + m * rt2[2]; | 
					
						
							|  |  |  | 			rt[3] = rt1[3]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		if (y == 0) | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		y--; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2013-04-09 16:20:24 +00:00
										 |  |  | 			m = 1.0f - (rt1[3] * (1.0f - fac3)); | 
					
						
							|  |  |  | 			rt[0] = rt1[0] + m * rt2[0]; | 
					
						
							|  |  |  | 			rt[1] = rt1[1] + m * rt2[1]; | 
					
						
							|  |  |  | 			rt[2] = rt1[2] + m * rt2[2]; | 
					
						
							|  |  |  | 			rt[3] = rt1[3]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static void do_add_effect(const SeqRenderData *context, Sequence *UNUSED(seq), float UNUSED(cfra), float facf0, float facf1, | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  |                           ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *UNUSED(ibuf3), int start_line, int total_lines, ImBuf *out) | 
					
						
							| 
									
										
										
										
											2012-05-17 23:21:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	if (out->rect_float) { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		float *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_float_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_add_effect_float(facf0, facf1, context->rectx, total_lines, rect1, rect2, rect_out); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		unsigned char *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_byte_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_add_effect_byte(facf0, facf1, context->rectx, total_lines, rect1, rect2, rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** Sub *************************/ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | static void do_sub_effect_byte(float facf0, float facf1, int x, int y, unsigned char *rect1, unsigned char *rect2, unsigned char *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-04-09 16:20:24 +00:00
										 |  |  | 	int xo, fac1, fac3; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	unsigned char *cp1, *cp2, *rt; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	xo = x; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	cp1 = rect1; | 
					
						
							|  |  |  | 	cp2 = rect2; | 
					
						
							|  |  |  | 	rt = out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-09 16:20:24 +00:00
										 |  |  | 	fac1 = (int) (256.0f * facf0); | 
					
						
							|  |  |  | 	fac3 = (int) (256.0f * facf1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (y--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2013-04-09 16:20:24 +00:00
										 |  |  | 			rt[0] = max_ii(cp1[0] - ((fac1 * cp2[0]) >> 8), 0); | 
					
						
							|  |  |  | 			rt[1] = max_ii(cp1[1] - ((fac1 * cp2[1]) >> 8), 0); | 
					
						
							|  |  |  | 			rt[2] = max_ii(cp1[2] - ((fac1 * cp2[2]) >> 8), 0); | 
					
						
							|  |  |  | 			rt[3] = cp1[3]; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			cp1 += 4; cp2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		if (y == 0) | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		y--; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2013-04-09 16:20:24 +00:00
										 |  |  | 			rt[0] = max_ii(cp1[0] - ((fac3 * cp2[0]) >> 8), 0); | 
					
						
							|  |  |  | 			rt[1] = max_ii(cp1[1] - ((fac3 * cp2[1]) >> 8), 0); | 
					
						
							|  |  |  | 			rt[2] = max_ii(cp1[2] - ((fac3 * cp2[2]) >> 8), 0); | 
					
						
							|  |  |  | 			rt[3] = cp1[3]; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			cp1 += 4; cp2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-28 15:37:18 +00:00
										 |  |  | static void do_sub_effect_float(float UNUSED(facf0), float facf1, int x, int y, float *rect1, float *rect2, float *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int xo; | 
					
						
							| 
									
										
										
										
											2013-04-28 15:37:18 +00:00
										 |  |  | 	float m /*, fac1*/, fac3; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	float *rt1, *rt2, *rt; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	xo = x; | 
					
						
							|  |  |  | 	rt1 = rect1; | 
					
						
							|  |  |  | 	rt2 = rect2; | 
					
						
							|  |  |  | 	rt = out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-28 15:37:18 +00:00
										 |  |  | 	/* UNUSED */ | 
					
						
							|  |  |  | 	// fac1 = facf0;
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	fac3 = facf1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (y--) { | 
					
						
							| 
									
										
										
										
											2013-03-28 08:21:29 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2013-04-09 16:20:24 +00:00
										 |  |  | 			m = 1.0f - (rt1[3] * (1 - fac3)); | 
					
						
							|  |  |  | 			rt[0] = max_ff(rt1[0] - m * rt2[0], 0.0f); | 
					
						
							|  |  |  | 			rt[1] = max_ff(rt1[1] - m * rt2[1], 0.0f); | 
					
						
							|  |  |  | 			rt[2] = max_ff(rt1[2] - m * rt2[2], 0.0f); | 
					
						
							|  |  |  | 			rt[3] = rt1[3]; | 
					
						
							| 
									
										
										
										
											2013-03-28 08:21:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		if (y == 0) | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		y--; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-28 08:21:29 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2013-04-09 16:20:24 +00:00
										 |  |  | 			m = 1.0f - (rt1[3] * (1 - fac3)); | 
					
						
							|  |  |  | 			rt[0] = max_ff(rt1[0] - m * rt2[0], 0.0f); | 
					
						
							|  |  |  | 			rt[1] = max_ff(rt1[1] - m * rt2[1], 0.0f); | 
					
						
							|  |  |  | 			rt[2] = max_ff(rt1[2] - m * rt2[2], 0.0f); | 
					
						
							|  |  |  | 			rt[3] = rt1[3]; | 
					
						
							| 
									
										
										
										
											2013-03-28 08:21:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static void do_sub_effect(const SeqRenderData *context, Sequence *UNUSED(seq), float UNUSED(cfra), float facf0, float facf1, | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  |                           ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *UNUSED(ibuf3), int start_line, int total_lines, ImBuf *out) | 
					
						
							| 
									
										
										
										
											2012-05-17 23:21:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	if (out->rect_float) { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		float *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_float_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_sub_effect_float(facf0, facf1, context->rectx, total_lines, rect1, rect2, rect_out); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		unsigned char *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_byte_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_sub_effect_byte(facf0, facf1, context->rectx, total_lines, rect1, rect2, rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** Drop *************************/ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* Must be > 0 or add precopy, etc to the function */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | #define XOFF    8
 | 
					
						
							|  |  |  | #define YOFF    8
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | static void do_drop_effect_byte(float facf0, float facf1, int x, int y, unsigned char *rect2i, unsigned char *rect1i, unsigned char *outi) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int height, width, temp, fac, fac1, fac2; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	unsigned char *rt1, *rt2, *out; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	int field = 1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	width = x; | 
					
						
							|  |  |  | 	height = y; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	fac1 = (int) (70.0f * facf0); | 
					
						
							|  |  |  | 	fac2 = (int) (70.0f * facf1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	rt2 = (unsigned char *) (rect2i + YOFF * width); | 
					
						
							|  |  |  | 	rt1 = (unsigned char *) rect1i; | 
					
						
							|  |  |  | 	out = (unsigned char *) outi; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	for (y = 0; y < height - YOFF; y++) { | 
					
						
							|  |  |  | 		if (field) fac = fac1; | 
					
						
							|  |  |  | 		else fac = fac2; | 
					
						
							|  |  |  | 		field = !field; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		memcpy(out, rt1, sizeof(int) * XOFF); | 
					
						
							|  |  |  | 		rt1 += XOFF * 4; | 
					
						
							|  |  |  | 		out += XOFF * 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		for (x = XOFF; x < width; x++) { | 
					
						
							|  |  |  | 			temp = ((fac * rt2[3]) >> 8); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			*(out++) = MAX2(0, *rt1 - temp); rt1++; | 
					
						
							|  |  |  | 			*(out++) = MAX2(0, *rt1 - temp); rt1++; | 
					
						
							|  |  |  | 			*(out++) = MAX2(0, *rt1 - temp); rt1++; | 
					
						
							|  |  |  | 			*(out++) = MAX2(0, *rt1 - temp); rt1++; | 
					
						
							|  |  |  | 			rt2 += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		rt2 += XOFF * 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	memcpy(out, rt1, sizeof(int) * YOFF * width); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void do_drop_effect_float(float facf0, float facf1, int x, int y, float *rect2i, float *rect1i, float *outi) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int height, width; | 
					
						
							|  |  |  | 	float temp, fac, fac1, fac2; | 
					
						
							|  |  |  | 	float *rt1, *rt2, *out; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	int field = 1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	width = x; | 
					
						
							|  |  |  | 	height = y; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	fac1 = 70.0f * facf0; | 
					
						
							|  |  |  | 	fac2 = 70.0f * facf1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	rt2 =  (rect2i + YOFF * width); | 
					
						
							|  |  |  | 	rt1 =  rect1i; | 
					
						
							|  |  |  | 	out =  outi; | 
					
						
							|  |  |  | 	for (y = 0; y < height - YOFF; y++) { | 
					
						
							|  |  |  | 		if (field) fac = fac1; | 
					
						
							|  |  |  | 		else fac = fac2; | 
					
						
							|  |  |  | 		field = !field; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		memcpy(out, rt1, 4 * sizeof(float) * XOFF); | 
					
						
							|  |  |  | 		rt1 += XOFF * 4; | 
					
						
							|  |  |  | 		out += XOFF * 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		for (x = XOFF; x < width; x++) { | 
					
						
							|  |  |  | 			temp = fac * rt2[3]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			*(out++) = MAX2(0.0f, *rt1 - temp); rt1++; | 
					
						
							|  |  |  | 			*(out++) = MAX2(0.0f, *rt1 - temp); rt1++; | 
					
						
							|  |  |  | 			*(out++) = MAX2(0.0f, *rt1 - temp); rt1++; | 
					
						
							|  |  |  | 			*(out++) = MAX2(0.0f, *rt1 - temp); rt1++; | 
					
						
							|  |  |  | 			rt2 += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		rt2 += XOFF * 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	memcpy(out, rt1, 4 * sizeof(float) * YOFF * width); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** Mul *************************/ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void do_mul_effect_byte(float facf0, float facf1, int x, int y, unsigned char *rect1, unsigned char *rect2, | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  |                                unsigned char *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int xo, fac1, fac3; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	unsigned char *rt1, *rt2, *rt; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	xo = x; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	rt1 = rect1; | 
					
						
							|  |  |  | 	rt2 = rect2; | 
					
						
							|  |  |  | 	rt = out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	fac1 = (int)(256.0f * facf0); | 
					
						
							|  |  |  | 	fac3 = (int)(256.0f * facf1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* formula:
 | 
					
						
							| 
									
										
										
										
											2013-01-07 03:24:22 +00:00
										 |  |  | 	 *		fac * (a * b) + (1 - fac) * a  => fac * a * (b - 1) + axaux = c * px + py * s; //+centx
 | 
					
						
							| 
									
										
										
										
											2012-05-27 19:40:36 +00:00
										 |  |  | 	 *		yaux = -s * px + c * py; //+centy
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (y--) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-09 16:20:24 +00:00
										 |  |  | 			rt[0] = rt1[0] + ((fac1 * rt1[0] * (rt2[0] - 255)) >> 16); | 
					
						
							|  |  |  | 			rt[1] = rt1[1] + ((fac1 * rt1[1] * (rt2[1] - 255)) >> 16); | 
					
						
							|  |  |  | 			rt[2] = rt1[2] + ((fac1 * rt1[2] * (rt2[2] - 255)) >> 16); | 
					
						
							|  |  |  | 			rt[3] = rt1[3] + ((fac1 * rt1[3] * (rt2[3] - 255)) >> 16); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		if (y == 0) break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		y--; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-09 16:20:24 +00:00
										 |  |  | 			rt[0] = rt1[0] + ((fac3 * rt1[0] * (rt2[0] - 255)) >> 16); | 
					
						
							|  |  |  | 			rt[1] = rt1[1] + ((fac3 * rt1[1] * (rt2[1] - 255)) >> 16); | 
					
						
							|  |  |  | 			rt[2] = rt1[2] + ((fac3 * rt1[2] * (rt2[2] - 255)) >> 16); | 
					
						
							|  |  |  | 			rt[3] = rt1[3] + ((fac3 * rt1[3] * (rt2[3] - 255)) >> 16); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void do_mul_effect_float(float facf0, float facf1, int x, int y, float *rect1, float *rect2, float *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int xo; | 
					
						
							|  |  |  | 	float fac1, fac3; | 
					
						
							|  |  |  | 	float *rt1, *rt2, *rt; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	xo = x; | 
					
						
							|  |  |  | 	rt1 = rect1; | 
					
						
							|  |  |  | 	rt2 = rect2; | 
					
						
							|  |  |  | 	rt = out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	fac1 = facf0; | 
					
						
							|  |  |  | 	fac3 = facf1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* formula:
 | 
					
						
							| 
									
										
										
										
											2012-10-27 10:42:28 +00:00
										 |  |  | 	 * fac * (a * b) + (1 - fac) * a  =>  fac * a * (b - 1) + a | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	while (y--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt[0] = rt1[0] + fac1 * rt1[0] * (rt2[0] - 1.0f); | 
					
						
							|  |  |  | 			rt[1] = rt1[1] + fac1 * rt1[1] * (rt2[1] - 1.0f); | 
					
						
							|  |  |  | 			rt[2] = rt1[2] + fac1 * rt1[2] * (rt2[2] - 1.0f); | 
					
						
							|  |  |  | 			rt[3] = rt1[3] + fac1 * rt1[3] * (rt2[3] - 1.0f); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		if (y == 0) | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		y--; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		x = xo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		while (x--) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt[0] = rt1[0] + fac3 * rt1[0] * (rt2[0] - 1.0f); | 
					
						
							|  |  |  | 			rt[1] = rt1[1] + fac3 * rt1[1] * (rt2[1] - 1.0f); | 
					
						
							|  |  |  | 			rt[2] = rt1[2] + fac3 * rt1[2] * (rt2[2] - 1.0f); | 
					
						
							|  |  |  | 			rt[3] = rt1[3] + fac3 * rt1[3] * (rt2[3] - 1.0f); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt1 += 4; rt2 += 4; rt += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static void do_mul_effect(const SeqRenderData *context, Sequence *UNUSED(seq), float UNUSED(cfra), float facf0, float facf1, | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  |                           ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *UNUSED(ibuf3), int start_line, int total_lines, ImBuf *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	if (out->rect_float) { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		float *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_float_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_mul_effect_float(facf0, facf1, context->rectx, total_lines, rect1, rect2, rect_out); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		unsigned char *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_byte_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_mul_effect_byte(facf0, facf1, context->rectx, total_lines, rect1, rect2, rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** Wipe *************************/ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | typedef struct WipeZone { | 
					
						
							|  |  |  | 	float angle; | 
					
						
							|  |  |  | 	int flip; | 
					
						
							|  |  |  | 	int xo, yo; | 
					
						
							|  |  |  | 	int width; | 
					
						
							|  |  |  | 	float pythangle; | 
					
						
							|  |  |  | } WipeZone; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void precalc_wipe_zone(WipeZone *wipezone, WipeVars *wipe, int xo, int yo) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
											  
											
												Cleanup: Internal degrees removal.
This patch changes most of the reamining degrees usage in internal code into radians.
I let a few which I know off asside, for reasons explained below - and I'm not sure to have found out all of them.
WARNING: this introduces forward incompatibility, which means files saved from this version won't open 100% correctly
         in previous versions (a few angle properties would use radians values as degrees...).
Details:
- Data:
-- Lamp.spotsize: Game engine exposed this setting in degrees, to not break the API here I kept it as such
                  (using getter/setter functions), still using radians internally.
-- Mesh.smoothresh: Didn't touch to this one, as we will hopefully replace it completely by loop normals currently in dev.
- Modifiers:
-- EdgeSplitModifierData.split_angle, BevelModifierData.bevel_angle: Done.
- Postprocessing:
-- WipeVars.angle (sequencer's effect), NodeBokehImage.angle, NodeBoxMask.rotation, NodeEllipseMask.rotation: Done.
- BGE:
-- bConstraintActuator: Orientation type done (the minloc[0] & maxloc[0] cases). Did not touch to 'limit location' type,
                        it can also limit rotation, but it exposes through RNA the same limit_min/limit_max, which hence
                        can be either distance or angle values, depending on the mode. Will leave this to BGE team.
-- bSoundActuator.cone_outer_angle_3d, bSoundActuator.cone_inner_angle_3d: Done (note I kept degrees in BGE itself,
                                                                           as it seems this is the expected value here...).
-- bRadarSensor.angle: Done.
Reviewers: brecht, campbellbarton, sergey, gaiaclary, dfelinto, moguri, jbakker, lukastoenne, howardt
Reviewed By: brecht, campbellbarton, sergey, gaiaclary, moguri, jbakker, lukastoenne, howardt
Thanks to all!
Differential Revision: http://developer.blender.org/D59
											
										 
											2013-12-03 20:09:25 +01:00
										 |  |  | 	wipezone->flip = (wipe->angle < 0.0f); | 
					
						
							|  |  |  | 	wipezone->angle = tanf(fabsf(wipe->angle)); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	wipezone->xo = xo; | 
					
						
							|  |  |  | 	wipezone->yo = yo; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	wipezone->width = (int)(wipe->edgeWidth * ((xo + yo) / 2.0f)); | 
					
						
							|  |  |  | 	wipezone->pythangle = 1.0f / sqrtf(wipezone->angle * wipezone->angle + 1.0f); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:38 +00:00
										 |  |  | /* This function calculates the blur band for the wipe effects */ | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | static float in_band(float width, float dist, int side, int dir) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-06 10:08:46 +00:00
										 |  |  | 	float alpha; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (width == 0) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		return (float)side; | 
					
						
							| 
									
										
										
										
											2012-01-06 10:08:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (width < dist) | 
					
						
							| 
									
										
										
										
											2012-01-06 10:08:46 +00:00
										 |  |  | 		return (float)side; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (side == 1) | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		alpha = (dist + 0.5f * width) / (width); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		alpha = (0.5f * width - dist) / (width); | 
					
						
							| 
									
										
										
										
											2012-01-06 10:08:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (dir == 0) | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		alpha = 1 - alpha; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return alpha; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static float check_zone(WipeZone *wipezone, int x, int y, Sequence *seq, float facf0) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 	float posx, posy, hyp, hyp2, angle, hwidth, b1, b2, b3, pointdist; | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  | 	/* some future stuff */ | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	/* float hyp3, hyp4, b4, b5 */ | 
					
						
							|  |  |  | 	float temp1, temp2, temp3, temp4; /* some placeholder variables */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	int xo = wipezone->xo; | 
					
						
							|  |  |  | 	int yo = wipezone->yo; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	float halfx = xo * 0.5f; | 
					
						
							|  |  |  | 	float halfy = yo * 0.5f; | 
					
						
							|  |  |  | 	float widthf, output = 0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	WipeVars *wipe = (WipeVars *)seq->effectdata; | 
					
						
							|  |  |  | 	int width; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (wipezone->flip) x = xo - x; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	angle = wipezone->angle; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (wipe->forward) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		posx = facf0 * xo; | 
					
						
							|  |  |  | 		posy = facf0 * yo; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		posx = xo - facf0 * xo; | 
					
						
							|  |  |  | 		posy = yo - facf0 * yo; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	switch (wipe->wipetype) { | 
					
						
							|  |  |  | 		case DO_SINGLE_WIPE: | 
					
						
							| 
									
										
										
										
											2013-01-18 09:36:17 +00:00
										 |  |  | 			width = min_ii(wipezone->width, facf0 * yo); | 
					
						
							|  |  |  | 			width = min_ii(width, yo - facf0 * yo); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (angle == 0.0f) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				b1 = posy; | 
					
						
							|  |  |  | 				b2 = y; | 
					
						
							| 
									
										
										
										
											2014-09-17 14:11:37 +10:00
										 |  |  | 				hyp = fabsf(y - posy); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 				b1 = posy - (-angle) * posx; | 
					
						
							|  |  |  | 				b2 = y - (-angle) * x; | 
					
						
							|  |  |  | 				hyp = fabsf(angle * x + y + (-posy - angle * posx)) * wipezone->pythangle; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (angle < 0) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				temp1 = b1; | 
					
						
							|  |  |  | 				b1 = b2; | 
					
						
							|  |  |  | 				b2 = temp1; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (wipe->forward) { | 
					
						
							|  |  |  | 				if (b1 < b2) | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 					output = in_band(width, hyp, 1, 1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				else | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 					output = in_band(width, hyp, 0, 1); | 
					
						
							| 
									
										
										
										
											2011-04-21 15:53:30 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				if (b1 < b2) | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 					output = in_band(width, hyp, 0, 1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				else | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 					output = in_band(width, hyp, 1, 1); | 
					
						
							| 
									
										
										
										
											2011-04-21 15:53:30 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2011-04-21 15:53:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		case DO_DOUBLE_WIPE: | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (!wipe->forward) | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 				facf0 = 1.0f - facf0;  /* Go the other direction */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 			width = wipezone->width;  /* calculate the blur width */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			hwidth = width * 0.5f; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			if (angle == 0) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 				b1 = posy * 0.5f; | 
					
						
							|  |  |  | 				b3 = yo - posy * 0.5f; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				b2 = y; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-01 13:39:36 +11:00
										 |  |  | 				hyp = fabsf(y - posy * 0.5f); | 
					
						
							|  |  |  | 				hyp2 = fabsf(y - (yo - posy * 0.5f)); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 				b1 = posy * 0.5f - (-angle) * posx * 0.5f; | 
					
						
							|  |  |  | 				b3 = (yo - posy * 0.5f) - (-angle) * (xo - posx * 0.5f); | 
					
						
							|  |  |  | 				b2 = y - (-angle) * x; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 				hyp = fabsf(angle * x + y + (-posy * 0.5f - angle * posx * 0.5f)) * wipezone->pythangle; | 
					
						
							|  |  |  | 				hyp2 = fabsf(angle * x + y + (-(yo - posy * 0.5f) - angle * (xo - posx * 0.5f))) * wipezone->pythangle; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-23 13:28:22 +00:00
										 |  |  | 			hwidth = min_ff(hwidth, fabsf(b3 - b1) / 2.0f); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			if (b2 < b1 && b2 < b3) { | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 				output = in_band(hwidth, hyp, 0, 1); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			else if (b2 > b1 && b2 > b3) { | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 				output = in_band(hwidth, hyp2, 0, 1); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 				if (hyp < hwidth && hyp2 > hwidth) | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 					output = in_band(hwidth, hyp, 1, 1); | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 				else if (hyp > hwidth && hyp2 < hwidth) | 
					
						
							|  |  |  | 					output = in_band(hwidth, hyp2, 1, 1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				else | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 					output = in_band(hwidth, hyp2, 1, 1) * in_band(hwidth, hyp, 1, 1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			if (!wipe->forward) output = 1 - output; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2011-04-21 15:53:30 +00:00
										 |  |  | 		case DO_CLOCK_WIPE: | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  | 			/*
 | 
					
						
							|  |  |  | 			 *  temp1: angle of effect center in rads | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 			 *  temp2: angle of line through (halfx, halfy) and (x, y) in rads | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  | 			 *  temp3: angle of low side of blur | 
					
						
							|  |  |  | 			 *  temp4: angle of high side of blur | 
					
						
							|  |  |  | 			 */ | 
					
						
							| 
									
										
										
										
											2011-04-21 15:53:30 +00:00
										 |  |  | 			output = 1.0f - facf0; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			widthf = wipe->edgeWidth * 2.0f * (float)M_PI; | 
					
						
							| 
									
										
										
										
											2011-04-21 15:53:30 +00:00
										 |  |  | 			temp1 = 2.0f * (float)M_PI * facf0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (wipe->forward) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 				temp1 = 2.0f * (float)M_PI - temp1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-04-21 15:53:30 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			x = x - halfx; | 
					
						
							|  |  |  | 			y = y - halfy; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-14 17:27:50 +10:00
										 |  |  | 			temp2 = asin(abs(y) / hypot(x, y)); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (x <= 0 && y >= 0) temp2 = (float)M_PI - temp2; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			else if (x <= 0 && y <= 0) temp2 += (float)M_PI; | 
					
						
							|  |  |  | 			else if (x >= 0 && y <= 0) temp2 = 2.0f * (float)M_PI - temp2; | 
					
						
							| 
									
										
										
										
											2011-04-21 15:53:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (wipe->forward) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 				temp3 = temp1 - (widthf * 0.5f) * facf0; | 
					
						
							|  |  |  | 				temp4 = temp1 + (widthf * 0.5f) * (1 - facf0); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 				temp3 = temp1 - (widthf * 0.5f) * (1 - facf0); | 
					
						
							|  |  |  | 				temp4 = temp1 + (widthf * 0.5f) * facf0; | 
					
						
							| 
									
										
										
										
											2011-04-21 15:53:30 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			if (temp3 < 0) temp3 = 0; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			if (temp4 > 2.0f * (float)M_PI) temp4 = 2.0f * (float)M_PI; | 
					
						
							| 
									
										
										
										
											2011-04-21 15:53:30 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (temp2 < temp3) output = 0; | 
					
						
							| 
									
										
										
										
											2011-04-21 15:53:30 +00:00
										 |  |  | 			else if (temp2 > temp4) output = 1; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			else output = (temp2 - temp3) / (temp4 - temp3); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (x == 0 && y == 0) output = 1; | 
					
						
							|  |  |  | 			if (output != output) output = 1; | 
					
						
							|  |  |  | 			if (wipe->forward) output = 1 - output; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 			/* BOX WIPE IS NOT WORKING YET */ | 
					
						
							|  |  |  | 			/* case DO_CROSS_WIPE: */ | 
					
						
							|  |  |  | 			/* BOX WIPE IS NOT WORKING YET */ | 
					
						
							| 
									
										
										
										
											2012-04-22 11:54:53 +00:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		case DO_BOX_WIPE:  | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			if (invert) facf0 = 1 - facf0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			width = (int)(wipe->edgeWidth * ((xo + yo) / 2.0)); | 
					
						
							|  |  |  | 			hwidth = (float)width / 2.0; | 
					
						
							|  |  |  | 			if (angle == 0) angle = 0.000001; | 
					
						
							|  |  |  | 			b1 = posy / 2 - (-angle) * posx / 2; | 
					
						
							|  |  |  | 			b3 = (yo - posy / 2) - (-angle) * (xo - posx / 2); | 
					
						
							|  |  |  | 			b2 = y - (-angle) * x; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			hyp = abs(angle * x + y + (-posy / 2 - angle * posx / 2)) * wipezone->pythangle; | 
					
						
							|  |  |  | 			hyp2 = abs(angle * x + y + (-(yo - posy / 2) - angle * (xo - posx / 2))) * wipezone->pythangle; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			temp1 = xo * (1 - facf0 / 2) - xo * facf0 / 2; | 
					
						
							|  |  |  | 			temp2 = yo * (1 - facf0 / 2) - yo * facf0 / 2; | 
					
						
							| 
									
										
										
										
											2014-06-14 17:27:50 +10:00
										 |  |  | 			pointdist = hypot(temp1, temp2); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			if (b2 < b1 && b2 < b3) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				if (hwidth < pointdist) | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 					output = in_band(wipezone, hwidth, hyp, facf0, 0, 1); | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else if (b2 > b1 && b2 > b3) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				if (hwidth < pointdist) | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 					output = in_band(wipezone, hwidth, hyp2, facf0, 0, 1); | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				if (hyp < hwidth && hyp2 > hwidth) | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 					output = in_band(wipezone, hwidth, hyp, facf0, 1, 1); | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 				else if (hyp > hwidth && hyp2 < hwidth) | 
					
						
							|  |  |  | 					output = in_band(wipezone, hwidth, hyp2, facf0, 1, 1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				else | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 					output = in_band(wipezone, hwidth, hyp2, facf0, 1, 1) * in_band(wipezone, hwidth, hyp, facf0, 1, 1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			if (invert) facf0 = 1 - facf0; | 
					
						
							|  |  |  | 			angle = -1 / angle; | 
					
						
							|  |  |  | 			b1 = posy / 2 - (-angle) * posx / 2; | 
					
						
							|  |  |  | 			b3 = (yo - posy / 2) - (-angle) * (xo - posx / 2); | 
					
						
							|  |  |  | 			b2 = y - (-angle) * x; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			hyp = abs(angle * x + y + (-posy / 2 - angle * posx / 2)) * wipezone->pythangle; | 
					
						
							|  |  |  | 			hyp2 = abs(angle * x + y + (-(yo - posy / 2) - angle * (xo - posx / 2))) * wipezone->pythangle; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			if (b2 < b1 && b2 < b3) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				if (hwidth < pointdist) | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 					output *= in_band(wipezone, hwidth, hyp, facf0, 0, 1); | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else if (b2 > b1 && b2 > b3) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				if (hwidth < pointdist) | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 					output *= in_band(wipezone, hwidth, hyp2, facf0, 0, 1); | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				if (hyp < hwidth && hyp2 > hwidth) | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 					output *= in_band(wipezone, hwidth, hyp, facf0, 1, 1); | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 				else if (hyp > hwidth && hyp2 < hwidth) | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 					output *= in_band(wipezone, hwidth, hyp2, facf0, 1, 1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				else | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 					output *= in_band(wipezone, hwidth, hyp2, facf0, 1, 1) * in_band(wipezone, hwidth, hyp, facf0, 1, 1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-04-22 11:54:53 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		case DO_IRIS_WIPE: | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (xo > yo) yo = xo; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			else xo = yo; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			if (!wipe->forward) facf0 = 1 - facf0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			width = wipezone->width; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			hwidth = width * 0.5f; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			temp1 = (halfx - (halfx) * facf0); | 
					
						
							| 
									
										
										
										
											2014-06-14 17:27:50 +10:00
										 |  |  | 			pointdist = hypotf(temp1, temp1); | 
					
						
							| 
									
										
										
										
											2011-04-21 15:53:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-14 17:27:50 +10:00
										 |  |  | 			temp2 = hypotf(halfx - x, halfy - y); | 
					
						
							| 
									
										
										
										
											2014-03-01 14:20:54 +11:00
										 |  |  | 			if (temp2 > pointdist) output = in_band(hwidth, fabsf(temp2 - pointdist), 0, 1); | 
					
						
							|  |  |  | 			else output = in_band(hwidth, fabsf(temp2 - pointdist), 1, 1); | 
					
						
							| 
									
										
										
										
											2011-04-21 15:53:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			if (!wipe->forward) output = 1 - output; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	if (output < 0) output = 0; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	else if (output > 1) output = 1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	return output; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void init_wipe_effect(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	if (seq->effectdata) | 
					
						
							|  |  |  | 		MEM_freeN(seq->effectdata); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:38 +00:00
										 |  |  | 	seq->effectdata = MEM_callocN(sizeof(WipeVars), "wipevars"); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 12:30:59 +00:00
										 |  |  | static int num_inputs_wipe(void) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void free_wipe_effect(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	if (seq->effectdata) | 
					
						
							|  |  |  | 		MEM_freeN(seq->effectdata); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 	seq->effectdata = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void copy_wipe_effect(Sequence *dst, Sequence *src) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	dst->effectdata = MEM_dupallocN(src->effectdata); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void do_wipe_effect_byte(Sequence *seq, float facf0, float UNUSED(facf1),  int x, int y, unsigned char *rect1, | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  |                                 unsigned char *rect2, unsigned char *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	WipeZone wipezone; | 
					
						
							|  |  |  | 	WipeVars *wipe = (WipeVars *)seq->effectdata; | 
					
						
							|  |  |  | 	int xo, yo; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	unsigned char *cp1, *cp2, *rt; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	precalc_wipe_zone(&wipezone, wipe, x, y); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	cp1 = rect1; | 
					
						
							|  |  |  | 	cp2 = rect2; | 
					
						
							|  |  |  | 	rt = out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	xo = x; | 
					
						
							|  |  |  | 	yo = y; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	for (y = 0; y < yo; y++) { | 
					
						
							|  |  |  | 		for (x = 0; x < xo; x++) { | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 			float check = check_zone(&wipezone, x, y, seq, facf0); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			if (check) { | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 				if (cp1) { | 
					
						
							|  |  |  | 					float rt1[4], rt2[4], tempc[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					straight_uchar_to_premul_float(rt1, cp1); | 
					
						
							|  |  |  | 					straight_uchar_to_premul_float(rt2, cp2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					tempc[0] = rt1[0] * check + rt2[0] * (1 - check); | 
					
						
							|  |  |  | 					tempc[1] = rt1[1] * check + rt2[1] * (1 - check); | 
					
						
							|  |  |  | 					tempc[2] = rt1[2] * check + rt2[2] * (1 - check); | 
					
						
							|  |  |  | 					tempc[3] = rt1[3] * check + rt2[3] * (1 - check); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					premul_float_to_straight_uchar(rt, tempc); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 					rt[0] = 0; | 
					
						
							|  |  |  | 					rt[1] = 0; | 
					
						
							|  |  |  | 					rt[2] = 0; | 
					
						
							|  |  |  | 					rt[3] = 255; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 				if (cp2) { | 
					
						
							|  |  |  | 					rt[0] = cp2[0]; | 
					
						
							|  |  |  | 					rt[1] = cp2[1]; | 
					
						
							|  |  |  | 					rt[2] = cp2[2]; | 
					
						
							|  |  |  | 					rt[3] = cp2[3]; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 					rt[0] = 0; | 
					
						
							|  |  |  | 					rt[1] = 0; | 
					
						
							|  |  |  | 					rt[2] = 0; | 
					
						
							|  |  |  | 					rt[3] = 255; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt += 4; | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 			if (cp1 != NULL) { | 
					
						
							|  |  |  | 				cp1 += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 			if (cp2 != NULL) { | 
					
						
							|  |  |  | 				cp2 += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void do_wipe_effect_float(Sequence *seq, float facf0, float UNUSED(facf1), int x, int y, float *rect1, | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  |                                  float *rect2, float *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	WipeZone wipezone; | 
					
						
							|  |  |  | 	WipeVars *wipe = (WipeVars *)seq->effectdata; | 
					
						
							|  |  |  | 	int xo, yo; | 
					
						
							|  |  |  | 	float *rt1, *rt2, *rt; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	precalc_wipe_zone(&wipezone, wipe, x, y); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	rt1 = rect1; | 
					
						
							|  |  |  | 	rt2 = rect2; | 
					
						
							|  |  |  | 	rt = out; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	xo = x; | 
					
						
							|  |  |  | 	yo = y; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	for (y = 0; y < yo; y++) { | 
					
						
							|  |  |  | 		for (x = 0; x < xo; x++) { | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 			float check = check_zone(&wipezone, x, y, seq, facf0); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			if (check) { | 
					
						
							|  |  |  | 				if (rt1) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 					rt[0] = rt1[0] * check + rt2[0] * (1 - check); | 
					
						
							|  |  |  | 					rt[1] = rt1[1] * check + rt2[1] * (1 - check); | 
					
						
							|  |  |  | 					rt[2] = rt1[2] * check + rt2[2] * (1 - check); | 
					
						
							|  |  |  | 					rt[3] = rt1[3] * check + rt2[3] * (1 - check); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 					rt[0] = 0; | 
					
						
							|  |  |  | 					rt[1] = 0; | 
					
						
							|  |  |  | 					rt[2] = 0; | 
					
						
							|  |  |  | 					rt[3] = 1.0; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				if (rt2) { | 
					
						
							|  |  |  | 					rt[0] = rt2[0]; | 
					
						
							|  |  |  | 					rt[1] = rt2[1]; | 
					
						
							|  |  |  | 					rt[2] = rt2[2]; | 
					
						
							|  |  |  | 					rt[3] = rt2[3]; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 					rt[0] = 0; | 
					
						
							|  |  |  | 					rt[1] = 0; | 
					
						
							|  |  |  | 					rt[2] = 0; | 
					
						
							|  |  |  | 					rt[3] = 1.0; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rt += 4; | 
					
						
							|  |  |  | 			if (rt1 != NULL) { | 
					
						
							|  |  |  | 				rt1 += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			if (rt2 != NULL) { | 
					
						
							|  |  |  | 				rt2 += 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static ImBuf *do_wipe_effect(const SeqRenderData *context, Sequence *seq, float UNUSED(cfra), float facf0, float facf1, | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  |                              ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *ibuf3) | 
					
						
							| 
									
										
										
										
											2012-05-17 23:21:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:38 +00:00
										 |  |  | 	ImBuf *out = prepare_effect_imbufs(context, ibuf1, ibuf2, ibuf3); | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	if (out->rect_float) { | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_wipe_effect_float(seq, facf0, facf1, context->rectx, context->recty, ibuf1->rect_float, | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		                     ibuf2->rect_float, out->rect_float); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_wipe_effect_byte(seq, facf0, facf1, context->rectx, context->recty, (unsigned char *) ibuf1->rect, | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		                    (unsigned char *) ibuf2->rect, (unsigned char *) out->rect); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*********************** Transform *************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | static void init_transform_effect(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-12-11 22:51:53 +00:00
										 |  |  | 	TransformVars *transform; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	if (seq->effectdata) | 
					
						
							|  |  |  | 		MEM_freeN(seq->effectdata); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:38 +00:00
										 |  |  | 	seq->effectdata = MEM_callocN(sizeof(TransformVars), "transformvars"); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	transform = (TransformVars *) seq->effectdata; | 
					
						
							| 
									
										
										
										
											2009-12-11 22:51:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	transform->ScalexIni = 1.0f; | 
					
						
							|  |  |  | 	transform->ScaleyIni = 1.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	transform->xIni = 0.0f; | 
					
						
							|  |  |  | 	transform->yIni = 0.0f; | 
					
						
							| 
									
										
										
										
											2009-12-11 22:51:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	transform->rotIni = 0.0f; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	transform->interpolation = 1; | 
					
						
							|  |  |  | 	transform->percent = 1; | 
					
						
							|  |  |  | 	transform->uniform_scale = 0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 12:30:59 +00:00
										 |  |  | static int num_inputs_transform(void) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void free_transform_effect(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	if (seq->effectdata) MEM_freeN(seq->effectdata); | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 	seq->effectdata = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void copy_transform_effect(Sequence *dst, Sequence *src) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	dst->effectdata = MEM_dupallocN(src->effectdata); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void transform_image(int x, int y, ImBuf *ibuf1, ImBuf *out,  float scale_x, float scale_y, | 
					
						
							|  |  |  |                             float translate_x, float translate_y, float rotate, int interpolation) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int xo, yo, xi, yi; | 
					
						
							| 
									
										
										
										
											2009-12-11 22:51:53 +00:00
										 |  |  | 	float xt, yt, xr, yr; | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 	float s, c; | 
					
						
							| 
									
										
										
										
											2009-02-08 19:28:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	xo = x; | 
					
						
							|  |  |  | 	yo = y; | 
					
						
							| 
									
										
										
										
											2009-12-11 22:51:53 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	/* Rotate */ | 
					
						
							| 
									
										
										
										
											2014-09-17 14:11:37 +10:00
										 |  |  | 	s = sinf(rotate); | 
					
						
							|  |  |  | 	c = cosf(rotate); | 
					
						
							| 
									
										
										
										
											2009-02-08 19:28:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	for (yi = 0; yi < yo; yi++) { | 
					
						
							|  |  |  | 		for (xi = 0; xi < xo; xi++) { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 			/* translate point */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			xt = xi - translate_x; | 
					
						
							|  |  |  | 			yt = yi - translate_y; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 			/* rotate point with center ref */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			xr =  c * xt + s * yt; | 
					
						
							|  |  |  | 			yr = -s * xt + c * yt; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 			/* scale point with center ref */ | 
					
						
							| 
									
										
										
										
											2009-12-11 22:51:53 +00:00
										 |  |  | 			xt = xr / scale_x; | 
					
						
							|  |  |  | 			yt = yr / scale_y; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 			/* undo reference center point  */ | 
					
						
							| 
									
										
										
										
											2009-12-11 22:51:53 +00:00
										 |  |  | 			xt += (xo / 2.0f); | 
					
						
							|  |  |  | 			yt += (yo / 2.0f); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 			/* interpolate */ | 
					
						
							| 
									
										
										
										
											2012-04-28 06:31:57 +00:00
										 |  |  | 			switch (interpolation) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 				case 0: | 
					
						
							| 
									
										
										
										
											2012-12-11 14:19:41 +00:00
										 |  |  | 					nearest_interpolation(ibuf1, out, xt, yt, xi, yi); | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 					break; | 
					
						
							|  |  |  | 				case 1: | 
					
						
							|  |  |  | 					bilinear_interpolation(ibuf1, out, xt, yt, xi, yi); | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				case 2: | 
					
						
							|  |  |  | 					bicubic_interpolation(ibuf1, out, xt, yt, xi, yi); | 
					
						
							|  |  |  | 					break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-12-11 22:51:53 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void do_transform(Scene *scene, Sequence *seq, float UNUSED(facf0), int x, int y,  ImBuf *ibuf1, ImBuf *out) | 
					
						
							| 
									
										
										
										
											2009-12-11 22:51:53 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	TransformVars *transform = (TransformVars *) seq->effectdata; | 
					
						
							| 
									
										
										
										
											2009-12-11 22:51:53 +00:00
										 |  |  | 	float scale_x, scale_y, translate_x, translate_y, rotate_radians; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-07-07 22:51:57 +00:00
										 |  |  | 	/* Scale */ | 
					
						
							| 
									
										
										
										
											2009-12-11 22:51:53 +00:00
										 |  |  | 	if (transform->uniform_scale) { | 
					
						
							|  |  |  | 		scale_x = scale_y = transform->ScalexIni; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2009-12-11 22:51:53 +00:00
										 |  |  | 		scale_x = transform->ScalexIni; | 
					
						
							|  |  |  | 		scale_y = transform->ScaleyIni; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-07 22:51:57 +00:00
										 |  |  | 	/* Translate */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	if (!transform->percent) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		float rd_s = (scene->r.size / 100.0f); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		translate_x = transform->xIni * rd_s + (x / 2.0f); | 
					
						
							|  |  |  | 		translate_y = transform->yIni * rd_s + (y / 2.0f); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		translate_x = x * (transform->xIni / 100.0f) + (x / 2.0f); | 
					
						
							|  |  |  | 		translate_y = y * (transform->yIni / 100.0f) + (y / 2.0f); | 
					
						
							| 
									
										
										
										
											2009-12-11 22:51:53 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-07-07 22:51:57 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* Rotate */ | 
					
						
							| 
									
										
										
										
											2011-09-17 09:43:51 +00:00
										 |  |  | 	rotate_radians = DEG2RADF(transform->rotIni); | 
					
						
							| 
									
										
										
										
											2009-12-11 22:51:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 	transform_image(x, y, ibuf1, out, scale_x, scale_y, translate_x, translate_y, rotate_radians, transform->interpolation); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-12-11 22:51:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static ImBuf *do_transform_effect(const SeqRenderData *context, Sequence *seq, float UNUSED(cfra), float facf0, | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  |                                   float UNUSED(facf1), ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *ibuf3) | 
					
						
							| 
									
										
										
										
											2012-05-17 23:21:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:38 +00:00
										 |  |  | 	ImBuf *out = prepare_effect_imbufs(context, ibuf1, ibuf2, ibuf3); | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 	do_transform(context->scene, seq, facf0, context->rectx, context->recty, ibuf1, out); | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** Glow *************************/ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void RVBlurBitmap2_float(float *map, int width, int height, float blur, int quality) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | /*	MUUUCCH better than the previous blur. */ | 
					
						
							|  |  |  | /*	We do the blurring in two passes which is a whole lot faster. */ | 
					
						
							|  |  |  | /*	I changed the math arount to implement an actual Gaussian */ | 
					
						
							|  |  |  | /*	distribution. */ | 
					
						
							|  |  |  | /* */ | 
					
						
							|  |  |  | /*	Watch out though, it tends to misbehaven with large blur values on */ | 
					
						
							|  |  |  | /*	a small bitmap.  Avoid avoid avoid. */ | 
					
						
							|  |  |  | /*=============================== */ | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	float *temp = NULL, *swap; | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	float *filter = NULL; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	int x, y, i, fx, fy; | 
					
						
							|  |  |  | 	int index, ix, halfWidth; | 
					
						
							|  |  |  | 	float fval, k, curColor[3], curColor2[3], weight = 0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	/* If we're not really blurring, bail out */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	if (blur <= 0) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	/* Allocate memory for the tempmap and the blur filter matrix */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	temp = MEM_mallocN((width * height * 4 * sizeof(float)), "blurbitmaptemp"); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	if (!temp) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	/* Allocate memory for the filter elements */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	halfWidth = ((quality + 1) * blur); | 
					
						
							|  |  |  | 	filter = (float *)MEM_mallocN(sizeof(float) * halfWidth * 2, "blurbitmapfilter"); | 
					
						
							| 
									
										
										
										
											2012-02-27 10:35:39 +00:00
										 |  |  | 	if (!filter) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		MEM_freeN(temp); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	/* Apparently we're calculating a bell curve based on the standard deviation (or radius)
 | 
					
						
							|  |  |  | 	 * This code is based on an example posted to comp.graphics.algorithms by | 
					
						
							|  |  |  | 	 * Blancmange (bmange@airdmhor.gen.nz) | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	k = -1.0f / (2.0f * (float)M_PI * blur * blur); | 
					
						
							| 
									
										
										
										
											2011-07-27 06:55:20 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	for (ix = 0; ix < halfWidth; ix++) { | 
					
						
							|  |  |  | 		weight = (float)exp(k * (ix * ix)); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		filter[halfWidth - ix] = weight; | 
					
						
							|  |  |  | 		filter[halfWidth + ix] = weight; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	filter[0] = weight; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	/* Normalize the array */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	fval = 0; | 
					
						
							|  |  |  | 	for (ix = 0; ix < halfWidth * 2; ix++) | 
					
						
							|  |  |  | 		fval += filter[ix]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	for (ix = 0; ix < halfWidth * 2; ix++) | 
					
						
							|  |  |  | 		filter[ix] /= fval; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	/* Blur the rows */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	for (y = 0; y < height; y++) { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		/* Do the left & right strips */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		for (x = 0; x < halfWidth; x++) { | 
					
						
							|  |  |  | 			index = (x + y * width) * 4; | 
					
						
							|  |  |  | 			fx = 0; | 
					
						
							|  |  |  | 			curColor[0] = curColor[1] = curColor[2] = 0.0f; | 
					
						
							|  |  |  | 			curColor2[0] = curColor2[1] = curColor2[2] = 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			for (i = x - halfWidth; i < x + halfWidth; i++) { | 
					
						
							|  |  |  | 				if ((i >= 0) && (i < width)) { | 
					
						
							|  |  |  | 					curColor[0] += map[(i + y * width) * 4 + GlowR] * filter[fx]; | 
					
						
							|  |  |  | 					curColor[1] += map[(i + y * width) * 4 + GlowG] * filter[fx]; | 
					
						
							|  |  |  | 					curColor[2] += map[(i + y * width) * 4 + GlowB] * filter[fx]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 					curColor2[0] += map[(width - 1 - i + y * width) * 4 + GlowR] * filter[fx]; | 
					
						
							|  |  |  | 					curColor2[1] += map[(width - 1 - i + y * width) * 4 + GlowG] * filter[fx]; | 
					
						
							|  |  |  | 					curColor2[2] += map[(width - 1 - i + y * width) * 4 + GlowB] * filter[fx]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				fx++; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			temp[index + GlowR] = curColor[0]; | 
					
						
							|  |  |  | 			temp[index + GlowG] = curColor[1]; | 
					
						
							|  |  |  | 			temp[index + GlowB] = curColor[2]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			temp[((width - 1 - x + y * width) * 4) + GlowR] = curColor2[0]; | 
					
						
							|  |  |  | 			temp[((width - 1 - x + y * width) * 4) + GlowG] = curColor2[1]; | 
					
						
							|  |  |  | 			temp[((width - 1 - x + y * width) * 4) + GlowB] = curColor2[2]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* Do the main body */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		for (x = halfWidth; x < width - halfWidth; x++) { | 
					
						
							|  |  |  | 			index = (x + y * width) * 4; | 
					
						
							|  |  |  | 			fx = 0; | 
					
						
							| 
									
										
										
										
											2012-03-23 20:18:09 +00:00
										 |  |  | 			zero_v3(curColor); | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			for (i = x - halfWidth; i < x + halfWidth; i++) { | 
					
						
							|  |  |  | 				curColor[0] += map[(i + y * width) * 4 + GlowR] * filter[fx]; | 
					
						
							|  |  |  | 				curColor[1] += map[(i + y * width) * 4 + GlowG] * filter[fx]; | 
					
						
							|  |  |  | 				curColor[2] += map[(i + y * width) * 4 + GlowB] * filter[fx]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				fx++; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			temp[index + GlowR] = curColor[0]; | 
					
						
							|  |  |  | 			temp[index + GlowG] = curColor[1]; | 
					
						
							|  |  |  | 			temp[index + GlowB] = curColor[2]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	/* Swap buffers */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	swap = temp; temp = map; map = swap; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	/* Blur the columns */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	for (x = 0; x < width; x++) { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		/* Do the top & bottom strips */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		for (y = 0; y < halfWidth; y++) { | 
					
						
							|  |  |  | 			index = (x + y * width) * 4; | 
					
						
							|  |  |  | 			fy = 0; | 
					
						
							| 
									
										
										
										
											2012-03-23 20:18:09 +00:00
										 |  |  | 			zero_v3(curColor); | 
					
						
							|  |  |  | 			zero_v3(curColor2); | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			for (i = y - halfWidth; i < y + halfWidth; i++) { | 
					
						
							|  |  |  | 				if ((i >= 0) && (i < height)) { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 					/* Bottom */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 					curColor[0] += map[(x + i * width) * 4 + GlowR] * filter[fy]; | 
					
						
							|  |  |  | 					curColor[1] += map[(x + i * width) * 4 + GlowG] * filter[fy]; | 
					
						
							|  |  |  | 					curColor[2] += map[(x + i * width) * 4 + GlowB] * filter[fy]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 					/* Top */ | 
					
						
							|  |  |  | 					curColor2[0] += map[(x + (height - 1 - i) * width) * 4 + GlowR] * filter[fy]; | 
					
						
							|  |  |  | 					curColor2[1] += map[(x + (height - 1 - i) * width) * 4 + GlowG] * filter[fy]; | 
					
						
							|  |  |  | 					curColor2[2] += map[(x + (height - 1 - i) * width) * 4 + GlowB] * filter[fy]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				fy++; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			temp[index + GlowR] = curColor[0]; | 
					
						
							|  |  |  | 			temp[index + GlowG] = curColor[1]; | 
					
						
							|  |  |  | 			temp[index + GlowB] = curColor[2]; | 
					
						
							|  |  |  | 			temp[((x + (height - 1 - y) * width) * 4) + GlowR] = curColor2[0]; | 
					
						
							|  |  |  | 			temp[((x + (height - 1 - y) * width) * 4) + GlowG] = curColor2[1]; | 
					
						
							|  |  |  | 			temp[((x + (height - 1 - y) * width) * 4) + GlowB] = curColor2[2]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 		/* Do the main body */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		for (y = halfWidth; y < height - halfWidth; y++) { | 
					
						
							|  |  |  | 			index = (x + y * width) * 4; | 
					
						
							|  |  |  | 			fy = 0; | 
					
						
							| 
									
										
										
										
											2012-03-23 20:18:09 +00:00
										 |  |  | 			zero_v3(curColor); | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			for (i = y - halfWidth; i < y + halfWidth; i++) { | 
					
						
							|  |  |  | 				curColor[0] += map[(x + i * width) * 4 + GlowR] * filter[fy]; | 
					
						
							|  |  |  | 				curColor[1] += map[(x + i * width) * 4 + GlowG] * filter[fy]; | 
					
						
							|  |  |  | 				curColor[2] += map[(x + i * width) * 4 + GlowB] * filter[fy]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				fy++; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			temp[index + GlowR] = curColor[0]; | 
					
						
							|  |  |  | 			temp[index + GlowG] = curColor[1]; | 
					
						
							|  |  |  | 			temp[index + GlowB] = curColor[2]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	/* Swap buffers */ | 
					
						
							| 
									
										
										
										
											2012-05-27 19:40:36 +00:00
										 |  |  | 	swap = temp; temp = map; /* map = swap; */ /* UNUSED */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	/* Tidy up	 */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	MEM_freeN(filter); | 
					
						
							|  |  |  | 	MEM_freeN(temp); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void RVAddBitmaps_float(float *a, float *b, float *c, int width, int height) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	int x, y, index; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	for (y = 0; y < height; y++) { | 
					
						
							|  |  |  | 		for (x = 0; x < width; x++) { | 
					
						
							|  |  |  | 			index = (x + y * width) * 4; | 
					
						
							|  |  |  | 			c[index + GlowR] = MIN2(1.0f, a[index + GlowR] + b[index + GlowR]); | 
					
						
							|  |  |  | 			c[index + GlowG] = MIN2(1.0f, a[index + GlowG] + b[index + GlowG]); | 
					
						
							|  |  |  | 			c[index + GlowB] = MIN2(1.0f, a[index + GlowB] + b[index + GlowB]); | 
					
						
							|  |  |  | 			c[index + GlowA] = MIN2(1.0f, a[index + GlowA] + b[index + GlowA]); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void RVIsolateHighlights_float(float *in, float *out, int width, int height, float threshold, float boost, float clamp) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-29 15:47:02 +00:00
										 |  |  | 	int x, y, index; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	float intensity; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	for (y = 0; y < height; y++) { | 
					
						
							|  |  |  | 		for (x = 0; x < width; x++) { | 
					
						
							|  |  |  | 			index = (x + y * width) * 4; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 			/* Isolate the intensity */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			intensity = (in[index + GlowR] + in[index + GlowG] + in[index + GlowB] - threshold); | 
					
						
							|  |  |  | 			if (intensity > 0) { | 
					
						
							|  |  |  | 				out[index + GlowR] = MIN2(clamp, (in[index + GlowR] * boost * intensity)); | 
					
						
							|  |  |  | 				out[index + GlowG] = MIN2(clamp, (in[index + GlowG] * boost * intensity)); | 
					
						
							|  |  |  | 				out[index + GlowB] = MIN2(clamp, (in[index + GlowB] * boost * intensity)); | 
					
						
							|  |  |  | 				out[index + GlowA] = MIN2(clamp, (in[index + GlowA] * boost * intensity)); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 				out[index + GlowR] = 0; | 
					
						
							|  |  |  | 				out[index + GlowG] = 0; | 
					
						
							|  |  |  | 				out[index + GlowB] = 0; | 
					
						
							|  |  |  | 				out[index + GlowA] = 0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void init_glow_effect(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	GlowVars *glow; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	if (seq->effectdata) | 
					
						
							|  |  |  | 		MEM_freeN(seq->effectdata); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:38 +00:00
										 |  |  | 	seq->effectdata = MEM_callocN(sizeof(GlowVars), "glowvars"); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	glow = (GlowVars *)seq->effectdata; | 
					
						
							|  |  |  | 	glow->fMini = 0.25; | 
					
						
							|  |  |  | 	glow->fClamp = 1.0; | 
					
						
							|  |  |  | 	glow->fBoost = 0.5; | 
					
						
							|  |  |  | 	glow->dDist = 3.0; | 
					
						
							|  |  |  | 	glow->dQuality = 3; | 
					
						
							|  |  |  | 	glow->bNoComp = 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 12:30:59 +00:00
										 |  |  | static int num_inputs_glow(void) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void free_glow_effect(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	if (seq->effectdata) | 
					
						
							|  |  |  | 		MEM_freeN(seq->effectdata); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 	seq->effectdata = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void copy_glow_effect(Sequence *dst, Sequence *src) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	dst->effectdata = MEM_dupallocN(src->effectdata); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void do_glow_effect_byte(Sequence *seq, int render_size, float facf0, float UNUSED(facf1),  int x, int y, | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  |                                 unsigned char *rect1, unsigned char *UNUSED(rect2), unsigned char *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	float *outbuf, *inbuf; | 
					
						
							|  |  |  | 	GlowVars *glow = (GlowVars *)seq->effectdata; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	inbuf = MEM_mallocN(4 * sizeof(float) * x * y, "glow effect input"); | 
					
						
							|  |  |  | 	outbuf = MEM_mallocN(4 * sizeof(float) * x * y, "glow effect output"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-01 11:34:00 +11:00
										 |  |  | 	IMB_buffer_float_from_byte(inbuf, rect1, IB_PROFILE_SRGB, IB_PROFILE_SRGB, false, x, y, x, x); | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 	IMB_buffer_float_premultiply(inbuf, x, y); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	RVIsolateHighlights_float(inbuf, outbuf, x, y, glow->fMini * 3.0f, glow->fBoost * facf0, glow->fClamp); | 
					
						
							|  |  |  | 	RVBlurBitmap2_float(outbuf, x, y, glow->dDist * (render_size / 100.0f), glow->dQuality); | 
					
						
							|  |  |  | 	if (!glow->bNoComp) | 
					
						
							|  |  |  | 		RVAddBitmaps_float(inbuf, outbuf, outbuf, x, y); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	IMB_buffer_float_unpremultiply(outbuf, x, y); | 
					
						
							| 
									
										
										
										
											2014-04-01 11:34:00 +11:00
										 |  |  | 	IMB_buffer_byte_from_float(out, outbuf, 4, 0.0f, IB_PROFILE_SRGB, IB_PROFILE_SRGB, false, x, y, x, x); | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	MEM_freeN(inbuf); | 
					
						
							|  |  |  | 	MEM_freeN(outbuf); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void do_glow_effect_float(Sequence *seq, int render_size, float facf0, float UNUSED(facf1),  int x, int y, | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  |                                  float *rect1, float *UNUSED(rect2), float *out) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float *outbuf = out; | 
					
						
							|  |  |  | 	float *inbuf = rect1; | 
					
						
							|  |  |  | 	GlowVars *glow = (GlowVars *)seq->effectdata; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	RVIsolateHighlights_float(inbuf, outbuf, x, y, glow->fMini * 3.0f, glow->fBoost * facf0, glow->fClamp); | 
					
						
							|  |  |  | 	RVBlurBitmap2_float(outbuf, x, y, glow->dDist * (render_size / 100.0f), glow->dQuality); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	if (!glow->bNoComp) | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		RVAddBitmaps_float(inbuf, outbuf, outbuf, x, y); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static ImBuf *do_glow_effect(const SeqRenderData *context, Sequence *seq, float UNUSED(cfra), float facf0, float facf1, | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  |                              ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *ibuf3) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:38 +00:00
										 |  |  | 	ImBuf *out = prepare_effect_imbufs(context, ibuf1, ibuf2, ibuf3); | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 	int render_size = 100 * context->rectx / context->scene->r.xsch; | 
					
						
							| 
									
										
										
										
											2010-11-01 18:55:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	if (out->rect_float) { | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_glow_effect_float(seq, render_size, facf0, facf1, context->rectx, context->recty, | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		                     ibuf1->rect_float, ibuf2->rect_float, out->rect_float); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_glow_effect_byte(seq, render_size, facf0, facf1, context->rectx, context->recty, | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 		                    (unsigned char *) ibuf1->rect, (unsigned char *) ibuf2->rect, (unsigned char *) out->rect); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** Solid color *************************/ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static void init_solid_color(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	SolidColorVars *cv; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	if (seq->effectdata) | 
					
						
							|  |  |  | 		MEM_freeN(seq->effectdata); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:38 +00:00
										 |  |  | 	seq->effectdata = MEM_callocN(sizeof(SolidColorVars), "solidcolor"); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	cv = (SolidColorVars *)seq->effectdata; | 
					
						
							|  |  |  | 	cv->col[0] = cv->col[1] = cv->col[2] = 0.5; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 12:30:59 +00:00
										 |  |  | static int num_inputs_color(void) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void free_solid_color(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	if (seq->effectdata) | 
					
						
							|  |  |  | 		MEM_freeN(seq->effectdata); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 	seq->effectdata = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void copy_solid_color(Sequence *dst, Sequence *src) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	dst->effectdata = MEM_dupallocN(src->effectdata); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static int early_out_color(Sequence *UNUSED(seq), float UNUSED(facf0), float UNUSED(facf1)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:44 +00:00
										 |  |  | 	return EARLY_NO_INPUT; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static ImBuf *do_solid_color(const SeqRenderData *context, Sequence *seq, float UNUSED(cfra), float facf0, float facf1, | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  |                              ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *ibuf3) | 
					
						
							| 
									
										
										
										
											2012-05-17 23:21:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	ImBuf *out = prepare_effect_imbufs(context, ibuf1, ibuf2, ibuf3); | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	SolidColorVars *cv = (SolidColorVars *)seq->effectdata; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	unsigned char *rect; | 
					
						
							|  |  |  | 	float *rect_float; | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 	int x; /*= context->rectx;*/ /*UNUSED*/ | 
					
						
							|  |  |  | 	int y; /*= context->recty;*/ /*UNUSED*/ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (out->rect) { | 
					
						
							|  |  |  | 		unsigned char col0[3]; | 
					
						
							|  |  |  | 		unsigned char col1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		col0[0] = facf0 * cv->col[0] * 255; | 
					
						
							|  |  |  | 		col0[1] = facf0 * cv->col[1] * 255; | 
					
						
							|  |  |  | 		col0[2] = facf0 * cv->col[2] * 255; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		col1[0] = facf1 * cv->col[0] * 255; | 
					
						
							|  |  |  | 		col1[1] = facf1 * cv->col[1] * 255; | 
					
						
							|  |  |  | 		col1[2] = facf1 * cv->col[2] * 255; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		rect = (unsigned char *)out->rect; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		for (y = 0; y < out->y; y++) { | 
					
						
							|  |  |  | 			for (x = 0; x < out->x; x++, rect += 4) { | 
					
						
							|  |  |  | 				rect[0] = col0[0]; | 
					
						
							|  |  |  | 				rect[1] = col0[1]; | 
					
						
							|  |  |  | 				rect[2] = col0[2]; | 
					
						
							|  |  |  | 				rect[3] = 255; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			y++; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			if (y < out->y) { | 
					
						
							|  |  |  | 				for (x = 0; x < out->x; x++, rect += 4) { | 
					
						
							|  |  |  | 					rect[0] = col1[0]; | 
					
						
							|  |  |  | 					rect[1] = col1[1]; | 
					
						
							|  |  |  | 					rect[2] = col1[2]; | 
					
						
							|  |  |  | 					rect[3] = 255; | 
					
						
							| 
									
										
										
										
											2012-10-21 05:46:41 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if (out->rect_float) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		float col0[3]; | 
					
						
							|  |  |  | 		float col1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		col0[0] = facf0 * cv->col[0]; | 
					
						
							|  |  |  | 		col0[1] = facf0 * cv->col[1]; | 
					
						
							|  |  |  | 		col0[2] = facf0 * cv->col[2]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		col1[0] = facf1 * cv->col[0]; | 
					
						
							|  |  |  | 		col1[1] = facf1 * cv->col[1]; | 
					
						
							|  |  |  | 		col1[2] = facf1 * cv->col[2]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		rect_float = out->rect_float; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		for (y = 0; y < out->y; y++) { | 
					
						
							|  |  |  | 			for (x = 0; x < out->x; x++, rect_float += 4) { | 
					
						
							|  |  |  | 				rect_float[0] = col0[0]; | 
					
						
							|  |  |  | 				rect_float[1] = col0[1]; | 
					
						
							|  |  |  | 				rect_float[2] = col0[2]; | 
					
						
							|  |  |  | 				rect_float[3] = 1.0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			y++; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			if (y < out->y) { | 
					
						
							|  |  |  | 				for (x = 0; x < out->x; x++, rect_float += 4) { | 
					
						
							|  |  |  | 					rect_float[0] = col1[0]; | 
					
						
							|  |  |  | 					rect_float[1] = col1[1]; | 
					
						
							|  |  |  | 					rect_float[2] = col1[2]; | 
					
						
							|  |  |  | 					rect_float[3] = 1.0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 	return out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** Mulitcam *************************/ | 
					
						
							| 
									
										
											  
											
												== 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
										 |  |  | 
 | 
					
						
							|  |  |  | /* no effect inputs for multicam, we use give_ibuf_seq */ | 
					
						
							| 
									
										
										
										
											2010-12-03 12:30:59 +00:00
										 |  |  | static int num_inputs_multicam(void) | 
					
						
							| 
									
										
											  
											
												== 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
										 |  |  | { | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:38 +00:00
										 |  |  | static int early_out_multicam(Sequence *UNUSED(seq), float UNUSED(facf0), float UNUSED(facf1)) | 
					
						
							| 
									
										
											  
											
												== 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
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:44 +00:00
										 |  |  | 	return EARLY_NO_INPUT; | 
					
						
							| 
									
										
											  
											
												== 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
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static ImBuf *do_multicam(const SeqRenderData *context, Sequence *seq, float cfra, float UNUSED(facf0), float UNUSED(facf1), | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  |                           ImBuf *UNUSED(ibuf1), ImBuf *UNUSED(ibuf2), ImBuf *UNUSED(ibuf3)) | 
					
						
							| 
									
										
										
										
											2012-05-17 23:21:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	ImBuf *i; | 
					
						
							|  |  |  | 	ImBuf *out; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	Editing *ed; | 
					
						
							|  |  |  | 	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
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (seq->multicam_source == 0 || seq->multicam_source >= seq->machine) { | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 		return NULL; | 
					
						
							| 
									
										
											  
											
												== 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
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 	ed = context->scene->ed; | 
					
						
							| 
									
										
											  
											
												== 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
										 |  |  | 	if (!ed) { | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 		return NULL; | 
					
						
							| 
									
										
											  
											
												== 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
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:40 +00:00
										 |  |  | 	seqbasep = BKE_sequence_seqbase(&ed->seqbase, seq); | 
					
						
							| 
									
										
											  
											
												== 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
										 |  |  | 	if (!seqbasep) { | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 		return NULL; | 
					
						
							| 
									
										
											  
											
												== 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
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:40 +00:00
										 |  |  | 	i = BKE_sequencer_give_ibuf_seqbase(context, cfra, seq->multicam_source, 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
										 |  |  | 	if (!i) { | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 		return NULL; | 
					
						
							| 
									
										
											  
											
												== 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
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:40 +00:00
										 |  |  | 	if (BKE_sequencer_input_have_to_preprocess(context, seq, cfra)) { | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 		out = IMB_dupImBuf(i); | 
					
						
							|  |  |  | 		IMB_freeImBuf(i); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 		out = i; | 
					
						
							| 
									
										
											  
											
												== 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-07-25 17:19:55 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	return out; | 
					
						
							| 
									
										
											  
											
												== 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
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** Adjustment *************************/ | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* no effect inputs for adjustment, we use give_ibuf_seq */ | 
					
						
							|  |  |  | static int num_inputs_adjustment(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static int early_out_adjustment(Sequence *UNUSED(seq), float UNUSED(facf0), float UNUSED(facf1)) | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:44 +00:00
										 |  |  | 	return EARLY_NO_INPUT; | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static ImBuf *do_adjustment_impl(const SeqRenderData *context, Sequence *seq, float cfra) | 
					
						
							| 
									
										
										
										
											2012-05-17 23:21:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	Editing *ed; | 
					
						
							|  |  |  | 	ListBase *seqbasep; | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	ImBuf *i = NULL; | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 	ed = context->scene->ed; | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:40 +00:00
										 |  |  | 	seqbasep = BKE_sequence_seqbase(&ed->seqbase, seq); | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-10 15:30:38 +00:00
										 |  |  | 	if (seq->machine > 1) { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:40 +00:00
										 |  |  | 		i = BKE_sequencer_give_ibuf_seqbase(context, cfra, seq->machine - 1, seqbasep); | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* found nothing? so let's work the way up the metastrip stack, so
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	 * that it is possible to group a bunch of adjustment strips into | 
					
						
							|  |  |  | 	 * a metastrip and have that work on everything below the metastrip | 
					
						
							| 
									
										
										
										
											2012-03-09 18:28:30 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 	if (!i) { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 		Sequence *meta; | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:40 +00:00
										 |  |  | 		meta = BKE_sequence_metastrip(&ed->seqbase, NULL, seq); | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if (meta) { | 
					
						
							|  |  |  | 			i = do_adjustment_impl(context, meta, cfra); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return i; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static ImBuf *do_adjustment(const SeqRenderData *context, Sequence *seq, float cfra, float UNUSED(facf0), float UNUSED(facf1), | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  |                             ImBuf *UNUSED(ibuf1), ImBuf *UNUSED(ibuf2), ImBuf *UNUSED(ibuf3)) | 
					
						
							| 
									
										
										
										
											2012-05-17 23:21:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	ImBuf *i = NULL; | 
					
						
							|  |  |  | 	ImBuf *out; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	Editing *ed; | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 	ed = context->scene->ed; | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (!ed) { | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	i = do_adjustment_impl(context, seq, cfra); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:40 +00:00
										 |  |  | 	if (BKE_sequencer_input_have_to_preprocess(context, seq, cfra)) { | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 		out = IMB_dupImBuf(i); | 
					
						
							|  |  |  | 		IMB_freeImBuf(i); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2011-05-16 17:14:47 +00:00
										 |  |  | 		out = i; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return out; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** Speed *************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | static void init_speed_effect(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	SpeedControlVars *v; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	if (seq->effectdata) | 
					
						
							|  |  |  | 		MEM_freeN(seq->effectdata); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:38 +00:00
										 |  |  | 	seq->effectdata = MEM_callocN(sizeof(SpeedControlVars), "speedcontrolvars"); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	v = (SpeedControlVars *)seq->effectdata; | 
					
						
							|  |  |  | 	v->globalSpeed = 1.0; | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 	v->frameMap = NULL; | 
					
						
							| 
									
										
										
										
											2010-09-29 13:38:43 +00:00
										 |  |  | 	v->flags |= SEQ_SPEED_INTEGRATE; /* should be default behavior */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	v->length = 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | static void load_speed_effect(Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	SpeedControlVars *v = (SpeedControlVars *)seq->effectdata; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 	v->frameMap = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	v->length = 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 12:30:59 +00:00
										 |  |  | static int num_inputs_speed(void) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void free_speed_effect(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	SpeedControlVars *v = (SpeedControlVars *)seq->effectdata; | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	if (v->frameMap) | 
					
						
							|  |  |  | 		MEM_freeN(v->frameMap); | 
					
						
							|  |  |  | 	if (seq->effectdata) | 
					
						
							|  |  |  | 		MEM_freeN(seq->effectdata); | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 	seq->effectdata = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void copy_speed_effect(Sequence *dst, Sequence *src) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	SpeedControlVars *v; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	dst->effectdata = MEM_dupallocN(src->effectdata); | 
					
						
							|  |  |  | 	v = (SpeedControlVars *)dst->effectdata; | 
					
						
							| 
									
										
										
										
											2011-02-13 10:52:18 +00:00
										 |  |  | 	v->frameMap = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	v->length = 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static int early_out_speed(Sequence *UNUSED(seq), float UNUSED(facf0), float UNUSED(facf1)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:44 +00:00
										 |  |  | 	return EARLY_USE_INPUT_1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void store_icu_yrange_speed(Sequence *seq, short UNUSED(adrcode), float *ymin, float *ymax) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	SpeedControlVars *v = (SpeedControlVars *)seq->effectdata; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* if not already done, load / initialize data */ | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:40 +00:00
										 |  |  | 	BKE_sequence_get_effect(seq); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if ((v->flags & SEQ_SPEED_INTEGRATE) != 0) { | 
					
						
							|  |  |  | 		*ymin = -100.0; | 
					
						
							|  |  |  | 		*ymax = 100.0; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		if (v->flags & SEQ_SPEED_COMPRESS_IPO_Y) { | 
					
						
							|  |  |  | 			*ymin = 0.0; | 
					
						
							|  |  |  | 			*ymax = 1.0; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			*ymin = 0.0; | 
					
						
							|  |  |  | 			*ymax = seq->len; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-10-21 05:46:41 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | void BKE_sequence_effect_speed_rebuild_map(Scene *scene, Sequence *seq, bool force) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int cfra; | 
					
						
							| 
									
										
										
										
											2010-09-29 13:38:43 +00:00
										 |  |  | 	float fallback_fac = 1.0f; | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	SpeedControlVars *v = (SpeedControlVars *) seq->effectdata; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	FCurve *fcu = NULL; | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	int flags = v->flags; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* if not already done, load / initialize data */ | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:40 +00:00
										 |  |  | 	BKE_sequence_get_effect(seq); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 	if ((force == false) && | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	    (seq->len == v->length) && | 
					
						
							|  |  |  | 	    (v->frameMap != NULL)) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	if ((seq->seq1 == NULL) || (seq->len < 1)) { | 
					
						
							|  |  |  | 		/* make coverity happy and check for (CID 598) input strip ... */ | 
					
						
							| 
									
										
										
										
											2009-08-19 09:35:22 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-14 14:58:19 +00:00
										 |  |  | 	/* XXX - new in 2.5x. should we use the animation system this way?
 | 
					
						
							|  |  |  | 	 * The fcurve is needed because many frames need evaluating at once - campbell */ | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 	fcu = id_data_find_fcurve(&scene->id, seq, &RNA_Sequence, "speed_factor", 0, NULL); | 
					
						
							| 
									
										
										
										
											2009-11-14 14:58:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	if (!v->frameMap || v->length != seq->len) { | 
					
						
							|  |  |  | 		if (v->frameMap) MEM_freeN(v->frameMap); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		v->length = seq->len; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 		v->frameMap = MEM_callocN(sizeof(float) * v->length, "speedcontrol frameMap"); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 	fallback_fac = 1.0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (seq->flag & SEQ_USE_EFFECT_DEFAULT_FADE) { | 
					
						
							| 
									
										
										
										
											2012-04-21 15:11:03 +00:00
										 |  |  | 		if ((seq->seq1->enddisp != seq->seq1->start) && | 
					
						
							|  |  |  | 		    (seq->seq1->len != 0)) | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2015-09-09 00:36:10 +10:00
										 |  |  | 			fallback_fac = (float) seq->seq1->len / (float) (seq->seq1->enddisp - seq->seq1->start); | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 			flags = SEQ_SPEED_INTEGRATE; | 
					
						
							|  |  |  | 			fcu = NULL; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 		/* if there is no fcurve, use value as simple multiplier */ | 
					
						
							|  |  |  | 		if (!fcu) { | 
					
						
							|  |  |  | 			fallback_fac = seq->speed_fader; /* same as speed_factor in rna*/ | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (flags & SEQ_SPEED_INTEGRATE) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		float cursor = 0; | 
					
						
							| 
									
										
										
										
											2009-11-22 20:22:35 +00:00
										 |  |  | 		float facf; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		v->frameMap[0] = 0; | 
					
						
							|  |  |  | 		v->lastValidFrame = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for (cfra = 1; cfra < v->length; cfra++) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (fcu) { | 
					
						
							| 
									
										
										
										
											2010-09-29 13:38:43 +00:00
										 |  |  | 				facf = evaluate_fcurve(fcu, seq->startdisp + cfra); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2009-11-22 20:22:35 +00:00
										 |  |  | 				facf = fallback_fac; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-11-22 20:22:35 +00:00
										 |  |  | 			facf *= v->globalSpeed; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-22 20:22:35 +00:00
										 |  |  | 			cursor += facf; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-08 13:55:30 +00:00
										 |  |  | 			if (cursor >= seq->seq1->len) { | 
					
						
							|  |  |  | 				v->frameMap[cfra] = seq->seq1->len - 1; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				v->frameMap[cfra] = cursor; | 
					
						
							|  |  |  | 				v->lastValidFrame = cfra; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2009-11-22 20:22:35 +00:00
										 |  |  | 		float facf; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		v->lastValidFrame = 0; | 
					
						
							|  |  |  | 		for (cfra = 0; cfra < v->length; cfra++) { | 
					
						
							| 
									
										
										
										
											2009-11-14 14:58:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			if (fcu) { | 
					
						
							| 
									
										
										
										
											2010-09-29 13:38:43 +00:00
										 |  |  | 				facf = evaluate_fcurve(fcu, seq->startdisp + cfra); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2010-09-29 13:38:43 +00:00
										 |  |  | 				facf = fallback_fac; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2010-09-29 13:38:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | 			if (flags & SEQ_SPEED_COMPRESS_IPO_Y) { | 
					
						
							| 
									
										
										
										
											2010-09-30 09:34:22 +00:00
										 |  |  | 				facf *= seq->seq1->len; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-11-22 20:22:35 +00:00
										 |  |  | 			facf *= v->globalSpeed; | 
					
						
							| 
									
										
										
										
											2010-09-29 13:38:43 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2010-08-08 13:55:30 +00:00
										 |  |  | 			if (facf >= seq->seq1->len) { | 
					
						
							|  |  |  | 				facf = seq->seq1->len - 1; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 				v->lastValidFrame = cfra; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-11-22 20:22:35 +00:00
										 |  |  | 			v->frameMap[cfra] = facf; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static ImBuf *do_speed_effect(const SeqRenderData *context, Sequence *UNUSED(seq), float UNUSED(cfra), | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  |                               float facf0, float facf1, ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *ibuf3) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ImBuf *out = prepare_effect_imbufs(context, ibuf1, ibuf2, ibuf3); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (out->rect_float) { | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_cross_effect_float(facf0, facf1, context->rectx, context->recty, | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 		                      ibuf1->rect_float, ibuf2->rect_float, out->rect_float); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		do_cross_effect_byte(facf0, facf1, context->rectx, context->recty, | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 		                     (unsigned char *) ibuf1->rect, (unsigned char *) ibuf2->rect, (unsigned char *) out->rect); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	return out; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*********************** overdrop *************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static void do_overdrop_effect(const SeqRenderData *context, Sequence *UNUSED(seq), float UNUSED(cfra), float facf0, float facf1, | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  |                                ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *UNUSED(ibuf3), int start_line, int total_lines, ImBuf *out) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 	int x = context->rectx; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 	int y = total_lines; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (out->rect_float) { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		float *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_float_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		do_drop_effect_float(facf0, facf1, x, y, rect1, rect2, rect_out); | 
					
						
							|  |  |  | 		do_alphaover_effect_float(facf0, facf1, x, y, rect1, rect2, rect_out); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-08-18 04:50:20 +00:00
										 |  |  | 		unsigned char *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		slice_get_byte_buffers(context, ibuf1, ibuf2, NULL, out, start_line, &rect1, &rect2, NULL, &rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-31 13:52:13 +00:00
										 |  |  | 		do_drop_effect_byte(facf0, facf1, x, y, rect1, rect2, rect_out); | 
					
						
							|  |  |  | 		do_alphaover_effect_byte(facf0, facf1, x, y, rect1, rect2, rect_out); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-19 22:16:10 +06:00
										 |  |  | /*********************** Gaussian Blur *************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* NOTE: This gaussian blur implementation accumulates values in the square
 | 
					
						
							|  |  |  |  * kernel rather that doing X direction and then Y direction because of the | 
					
						
							|  |  |  |  * lack of using multiple-staged filters. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Once we can we'll implement a way to apply filter as multiple stages we | 
					
						
							|  |  |  |  * can optimize hell of a lot in here. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void init_gaussian_blur_effect(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (seq->effectdata) | 
					
						
							|  |  |  | 		MEM_freeN(seq->effectdata); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	seq->effectdata = MEM_callocN(sizeof(WipeVars), "wipevars"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int num_inputs_gaussian_blur(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void free_gaussian_blur_effect(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (seq->effectdata) | 
					
						
							|  |  |  | 		MEM_freeN(seq->effectdata); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	seq->effectdata = NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void copy_gaussian_blur_effect(Sequence *dst, Sequence *src) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	dst->effectdata = MEM_dupallocN(src->effectdata); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-20 14:32:09 +06:00
										 |  |  | static int early_out_gaussian_blur(Sequence *seq, float UNUSED(facf0), float UNUSED(facf1)) | 
					
						
							| 
									
										
										
										
											2014-07-19 22:16:10 +06:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-07-20 14:32:09 +06:00
										 |  |  | 	GaussianBlurVars *data = seq->effectdata; | 
					
						
							|  |  |  | 	if (data->size_x == 0.0f && data->size_y == 0) { | 
					
						
							|  |  |  | 		return EARLY_USE_INPUT_1; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-07-19 22:16:10 +06:00
										 |  |  | 	return EARLY_DO_EFFECT; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* TODO(sergey): De-duplicate with compositor. */ | 
					
						
							|  |  |  | static float *make_gaussian_blur_kernel(float rad, int size) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	float *gausstab, sum, val; | 
					
						
							|  |  |  | 	float fac; | 
					
						
							|  |  |  | 	int i, n; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	n = 2 * size + 1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	gausstab = (float *)MEM_mallocN(sizeof(float) * n, __func__); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	sum = 0.0f; | 
					
						
							|  |  |  | 	fac = (rad > 0.0f ? 1.0f / rad : 0.0f); | 
					
						
							|  |  |  | 	for (i = -size; i <= size; i++) { | 
					
						
							|  |  |  | 		val = RE_filter_value(R_FILTER_GAUSS, (float)i * fac); | 
					
						
							|  |  |  | 		sum += val; | 
					
						
							|  |  |  | 		gausstab[i + size] = val; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	sum = 1.0f / sum; | 
					
						
							|  |  |  | 	for (i = 0; i < n; i++) | 
					
						
							|  |  |  | 		gausstab[i] *= sum; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return gausstab; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void do_gaussian_blur_effect_byte(Sequence *seq, | 
					
						
							|  |  |  |                                          int start_line, | 
					
						
							|  |  |  |                                          int x, int y, | 
					
						
							|  |  |  |                                          int frame_width, int frame_height, | 
					
						
							|  |  |  |                                          unsigned char *rect, | 
					
						
							|  |  |  |                                          unsigned char *out) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #define INDEX(_x, _y) (((_y) * (x) + (_x)) * 4)
 | 
					
						
							|  |  |  | 	GaussianBlurVars *data = seq->effectdata; | 
					
						
							| 
									
										
										
										
											2015-02-11 18:38:41 +11:00
										 |  |  | 	const int size_x = (int) (data->size_x + 0.5f); | 
					
						
							|  |  |  | 	const int size_y = (int) (data->size_y + 0.5f); | 
					
						
							| 
									
										
										
										
											2014-07-19 22:16:10 +06:00
										 |  |  | 	int i, j; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Make gaussian weight tabke. */ | 
					
						
							|  |  |  | 	float *gausstab_x, *gausstab_y; | 
					
						
							|  |  |  | 	gausstab_x = make_gaussian_blur_kernel(data->size_x, size_x); | 
					
						
							|  |  |  | 	if (data->size_x == data->size_y) { | 
					
						
							|  |  |  | 		gausstab_y = gausstab_x; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		gausstab_y = make_gaussian_blur_kernel(data->size_y, size_y); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (i = 0; i < y; ++i) { | 
					
						
							|  |  |  | 		for (j = 0; j < x; ++j) { | 
					
						
							|  |  |  | 			int out_index = INDEX(j, i); | 
					
						
							|  |  |  | 			int current_x, current_y; | 
					
						
							|  |  |  | 			float accum[4] = {0.0f, 0.0f, 0.0f, 0.0f}; | 
					
						
							|  |  |  | 			float accum_weight = 0.0f; | 
					
						
							|  |  |  | 			for (current_y = i - size_y; | 
					
						
							| 
									
										
										
										
											2014-07-20 15:37:07 +06:00
										 |  |  | 			     current_y <= i + size_y; | 
					
						
							| 
									
										
										
										
											2014-07-19 22:16:10 +06:00
										 |  |  | 			     ++current_y) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				if (current_y < -start_line || | 
					
						
							|  |  |  | 				    current_y + start_line >= frame_height) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					/* Out of bounds. */ | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				for (current_x = j - size_x; | 
					
						
							| 
									
										
										
										
											2014-07-20 15:37:07 +06:00
										 |  |  | 				     current_x <= j + size_x; | 
					
						
							| 
									
										
										
										
											2014-07-19 22:16:10 +06:00
										 |  |  | 				     ++current_x) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					float weight; | 
					
						
							|  |  |  | 					int index = INDEX(current_x, current_y + start_line); | 
					
						
							|  |  |  | 					if (current_x < 0 || current_x >= frame_width) { | 
					
						
							|  |  |  | 						/* Out of bounds. */ | 
					
						
							|  |  |  | 						continue; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					BLI_assert(index >= 0); | 
					
						
							|  |  |  | 					BLI_assert(index < frame_width * frame_height * 4); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-20 15:37:07 +06:00
										 |  |  | 					if (size_x != 0 && size_y != 0) { | 
					
						
							|  |  |  | 						weight = gausstab_x[current_x - j + size_x] * | 
					
						
							|  |  |  | 							gausstab_y[current_y - i + size_y]; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					else if (size_x == 0) { | 
					
						
							|  |  |  | 						weight = gausstab_y[current_y - i + size_y]; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					else { | 
					
						
							|  |  |  | 						weight = gausstab_x[current_x - j + size_x]; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2014-07-19 22:16:10 +06:00
										 |  |  | 					accum[0] += rect[index] * weight; | 
					
						
							|  |  |  | 					accum[1] += rect[index + 1] * weight; | 
					
						
							|  |  |  | 					accum[2] += rect[index + 2] * weight; | 
					
						
							|  |  |  | 					accum[3] += rect[index + 3] * weight; | 
					
						
							|  |  |  | 					accum_weight += weight; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			out[out_index + 0] = accum[0] / accum_weight; | 
					
						
							|  |  |  | 			out[out_index + 1] = accum[1] / accum_weight; | 
					
						
							|  |  |  | 			out[out_index + 2] = accum[2] / accum_weight; | 
					
						
							|  |  |  | 			out[out_index + 3] = accum[3] / accum_weight; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	MEM_freeN(gausstab_x); | 
					
						
							|  |  |  | 	if (gausstab_x != gausstab_y) { | 
					
						
							|  |  |  | 		MEM_freeN(gausstab_y); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | #undef INDEX
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void do_gaussian_blur_effect_float(Sequence *seq, | 
					
						
							|  |  |  |                                           int start_line, | 
					
						
							|  |  |  |                                           int x, int y, | 
					
						
							|  |  |  |                                           int frame_width, int frame_height, | 
					
						
							|  |  |  |                                           float *rect, | 
					
						
							|  |  |  |                                           float *out) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #define INDEX(_x, _y) (((_y) * (x) + (_x)) * 4)
 | 
					
						
							|  |  |  | 	GaussianBlurVars *data = seq->effectdata; | 
					
						
							| 
									
										
										
										
											2015-02-11 18:38:41 +11:00
										 |  |  | 	const int size_x = (int) (data->size_x + 0.5f); | 
					
						
							|  |  |  | 	const int size_y = (int) (data->size_y + 0.5f); | 
					
						
							| 
									
										
										
										
											2014-07-19 22:16:10 +06:00
										 |  |  | 	int i, j; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Make gaussian weight tabke. */ | 
					
						
							|  |  |  | 	float *gausstab_x, *gausstab_y; | 
					
						
							|  |  |  | 	gausstab_x = make_gaussian_blur_kernel(data->size_x, size_x); | 
					
						
							|  |  |  | 	if (data->size_x == data->size_y) { | 
					
						
							|  |  |  | 		gausstab_y = gausstab_x; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		gausstab_y = make_gaussian_blur_kernel(data->size_y, size_y); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (i = 0; i < y; ++i) { | 
					
						
							|  |  |  | 		for (j = 0; j < x; ++j) { | 
					
						
							|  |  |  | 			int out_index = INDEX(j, i); | 
					
						
							|  |  |  | 			int current_x, current_y; | 
					
						
							|  |  |  | 			float accum[4] = {0.0f, 0.0f, 0.0f, 0.0f}; | 
					
						
							|  |  |  | 			float accum_weight = 0.0f; | 
					
						
							|  |  |  | 			for (current_y = i - size_y; | 
					
						
							| 
									
										
										
										
											2014-07-20 15:37:07 +06:00
										 |  |  | 			     current_y <= i + size_y; | 
					
						
							| 
									
										
										
										
											2014-07-19 22:16:10 +06:00
										 |  |  | 			     ++current_y) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				float weight; | 
					
						
							|  |  |  | 				if (current_y < -start_line || | 
					
						
							|  |  |  | 				    current_y + start_line >= frame_height) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					/* Out of bounds. */ | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				for (current_x = j - size_x; | 
					
						
							| 
									
										
										
										
											2014-07-20 15:37:07 +06:00
										 |  |  | 				     current_x <= j + size_x; | 
					
						
							| 
									
										
										
										
											2014-07-19 22:16:10 +06:00
										 |  |  | 				     ++current_x) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					int index = INDEX(current_x, current_y + start_line); | 
					
						
							|  |  |  | 					if (current_x < 0 || current_x >= frame_width) { | 
					
						
							|  |  |  | 						/* Out of bounds. */ | 
					
						
							|  |  |  | 						continue; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-20 15:37:07 +06:00
										 |  |  | 					if (size_x != 0 && size_y != 0) { | 
					
						
							|  |  |  | 						weight = gausstab_x[current_x - j + size_x] * | 
					
						
							|  |  |  | 							gausstab_y[current_y - i + size_y]; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					else if (size_x == 0) { | 
					
						
							|  |  |  | 						weight = gausstab_y[current_y - i + size_y]; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					else { | 
					
						
							|  |  |  | 						weight = gausstab_x[current_x - j + size_x]; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2014-07-19 22:16:10 +06:00
										 |  |  | 					madd_v4_v4fl(accum, &rect[index], weight); | 
					
						
							|  |  |  | 					accum_weight += weight; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			mul_v4_v4fl(&out[out_index], accum, 1.0f / accum_weight); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	MEM_freeN(gausstab_x); | 
					
						
							|  |  |  | 	if (gausstab_x != gausstab_y) { | 
					
						
							|  |  |  | 		MEM_freeN(gausstab_y); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | #undef INDEX
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void do_gaussian_blur_effect(const SeqRenderData *context, | 
					
						
							|  |  |  |                                     Sequence *seq, | 
					
						
							|  |  |  |                                     float UNUSED(cfra), | 
					
						
							|  |  |  |                                     float UNUSED(facf0), | 
					
						
							|  |  |  |                                     float UNUSED(facf1), | 
					
						
							|  |  |  |                                     ImBuf *ibuf1, | 
					
						
							|  |  |  |                                     ImBuf *ibuf2, | 
					
						
							|  |  |  |                                     ImBuf *UNUSED(ibuf3), | 
					
						
							|  |  |  |                                     int start_line, | 
					
						
							|  |  |  |                                     int total_lines, | 
					
						
							|  |  |  |                                     ImBuf *out) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (out->rect_float) { | 
					
						
							|  |  |  | 		float *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		slice_get_float_buffers(context, | 
					
						
							|  |  |  | 		                        ibuf1, ibuf2, | 
					
						
							|  |  |  | 		                        NULL, | 
					
						
							|  |  |  | 		                        out, | 
					
						
							|  |  |  | 		                        start_line, | 
					
						
							|  |  |  | 		                        &rect1, | 
					
						
							|  |  |  | 		                        &rect2, | 
					
						
							|  |  |  | 		                        NULL, | 
					
						
							|  |  |  | 		                        &rect_out); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		do_gaussian_blur_effect_float(seq, | 
					
						
							|  |  |  | 		                              start_line, | 
					
						
							|  |  |  | 		                              context->rectx, | 
					
						
							|  |  |  | 		                              total_lines, | 
					
						
							|  |  |  | 		                              context->rectx, | 
					
						
							|  |  |  | 		                              context->recty, | 
					
						
							|  |  |  | 		                              ibuf1->rect_float, | 
					
						
							|  |  |  | 		                              rect_out); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		unsigned char *rect1 = NULL, *rect2 = NULL, *rect_out = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		slice_get_byte_buffers(context, | 
					
						
							|  |  |  | 		                       ibuf1, ibuf2, | 
					
						
							|  |  |  | 		                       NULL, | 
					
						
							|  |  |  | 		                       out, | 
					
						
							|  |  |  | 		                       start_line, | 
					
						
							|  |  |  | 		                       &rect1, | 
					
						
							|  |  |  | 		                       &rect2, | 
					
						
							|  |  |  | 		                       NULL, | 
					
						
							|  |  |  | 		                       &rect_out); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		do_gaussian_blur_effect_byte(seq, | 
					
						
							|  |  |  | 		                             start_line, | 
					
						
							|  |  |  | 		                             context->rectx, | 
					
						
							|  |  |  | 		                             total_lines, | 
					
						
							|  |  |  | 		                             context->rectx, | 
					
						
							|  |  |  | 		                             context->recty, | 
					
						
							|  |  |  | 		                             (unsigned char *) ibuf1->rect, | 
					
						
							|  |  |  | 		                             rect_out); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-01 20:29:18 +02:00
										 |  |  | /*********************** text *************************/ | 
					
						
							|  |  |  | static void init_text_effect(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	TextVars *data; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (seq->effectdata) | 
					
						
							|  |  |  | 		MEM_freeN(seq->effectdata); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	data = seq->effectdata = MEM_callocN(sizeof(TextVars), "textvars"); | 
					
						
							| 
									
										
										
										
											2015-07-11 02:17:06 +10:00
										 |  |  | 	data->text_size = 30; | 
					
						
							| 
									
										
										
										
											2015-07-01 20:29:18 +02:00
										 |  |  | 	BLI_strncpy(data->text, "Text", sizeof(data->text)); | 
					
						
							| 
									
										
										
										
											2015-07-11 02:17:06 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	data->loc[0] = 0.5f; | 
					
						
							|  |  |  | 	data->align = SEQ_TEXT_ALIGN_CENTER; | 
					
						
							| 
									
										
										
										
											2015-07-01 20:29:18 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int num_inputs_text(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int early_out_text(Sequence *seq, float UNUSED(facf0), float UNUSED(facf1)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	TextVars *data = seq->effectdata; | 
					
						
							|  |  |  | 	if (data->text[0] == 0 || data->text_size < 1) { | 
					
						
							|  |  |  | 		return EARLY_USE_INPUT_1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return EARLY_NO_INPUT; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static ImBuf *do_text_effect(const SeqRenderData *context, Sequence *seq, float UNUSED(cfra), float UNUSED(facf0), float UNUSED(facf1), | 
					
						
							|  |  |  |                           ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *ibuf3) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ImBuf *out = prepare_effect_imbufs(context, ibuf1, ibuf2, ibuf3); | 
					
						
							|  |  |  | 	TextVars *data = seq->effectdata; | 
					
						
							|  |  |  | 	int width = out->x; | 
					
						
							|  |  |  | 	int height = out->y; | 
					
						
							|  |  |  | 	struct ColorManagedDisplay *display; | 
					
						
							|  |  |  | 	const char *display_device; | 
					
						
							|  |  |  | 	const int mono = blf_mono_font_render; // XXX
 | 
					
						
							| 
									
										
										
										
											2015-07-11 02:17:06 +10:00
										 |  |  | 	int y_ofs, x, y; | 
					
						
							| 
									
										
										
										
											2015-09-09 14:36:12 +02:00
										 |  |  | 	float proxy_size_comp; | 
					
						
							| 
									
										
										
										
											2015-07-01 20:29:18 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	display_device = context->scene->display_settings.display_device; | 
					
						
							|  |  |  | 	display = IMB_colormanagement_display_get_named(display_device); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-09 14:36:12 +02:00
										 |  |  | 	/* Compensate text size for preview render size. */ | 
					
						
							|  |  |  | 	if (context->preview_render_size == SEQ_PROXY_RENDER_SIZE_100) { | 
					
						
							|  |  |  | 		/* Should be rendered at 100%, but context->preview_render_size = 99 right now. */ | 
					
						
							|  |  |  | 		proxy_size_comp = 1.0f; | 
					
						
							| 
									
										
										
										
											2015-09-09 14:39:21 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2015-09-09 14:36:12 +02:00
										 |  |  | 		proxy_size_comp = context->preview_render_size / 100.0f; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-01 20:29:18 +02:00
										 |  |  | 	/* set before return */ | 
					
						
							| 
									
										
										
										
											2015-09-09 14:36:12 +02:00
										 |  |  | 	BLF_size(mono, proxy_size_comp * (context->scene->r.size / 100) * data->text_size, 72); | 
					
						
							| 
									
										
										
										
											2015-07-01 20:29:18 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	BLF_buffer(mono, out->rect_float, (unsigned char *)out->rect, width, height, out->channels, display); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	y_ofs = -BLF_descender(mono); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-11 02:17:06 +10:00
										 |  |  | 	x = (data->loc[0] * width); | 
					
						
							|  |  |  | 	y = (data->loc[1] * height) + y_ofs; | 
					
						
							| 
									
										
										
										
											2015-07-01 20:29:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-11 02:17:06 +10:00
										 |  |  | 	if (data->align == SEQ_TEXT_ALIGN_LEFT) { | 
					
						
							|  |  |  | 		/* pass */ | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		const int w = BLF_width(mono, data->text, sizeof(data->text)); | 
					
						
							| 
									
										
										
										
											2015-07-01 20:29:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-11 02:17:06 +10:00
										 |  |  | 		if (data->align == SEQ_TEXT_ALIGN_RIGHT) { | 
					
						
							|  |  |  | 			x -= w; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else {  /* SEQ_TEXT_ALIGN_CENTER */ | 
					
						
							|  |  |  | 			x -= w / 2; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-07-01 20:29:18 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* BLF_SHADOW won't work with buffers, instead use cheap shadow trick */ | 
					
						
							| 
									
										
										
										
											2015-07-11 02:17:06 +10:00
										 |  |  | 	if (data->flag & SEQ_TEXT_SHADOW) { | 
					
						
							| 
									
										
										
										
											2015-07-01 20:29:18 +02:00
										 |  |  | 		int fontx, fonty; | 
					
						
							|  |  |  | 		fontx = BLF_width_max(mono); | 
					
						
							|  |  |  | 		fonty = BLF_height_max(mono); | 
					
						
							|  |  |  | 		BLF_position(mono, x + max_ii(fontx / 25, 1), y + max_ii(fonty / 25, 1), 0.0); | 
					
						
							|  |  |  | 		BLF_buffer_col(mono, 0.0f, 0.0f, 0.0f, 1.0); | 
					
						
							|  |  |  | 		BLF_draw_buffer(mono, data->text); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	BLF_position(mono, x, y, 0.0); | 
					
						
							|  |  |  | 	BLF_buffer_col(mono, 1.0f, 1.0f, 1.0f, 1.0); | 
					
						
							|  |  |  | 	BLF_draw_buffer(mono, data->text); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	BLF_buffer(mono, NULL, NULL, 0, 0, 0, NULL); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return out; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | /*********************** sequence effect factory *************************/ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void init_noop(Sequence *UNUSED(seq)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void load_noop(Sequence *UNUSED(seq)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void free_noop(Sequence *UNUSED(seq)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 12:30:59 +00:00
										 |  |  | static int num_inputs_default(void) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	return 2; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-01 20:29:18 +02:00
										 |  |  | static void copy_effect_default(Sequence *dst, Sequence *src) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	dst->effectdata = MEM_dupallocN(src->effectdata); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void free_effect_default(Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (seq->effectdata) | 
					
						
							|  |  |  | 		MEM_freeN(seq->effectdata); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	seq->effectdata = NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static int early_out_noop(Sequence *UNUSED(seq), float UNUSED(facf0), float UNUSED(facf1)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:44 +00:00
										 |  |  | 	return EARLY_DO_EFFECT; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static int early_out_fade(Sequence *UNUSED(seq), float facf0, float facf1) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 	if (facf0 == 0.0f && facf1 == 0.0f) { | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:44 +00:00
										 |  |  | 		return EARLY_USE_INPUT_1; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:18:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if (facf0 == 1.0f && facf1 == 1.0f) { | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:44 +00:00
										 |  |  | 		return EARLY_USE_INPUT_2; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:44 +00:00
										 |  |  | 	return EARLY_DO_EFFECT; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static int early_out_mul_input2(Sequence *UNUSED(seq), float facf0, float facf1) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 	if (facf0 == 0.0f && facf1 == 0.0f) { | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:44 +00:00
										 |  |  | 		return EARLY_USE_INPUT_1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:44 +00:00
										 |  |  | 	return EARLY_DO_EFFECT; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void store_icu_yrange_noop(Sequence *UNUSED(seq), short UNUSED(adrcode), float *UNUSED(ymin), float *UNUSED(ymax)) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* defaults are fine */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void get_default_fac_noop(Sequence *UNUSED(seq), float UNUSED(cfra), float *facf0, float *facf1) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	*facf0 = *facf1 = 1.0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | static void get_default_fac_fade(Sequence *seq, float cfra, float *facf0, float *facf1) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	*facf0 = (float)(cfra - seq->startdisp); | 
					
						
							| 
									
										
										
										
											2011-03-30 16:11:16 +00:00
										 |  |  | 	*facf1 = (float)(*facf0 + 0.5f); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	*facf0 /= seq->len; | 
					
						
							|  |  |  | 	*facf1 /= seq->len; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | static struct ImBuf *init_execution(const SeqRenderData *context, ImBuf *ibuf1, ImBuf *ibuf2, ImBuf *ibuf3) | 
					
						
							| 
									
										
										
										
											2012-05-17 23:21:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:36 +00:00
										 |  |  | 	ImBuf *out = prepare_effect_imbufs(context, ibuf1, ibuf2, ibuf3); | 
					
						
							| 
									
										
										
										
											2010-07-25 17:19:55 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return out; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-17 23:21:11 +00:00
										 |  |  | static struct SeqEffectHandle get_sequence_effect_impl(int seq_type) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	struct SeqEffectHandle rval; | 
					
						
							|  |  |  | 	int sequence_type = seq_type; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 	rval.multithreaded = false; | 
					
						
							|  |  |  | 	rval.supports_mask = false; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	rval.init = init_noop; | 
					
						
							|  |  |  | 	rval.num_inputs = num_inputs_default; | 
					
						
							|  |  |  | 	rval.load = load_noop; | 
					
						
							|  |  |  | 	rval.free = free_noop; | 
					
						
							|  |  |  | 	rval.early_out = early_out_noop; | 
					
						
							|  |  |  | 	rval.get_default_fac = get_default_fac_noop; | 
					
						
							|  |  |  | 	rval.store_icu_yrange = store_icu_yrange_noop; | 
					
						
							|  |  |  | 	rval.execute = NULL; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 	rval.init_execution = init_execution; | 
					
						
							|  |  |  | 	rval.execute_slice = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	rval.copy = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	switch (sequence_type) { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_CROSS: | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 			rval.multithreaded = true; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 			rval.execute_slice = do_cross_effect; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rval.early_out = early_out_fade; | 
					
						
							|  |  |  | 			rval.get_default_fac = get_default_fac_fade; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_GAMCROSS: | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 			rval.multithreaded = true; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rval.init = init_gammacross; | 
					
						
							|  |  |  | 			rval.load = load_gammacross; | 
					
						
							|  |  |  | 			rval.free = free_gammacross; | 
					
						
							|  |  |  | 			rval.early_out = early_out_fade; | 
					
						
							|  |  |  | 			rval.get_default_fac = get_default_fac_fade; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 			rval.init_execution = gammacross_init_execution; | 
					
						
							|  |  |  | 			rval.execute_slice = do_gammacross_effect; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_ADD: | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 			rval.multithreaded = true; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 			rval.execute_slice = do_add_effect; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rval.early_out = early_out_mul_input2; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_SUB: | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 			rval.multithreaded = true; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 			rval.execute_slice = do_sub_effect; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rval.early_out = early_out_mul_input2; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_MUL: | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 			rval.multithreaded = true; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 			rval.execute_slice = do_mul_effect; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rval.early_out = early_out_mul_input2; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_ALPHAOVER: | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 			rval.multithreaded = true; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rval.init = init_alpha_over_or_under; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 			rval.execute_slice = do_alphaover_effect; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_OVERDROP: | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 			rval.multithreaded = true; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 			rval.execute_slice = do_overdrop_effect; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_ALPHAUNDER: | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 			rval.multithreaded = true; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rval.init = init_alpha_over_or_under; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 			rval.execute_slice = do_alphaunder_effect; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_WIPE: | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rval.init = init_wipe_effect; | 
					
						
							|  |  |  | 			rval.num_inputs = num_inputs_wipe; | 
					
						
							|  |  |  | 			rval.free = free_wipe_effect; | 
					
						
							|  |  |  | 			rval.copy = copy_wipe_effect; | 
					
						
							|  |  |  | 			rval.early_out = early_out_fade; | 
					
						
							|  |  |  | 			rval.get_default_fac = get_default_fac_fade; | 
					
						
							|  |  |  | 			rval.execute = do_wipe_effect; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_GLOW: | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rval.init = init_glow_effect; | 
					
						
							|  |  |  | 			rval.num_inputs = num_inputs_glow; | 
					
						
							|  |  |  | 			rval.free = free_glow_effect; | 
					
						
							|  |  |  | 			rval.copy = copy_glow_effect; | 
					
						
							|  |  |  | 			rval.execute = do_glow_effect; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_TRANSFORM: | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rval.init = init_transform_effect; | 
					
						
							|  |  |  | 			rval.num_inputs = num_inputs_transform; | 
					
						
							|  |  |  | 			rval.free = free_transform_effect; | 
					
						
							|  |  |  | 			rval.copy = copy_transform_effect; | 
					
						
							|  |  |  | 			rval.execute = do_transform_effect; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_SPEED: | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rval.init = init_speed_effect; | 
					
						
							|  |  |  | 			rval.num_inputs = num_inputs_speed; | 
					
						
							|  |  |  | 			rval.load = load_speed_effect; | 
					
						
							|  |  |  | 			rval.free = free_speed_effect; | 
					
						
							|  |  |  | 			rval.copy = copy_speed_effect; | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 			rval.execute = do_speed_effect; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rval.early_out = early_out_speed; | 
					
						
							|  |  |  | 			rval.store_icu_yrange = store_icu_yrange_speed; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_COLOR: | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rval.init = init_solid_color; | 
					
						
							|  |  |  | 			rval.num_inputs = num_inputs_color; | 
					
						
							|  |  |  | 			rval.early_out = early_out_color; | 
					
						
							|  |  |  | 			rval.free = free_solid_color; | 
					
						
							|  |  |  | 			rval.copy = copy_solid_color; | 
					
						
							|  |  |  | 			rval.execute = do_solid_color; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_MULTICAM: | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rval.num_inputs = num_inputs_multicam; | 
					
						
							|  |  |  | 			rval.early_out = early_out_multicam; | 
					
						
							|  |  |  | 			rval.execute = do_multicam; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_ADJUSTMENT: | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 			rval.supports_mask = true; | 
					
						
							| 
									
										
										
										
											2012-05-08 09:31:25 +00:00
										 |  |  | 			rval.num_inputs = num_inputs_adjustment; | 
					
						
							|  |  |  | 			rval.early_out = early_out_adjustment; | 
					
						
							|  |  |  | 			rval.execute = do_adjustment; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2014-07-19 22:16:10 +06:00
										 |  |  | 		case SEQ_TYPE_GAUSSIAN_BLUR: | 
					
						
							|  |  |  | 			rval.multithreaded = true; | 
					
						
							|  |  |  | 			rval.init = init_gaussian_blur_effect; | 
					
						
							|  |  |  | 			rval.num_inputs = num_inputs_gaussian_blur; | 
					
						
							|  |  |  | 			rval.free = free_gaussian_blur_effect; | 
					
						
							|  |  |  | 			rval.copy = copy_gaussian_blur_effect; | 
					
						
							|  |  |  | 			rval.early_out = early_out_gaussian_blur; | 
					
						
							|  |  |  | 			rval.execute_slice = do_gaussian_blur_effect; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2015-07-01 20:29:18 +02:00
										 |  |  | 		case SEQ_TYPE_TEXT: | 
					
						
							|  |  |  | 			rval.num_inputs = num_inputs_text; | 
					
						
							|  |  |  | 			rval.init = init_text_effect; | 
					
						
							|  |  |  | 			rval.free = free_effect_default; | 
					
						
							|  |  |  | 			rval.copy = copy_effect_default; | 
					
						
							|  |  |  | 			rval.early_out = early_out_text; | 
					
						
							|  |  |  | 			rval.execute = do_text_effect; | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return rval; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:40 +00:00
										 |  |  | struct SeqEffectHandle BKE_sequence_get_effect(Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 	struct SeqEffectHandle rval = {false, false, NULL}; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (seq->type & SEQ_TYPE_EFFECT) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		rval = get_sequence_effect_impl(seq->type); | 
					
						
							|  |  |  | 		if ((seq->flag & SEQ_EFFECT_NOT_LOADED) != 0) { | 
					
						
							|  |  |  | 			rval.load(seq); | 
					
						
							|  |  |  | 			seq->flag &= ~SEQ_EFFECT_NOT_LOADED; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return rval; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:40 +00:00
										 |  |  | struct SeqEffectHandle BKE_sequence_get_blend(Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 	struct SeqEffectHandle rval = {false, false, NULL}; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (seq->blend_mode != 0) { | 
					
						
							|  |  |  | 		rval = get_sequence_effect_impl(seq->blend_mode); | 
					
						
							|  |  |  | 		if ((seq->flag & SEQ_EFFECT_NOT_LOADED) != 0) { | 
					
						
							|  |  |  | 			rval.load(seq); | 
					
						
							|  |  |  | 			seq->flag &= ~SEQ_EFFECT_NOT_LOADED; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return rval; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:40 +00:00
										 |  |  | int BKE_sequence_effect_get_num_inputs(int seq_type) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	struct SeqEffectHandle rval = get_sequence_effect_impl(seq_type); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	int cnt = rval.num_inputs(); | 
					
						
							| 
									
										
										
										
											2012-08-08 16:46:45 +00:00
										 |  |  | 	if (rval.execute || (rval.execute_slice && rval.init_execution)) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		return cnt; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2012-08-11 14:37:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | int BKE_sequence_effect_get_supports_mask(int seq_type) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct SeqEffectHandle rval = get_sequence_effect_impl(seq_type); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return rval.supports_mask; | 
					
						
							|  |  |  | } |