| 
									
										
										
										
											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 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-27 20:29:51 +00:00
										 |  |  | /** \file blender/editors/space_sequencer/sequencer_draw.c
 | 
					
						
							|  |  |  |  *  \ingroup spseq | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #include <math.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "BLI_blenlib.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | #include "BLI_math.h"
 | 
					
						
							| 
									
										
										
										
											2011-01-07 18:36:47 +00:00
										 |  |  | #include "BLI_utildefines.h"
 | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | #include "BLI_threads.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "IMB_imbuf_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "DNA_scene_types.h"
 | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | #include "DNA_mask_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | #include "DNA_screen_types.h"
 | 
					
						
							|  |  |  | #include "DNA_space_types.h"
 | 
					
						
							|  |  |  | #include "DNA_userdef_types.h"
 | 
					
						
							| 
									
										
										
										
											2010-08-04 04:01:27 +00:00
										 |  |  | #include "DNA_sound_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "BKE_context.h"
 | 
					
						
							|  |  |  | #include "BKE_global.h"
 | 
					
						
							| 
									
										
										
										
											2013-12-26 17:24:42 +06:00
										 |  |  | #include "BKE_main.h"
 | 
					
						
							| 
									
										
										
										
											2009-12-13 14:56:45 +00:00
										 |  |  | #include "BKE_sequencer.h"
 | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | #include "BKE_sound.h"
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | #include "BKE_scene.h"
 | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | #include "IMB_imbuf.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "BIF_gl.h"
 | 
					
						
							|  |  |  | #include "BIF_glutil.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-05 22:11:31 +01:00
										 |  |  | #include "GPU_basic_shader.h"
 | 
					
						
							| 
									
										
										
										
											2015-11-28 01:20:28 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | #include "ED_anim_api.h"
 | 
					
						
							| 
									
										
										
										
											2012-06-11 00:21:50 +00:00
										 |  |  | #include "ED_gpencil.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | #include "ED_markers.h"
 | 
					
						
							| 
									
										
										
										
											2012-06-07 19:24:49 +00:00
										 |  |  | #include "ED_mask.h"
 | 
					
						
							| 
									
										
										
										
											2012-12-17 04:44:39 +00:00
										 |  |  | #include "ED_sequencer.h"
 | 
					
						
							| 
									
										
										
										
											2015-05-04 12:17:49 +02:00
										 |  |  | #include "ED_screen.h"
 | 
					
						
							| 
									
										
										
										
											2012-06-07 19:24:49 +00:00
										 |  |  | #include "ED_space_api.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "UI_interface.h"
 | 
					
						
							|  |  |  | #include "UI_resources.h"
 | 
					
						
							|  |  |  | #include "UI_view2d.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 "WM_api.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-28 19:45:16 +01:00
										 |  |  | #include "MEM_guardedalloc.h"
 | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | /* own include */ | 
					
						
							|  |  |  | #include "sequencer_intern.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-15 12:18:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-20 17:10:40 +00:00
										 |  |  | #define SEQ_LEFTHANDLE   1
 | 
					
						
							|  |  |  | #define SEQ_RIGHTHANDLE  2
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define SEQ_HANDLE_SIZE_MIN  7.0f
 | 
					
						
							|  |  |  | #define SEQ_HANDLE_SIZE_MAX 40.0f
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-01 16:22:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-18 07:38:51 +00:00
										 |  |  | /* Note, Don't use SEQ_BEGIN/SEQ_END while drawing!
 | 
					
						
							| 
									
										
										
										
											2011-10-26 22:46:06 +00:00
										 |  |  |  * it messes up transform, - Campbell */ | 
					
						
							| 
									
										
										
										
											2014-11-10 19:39:20 +01:00
										 |  |  | #undef SEQ_BEGIN
 | 
					
						
							|  |  |  | #undef SEQP_BEGIN
 | 
					
						
							|  |  |  | #undef SEQ_END
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-06 23:09:56 +11:00
										 |  |  | static Sequence *special_seq_update = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | void color3ubv_from_seq(Scene *curscene, Sequence *seq, unsigned char col[3]) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	unsigned char blendcol[3]; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	SolidColorVars *colvars = (SolidColorVars *)seq->effectdata; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	switch (seq->type) { | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_IMAGE: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			UI_GetThemeColor3ubv(TH_SEQ_IMAGE, col); | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_META: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			UI_GetThemeColor3ubv(TH_SEQ_META, col); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_MOVIE: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			UI_GetThemeColor3ubv(TH_SEQ_MOVIE, col); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_MOVIECLIP: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			UI_GetThemeColor3ubv(TH_SEQ_MOVIECLIP, col); | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		case SEQ_TYPE_MASK: | 
					
						
							|  |  |  | 			UI_GetThemeColor3ubv(TH_SEQ_MASK, col); /* TODO */ | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_SCENE: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			UI_GetThemeColor3ubv(TH_SEQ_SCENE, col); | 
					
						
							| 
									
										
										
										
											2010-09-15 11:58:19 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			if (seq->scene == curscene) { | 
					
						
							|  |  |  | 				UI_GetColorPtrShade3ubv(col, col, 20); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2010-09-15 11:58:19 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		/* transitions */ | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_CROSS: | 
					
						
							|  |  |  | 		case SEQ_TYPE_GAMCROSS: | 
					
						
							|  |  |  | 		case SEQ_TYPE_WIPE: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			UI_GetThemeColor3ubv(TH_SEQ_TRANSITION, col); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/* slightly offset hue to distinguish different effects */ | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 			if (seq->type == SEQ_TYPE_CROSS)    rgb_byte_set_hue_float_offset(col, 0.04); | 
					
						
							|  |  |  | 			if (seq->type == SEQ_TYPE_GAMCROSS) rgb_byte_set_hue_float_offset(col, 0.08); | 
					
						
							|  |  |  | 			if (seq->type == SEQ_TYPE_WIPE)     rgb_byte_set_hue_float_offset(col, 0.12); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* effects */ | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_TRANSFORM: | 
					
						
							|  |  |  | 		case SEQ_TYPE_SPEED: | 
					
						
							|  |  |  | 		case SEQ_TYPE_ADD: | 
					
						
							|  |  |  | 		case SEQ_TYPE_SUB: | 
					
						
							|  |  |  | 		case SEQ_TYPE_MUL: | 
					
						
							|  |  |  | 		case SEQ_TYPE_ALPHAOVER: | 
					
						
							|  |  |  | 		case SEQ_TYPE_ALPHAUNDER: | 
					
						
							|  |  |  | 		case SEQ_TYPE_OVERDROP: | 
					
						
							|  |  |  | 		case SEQ_TYPE_GLOW: | 
					
						
							|  |  |  | 		case SEQ_TYPE_MULTICAM: | 
					
						
							|  |  |  | 		case SEQ_TYPE_ADJUSTMENT: | 
					
						
							| 
									
										
										
										
											2014-07-19 22:16:10 +06:00
										 |  |  | 		case SEQ_TYPE_GAUSSIAN_BLUR: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			UI_GetThemeColor3ubv(TH_SEQ_EFFECT, col); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/* slightly offset hue to distinguish different effects */ | 
					
						
							| 
									
										
										
										
											2014-07-19 22:16:10 +06:00
										 |  |  | 			if      (seq->type == SEQ_TYPE_ADD)           rgb_byte_set_hue_float_offset(col, 0.04); | 
					
						
							|  |  |  | 			else if (seq->type == SEQ_TYPE_SUB)           rgb_byte_set_hue_float_offset(col, 0.08); | 
					
						
							|  |  |  | 			else if (seq->type == SEQ_TYPE_MUL)           rgb_byte_set_hue_float_offset(col, 0.12); | 
					
						
							|  |  |  | 			else if (seq->type == SEQ_TYPE_ALPHAOVER)     rgb_byte_set_hue_float_offset(col, 0.16); | 
					
						
							|  |  |  | 			else if (seq->type == SEQ_TYPE_ALPHAUNDER)    rgb_byte_set_hue_float_offset(col, 0.20); | 
					
						
							|  |  |  | 			else if (seq->type == SEQ_TYPE_OVERDROP)      rgb_byte_set_hue_float_offset(col, 0.24); | 
					
						
							|  |  |  | 			else if (seq->type == SEQ_TYPE_GLOW)          rgb_byte_set_hue_float_offset(col, 0.28); | 
					
						
							|  |  |  | 			else if (seq->type == SEQ_TYPE_TRANSFORM)     rgb_byte_set_hue_float_offset(col, 0.36); | 
					
						
							|  |  |  | 			else if (seq->type == SEQ_TYPE_MULTICAM)      rgb_byte_set_hue_float_offset(col, 0.32); | 
					
						
							|  |  |  | 			else if (seq->type == SEQ_TYPE_ADJUSTMENT)    rgb_byte_set_hue_float_offset(col, 0.40); | 
					
						
							|  |  |  | 			else if (seq->type == SEQ_TYPE_GAUSSIAN_BLUR) rgb_byte_set_hue_float_offset(col, 0.42); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_COLOR: | 
					
						
							| 
									
										
										
										
											2013-07-13 14:16:59 +00:00
										 |  |  | 			rgb_float_to_uchar(col, colvars->col); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 		case SEQ_TYPE_SOUND_RAM: | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			UI_GetThemeColor3ubv(TH_SEQ_AUDIO, col); | 
					
						
							|  |  |  | 			blendcol[0] = blendcol[1] = blendcol[2] = 128; | 
					
						
							|  |  |  | 			if (seq->flag & SEQ_MUTE) UI_GetColorPtrBlendShade3ubv(col, blendcol, col, 0.5, 20); | 
					
						
							|  |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2015-12-01 23:56:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		case SEQ_TYPE_TEXT: | 
					
						
							|  |  |  | 			UI_GetThemeColor3ubv(TH_SEQ_TEXT, col); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		default: | 
					
						
							|  |  |  | 			col[0] = 10; col[1] = 255; col[2] = 40; | 
					
						
							| 
									
										
										
										
											2013-07-21 08:16:37 +00:00
										 |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | static void drawseqwave(const bContext *C, SpaceSeq *sseq, Scene *scene, Sequence *seq, float x1, float y1, float x2, float y2, float stepsize) | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/*
 | 
					
						
							| 
									
										
										
										
											2012-03-03 16:31:46 +00:00
										 |  |  | 	 * x1 is the starting x value to draw the wave, | 
					
						
							|  |  |  | 	 * x2 the end x value, same for y1 and y2 | 
					
						
							|  |  |  | 	 * stepsize is width of a pixel. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2016-01-04 19:41:26 +11:00
										 |  |  | 	if (seq->sound && ((sseq->flag & SEQ_ALL_WAVEFORMS) || (seq->flag & SEQ_AUDIO_DRAW_WAVEFORM))) { | 
					
						
							| 
									
										
										
										
											2011-08-09 14:10:32 +00:00
										 |  |  | 		int i, j, pos; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		int length = floor((x2 - x1) / stepsize) + 1; | 
					
						
							|  |  |  | 		float ymid = (y1 + y2) / 2; | 
					
						
							|  |  |  | 		float yscale = (y2 - y1) / 2; | 
					
						
							| 
									
										
										
										
											2011-08-09 14:10:32 +00:00
										 |  |  | 		float samplestep; | 
					
						
							|  |  |  | 		float startsample, endsample; | 
					
						
							| 
									
										
										
										
											2015-10-14 12:15:03 +03:00
										 |  |  | 		float value1, value2; | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 		bSound *sound = seq->sound; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		SoundWaveform *waveform; | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2015-01-28 19:45:16 +01:00
										 |  |  | 		if (!sound->spinlock) { | 
					
						
							|  |  |  | 			sound->spinlock = MEM_mallocN(sizeof(SpinLock), "sound_spinlock"); | 
					
						
							|  |  |  | 			BLI_spin_init(sound->spinlock); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2015-01-28 19:45:16 +01:00
										 |  |  | 		BLI_spin_lock(sound->spinlock); | 
					
						
							| 
									
										
										
										
											2016-01-04 19:41:26 +11:00
										 |  |  | 		if (!sound->waveform) { | 
					
						
							| 
									
										
										
										
											2014-11-26 10:44:06 +01:00
										 |  |  | 			if (!(sound->flags & SOUND_FLAGS_WAVEFORM_LOADING)) { | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 				/* prevent sounds from reloading */ | 
					
						
							| 
									
										
										
										
											2016-01-04 19:41:26 +11:00
										 |  |  | 				sound->flags |= SOUND_FLAGS_WAVEFORM_LOADING; | 
					
						
							| 
									
										
										
										
											2015-01-28 19:45:16 +01:00
										 |  |  | 				BLI_spin_unlock(sound->spinlock); | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 				sequencer_preview_add_sound(C, seq); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2015-01-28 19:45:16 +01:00
										 |  |  | 				BLI_spin_unlock(sound->spinlock); | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			return;  /* nothing to draw */ | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2015-01-28 19:45:16 +01:00
										 |  |  | 		BLI_spin_unlock(sound->spinlock); | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2016-01-04 19:41:26 +11:00
										 |  |  | 		waveform = sound->waveform; | 
					
						
							| 
									
										
										
										
											2015-08-07 23:42:32 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if (waveform->length == 0) { | 
					
						
							|  |  |  | 			/* BKE_sound_read_waveform() set an empty SoundWaveform data in case it cannot generate a valid one...
 | 
					
						
							|  |  |  | 			 * See T45726. */ | 
					
						
							|  |  |  | 			return; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		startsample = floor((seq->startofs + seq->anim_startofs) / FPS * SOUND_WAVE_SAMPLES_PER_SECOND); | 
					
						
							|  |  |  | 		endsample = ceil((seq->startofs + seq->anim_startofs + seq->enddisp - seq->startdisp) / FPS * SOUND_WAVE_SAMPLES_PER_SECOND); | 
					
						
							|  |  |  | 		samplestep = (endsample - startsample) * stepsize / (x2 - x1); | 
					
						
							| 
									
										
										
										
											2011-08-09 14:10:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (length > floor((waveform->length - startsample) / samplestep)) | 
					
						
							| 
									
										
										
										
											2011-08-09 14:10:32 +00:00
										 |  |  | 			length = floor((waveform->length - startsample) / samplestep); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-14 12:15:03 +03:00
										 |  |  | 		glColor4f(1.0f, 1.0f, 1.0f, 0.5); | 
					
						
							|  |  |  | 		glEnable(GL_BLEND); | 
					
						
							|  |  |  | 		glBegin(GL_TRIANGLE_STRIP); | 
					
						
							| 
									
										
										
										
											2012-04-28 06:31:57 +00:00
										 |  |  | 		for (i = 0; i < length; i++) { | 
					
						
							| 
									
										
										
										
											2015-10-14 12:15:03 +03:00
										 |  |  | 			float sampleoffset = startsample + i * samplestep; | 
					
						
							|  |  |  | 			pos = sampleoffset; | 
					
						
							| 
									
										
										
										
											2011-08-09 14:10:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-14 12:15:03 +03:00
										 |  |  | 			value1 = waveform->data[pos * 3]; | 
					
						
							|  |  |  | 			value2 = waveform->data[pos * 3 + 1]; | 
					
						
							| 
									
										
										
										
											2011-08-09 14:10:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-14 12:23:17 +03:00
										 |  |  | 			if (samplestep > 1.0f) { | 
					
						
							| 
									
										
										
										
											2015-10-14 12:15:03 +03:00
										 |  |  | 				for (j = pos + 1; (j < waveform->length) && (j < pos + samplestep); j++) { | 
					
						
							|  |  |  | 					if (value1 > waveform->data[j * 3]) | 
					
						
							|  |  |  | 						value1 = waveform->data[j * 3]; | 
					
						
							| 
									
										
										
										
											2011-08-09 14:10:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-14 12:15:03 +03:00
										 |  |  | 					if (value2 < waveform->data[j * 3 + 1]) | 
					
						
							|  |  |  | 						value2 = waveform->data[j * 3 + 1]; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2015-10-14 12:23:17 +03:00
										 |  |  | 				/* use simple linear interpolation */ | 
					
						
							| 
									
										
										
										
											2015-10-14 12:15:03 +03:00
										 |  |  | 				float f = sampleoffset - pos; | 
					
						
							|  |  |  | 				value1 = (1.0f - f) * value1 + f * waveform->data[pos * 3 + 3]; | 
					
						
							|  |  |  | 				value2 = (1.0f - f) * value2 + f * waveform->data[pos * 3 + 4]; | 
					
						
							| 
									
										
										
										
											2011-08-09 14:10:32 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-14 12:15:03 +03:00
										 |  |  | 			glVertex2f(x1 + i * stepsize, ymid + value1 * yscale); | 
					
						
							|  |  |  | 			glVertex2f(x1 + i * stepsize, ymid + value2 * yscale); | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		glEnd(); | 
					
						
							| 
									
										
										
										
											2015-10-14 12:15:03 +03:00
										 |  |  | 		glDisable(GL_BLEND); | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | static void drawmeta_stipple(int value) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (value) { | 
					
						
							| 
									
										
										
										
											2015-12-25 22:57:50 +01:00
										 |  |  | 		GPU_basic_shader_bind(GPU_SHADER_STIPPLE | GPU_SHADER_USE_COLOR); | 
					
						
							|  |  |  | 		GPU_basic_shader_stipple(GPU_SHADER_STIPPLE_HALFTONE); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		glEnable(GL_LINE_STIPPLE); | 
					
						
							|  |  |  | 		glLineStipple(1, 0x8888); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2015-12-25 22:57:50 +01:00
										 |  |  | 		GPU_basic_shader_bind(GPU_SHADER_USE_COLOR); | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 		glDisable(GL_LINE_STIPPLE); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void drawmeta_contents(Scene *scene, Sequence *seqm, float x1, float y1, float x2, float y2) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-10-26 22:46:06 +00:00
										 |  |  | 	/* note: this used to use SEQ_BEGIN/SEQ_END, but it messes up the
 | 
					
						
							|  |  |  | 	 * seq->depth value, (needed by transform when doing overlap checks) | 
					
						
							|  |  |  | 	 * so for now, just use the meta's immediate children, could be fixed but | 
					
						
							|  |  |  | 	 * its only drawing - campbell */ | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 	Sequence *seq; | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	unsigned char col[4]; | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	int chan_min = MAXSEQ; | 
					
						
							|  |  |  | 	int chan_max = 0; | 
					
						
							|  |  |  | 	int chan_range = 0; | 
					
						
							|  |  |  | 	float draw_range = y2 - y1; | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 	float draw_height; | 
					
						
							| 
									
										
										
										
											2014-12-10 15:26:41 +01:00
										 |  |  | 	ListBase *seqbase; | 
					
						
							|  |  |  | 	int offset; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	seqbase = BKE_sequence_seqbase_get(seqm, &offset); | 
					
						
							|  |  |  | 	if (!seqbase || BLI_listbase_is_empty(seqbase)) { | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (seqm->type == SEQ_TYPE_SCENE) { | 
					
						
							|  |  |  | 		offset  = seqm->start - offset; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		offset = 0; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	glEnable(GL_BLEND); | 
					
						
							|  |  |  | 	glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (seqm->flag & SEQ_MUTE) | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 		drawmeta_stipple(1); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-10 15:26:41 +01:00
										 |  |  | 	for (seq = seqbase->first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2012-11-07 12:31:05 +00:00
										 |  |  | 		chan_min = min_ii(chan_min, seq->machine); | 
					
						
							|  |  |  | 		chan_max = max_ii(chan_max, seq->machine); | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	chan_range = (chan_max - chan_min) + 1; | 
					
						
							|  |  |  | 	draw_height = draw_range / chan_range; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	col[3] = 196; /* alpha, used for all meta children */ | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-10 15:26:41 +01:00
										 |  |  | 	for (seq = seqbase->first; seq; seq = seq->next) { | 
					
						
							|  |  |  | 		const int startdisp = seq->startdisp + offset; | 
					
						
							|  |  |  | 		const int enddisp   = seq->enddisp   + offset; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if ((startdisp > x2 || enddisp < x1) == 0) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			float y_chan = (seq->machine - chan_min) / (float)(chan_range) * draw_range; | 
					
						
							| 
									
										
										
										
											2014-12-10 15:26:41 +01:00
										 |  |  | 			float x1_chan = startdisp; | 
					
						
							|  |  |  | 			float x2_chan = enddisp; | 
					
						
							| 
									
										
										
										
											2010-07-04 08:49:54 +00:00
										 |  |  | 			float y1_chan, y2_chan; | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if ((seqm->flag & SEQ_MUTE) == 0 && (seq->flag & SEQ_MUTE)) | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 				drawmeta_stipple(1); | 
					
						
							| 
									
										
										
										
											2010-07-04 08:49:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 			color3ubv_from_seq(scene, seq, col); | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 			glColor4ubv(col); | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2010-07-04 08:49:54 +00:00
										 |  |  | 			/* clamp within parent sequence strip bounds */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			if (x1_chan < x1) x1_chan = x1; | 
					
						
							|  |  |  | 			if (x2_chan > x2) x2_chan = x2; | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			y1_chan = y1 + y_chan + (draw_height * SEQ_STRIP_OFSBOTTOM); | 
					
						
							|  |  |  | 			y2_chan = y1 + y_chan + (draw_height * SEQ_STRIP_OFSTOP); | 
					
						
							| 
									
										
										
										
											2010-07-04 08:49:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			glRectf(x1_chan,  y1_chan, x2_chan,  y2_chan); | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-11 04:31:09 +00:00
										 |  |  | 			UI_GetColorPtrShade3ubv(col, col, -30); | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 			glColor4ubv(col); | 
					
						
							| 
									
										
										
										
											2010-07-04 08:49:54 +00:00
										 |  |  | 			fdrawbox(x1_chan,  y1_chan, x2_chan,  y2_chan); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if ((seqm->flag & SEQ_MUTE) == 0 && (seq->flag & SEQ_MUTE)) | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 				drawmeta_stipple(0); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (seqm->flag & SEQ_MUTE) | 
					
						
							|  |  |  | 		drawmeta_stipple(0); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 	glDisable(GL_BLEND); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-20 17:10:40 +00:00
										 |  |  | /* clamp handles to defined size in pixel space */ | 
					
						
							|  |  |  | static float draw_seq_handle_size_get_clamped(Sequence *seq, const float pixelx) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	const float minhandle = pixelx * SEQ_HANDLE_SIZE_MIN; | 
					
						
							|  |  |  | 	const float maxhandle = pixelx * SEQ_HANDLE_SIZE_MAX; | 
					
						
							| 
									
										
										
										
											2014-11-14 16:47:30 +01:00
										 |  |  | 	float size = CLAMPIS(seq->handsize, minhandle, maxhandle); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-21 14:14:50 +01:00
										 |  |  | 	/* ensure we're not greater than half width */ | 
					
						
							| 
									
										
										
										
											2014-11-14 16:47:30 +01:00
										 |  |  | 	return min_ff(size, ((float)(seq->enddisp - seq->startdisp) / 2.0f) / pixelx); | 
					
						
							| 
									
										
										
										
											2012-06-20 17:10:40 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | /* draw a handle, for each end of a sequence strip */ | 
					
						
							| 
									
										
										
										
											2012-06-20 17:10:40 +00:00
										 |  |  | static void draw_seq_handle(View2D *v2d, Sequence *seq, const float handsize_clamped, const short direction) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	float v1[2], v2[2], v3[2], rx1 = 0, rx2 = 0; //for triangles and rect
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	float x1, x2, y1, y2; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	unsigned int whichsel = 0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	x1 = seq->startdisp; | 
					
						
							|  |  |  | 	x2 = seq->enddisp; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	y1 = seq->machine + SEQ_STRIP_OFSBOTTOM; | 
					
						
							|  |  |  | 	y2 = seq->machine + SEQ_STRIP_OFSTOP; | 
					
						
							| 
									
										
										
										
											2012-06-20 17:10:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	/* set up co-ordinates/dimensions for either left or right handle */ | 
					
						
							| 
									
										
										
										
											2012-10-21 05:46:41 +00:00
										 |  |  | 	if (direction == SEQ_LEFTHANDLE) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		rx1 = x1; | 
					
						
							| 
									
										
										
										
											2012-06-20 17:10:40 +00:00
										 |  |  | 		rx2 = x1 + handsize_clamped * 0.75f; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-06-20 17:10:40 +00:00
										 |  |  | 		v1[0] = x1 + handsize_clamped / 4; v1[1] = y1 + ( ((y1 + y2) / 2.0f - y1) / 2); | 
					
						
							|  |  |  | 		v2[0] = x1 + handsize_clamped / 4; v2[1] = y2 - ( ((y1 + y2) / 2.0f - y1) / 2); | 
					
						
							|  |  |  | 		v3[0] = v2[0] + handsize_clamped / 4; v3[1] = (y1 + y2) / 2.0f; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		whichsel = SEQ_LEFTSEL; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if (direction == SEQ_RIGHTHANDLE) { | 
					
						
							| 
									
										
										
										
											2012-06-20 17:10:40 +00:00
										 |  |  | 		rx1 = x2 - handsize_clamped * 0.75f; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		rx2 = x2; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-06-20 17:10:40 +00:00
										 |  |  | 		v1[0] = x2 - handsize_clamped / 4; v1[1] = y1 + ( ((y1 + y2) / 2.0f - y1) / 2); | 
					
						
							|  |  |  | 		v2[0] = x2 - handsize_clamped / 4; v2[1] = y2 - ( ((y1 + y2) / 2.0f - y1) / 2); | 
					
						
							|  |  |  | 		v3[0] = v2[0] - handsize_clamped / 4; v3[1] = (y1 + y2) / 2.0f; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		whichsel = SEQ_RIGHTSEL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* draw! */ | 
					
						
							| 
									
										
										
										
											2015-07-01 17:32:56 +02:00
										 |  |  | 	if (!(seq->type & SEQ_TYPE_EFFECT) || | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:40 +00:00
										 |  |  | 	    BKE_sequence_effect_get_num_inputs(seq->type) == 0) | 
					
						
							| 
									
										
										
										
											2012-05-20 19:49:27 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		glEnable(GL_BLEND); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (seq->flag & whichsel) glColor4ub(0, 0, 0, 80); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		else if (seq->flag & SELECT) glColor4ub(255, 255, 255, 30); | 
					
						
							|  |  |  | 		else glColor4ub(0, 0, 0, 22); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glRectf(rx1, y1, rx2, y2); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (seq->flag & whichsel) glColor4ub(255, 255, 255, 200); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		else glColor4ub(0, 0, 0, 50); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		glEnable(GL_POLYGON_SMOOTH); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		glBegin(GL_TRIANGLES); | 
					
						
							|  |  |  | 		glVertex2fv(v1); glVertex2fv(v2); glVertex2fv(v3); | 
					
						
							|  |  |  | 		glEnd(); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		glDisable(GL_POLYGON_SMOOTH); | 
					
						
							|  |  |  | 		glDisable(GL_BLEND); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2013-06-24 22:41:37 +00:00
										 |  |  | 	if ((G.moving & G_TRANSFORM_SEQ) || (seq->flag & whichsel)) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		const char col[4] = {255, 255, 255, 255}; | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 		char numstr[32]; | 
					
						
							|  |  |  | 		size_t numstr_len; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		if (direction == SEQ_LEFTHANDLE) { | 
					
						
							| 
									
										
										
										
											2015-04-22 05:37:22 +10:00
										 |  |  | 			numstr_len = BLI_snprintf_rlen(numstr, sizeof(numstr), "%d", seq->startdisp); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			x1 = rx1; | 
					
						
							| 
									
										
										
										
											2011-03-30 05:07:12 +00:00
										 |  |  | 			y1 -= 0.45f; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2015-04-22 05:37:22 +10:00
										 |  |  | 			numstr_len = BLI_snprintf_rlen(numstr, sizeof(numstr), "%d", seq->enddisp - 1); | 
					
						
							| 
									
										
										
										
											2012-06-20 17:10:40 +00:00
										 |  |  | 			x1 = x2 - handsize_clamped * 0.75f; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			y1 = y2 + 0.05f; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 		UI_view2d_text_cache_add(v2d, x1, y1, numstr, numstr_len, col); | 
					
						
							| 
									
										
										
										
											2012-10-21 05:46:41 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* draw info text on a sequence strip */ | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | static void draw_seq_text(View2D *v2d, Sequence *seq, float x1, float x2, float y1, float y2, const unsigned char background_col[3]) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-06-01 17:21:03 +00:00
										 |  |  | 	rctf rect; | 
					
						
							| 
									
										
										
										
											2011-11-26 04:07:38 +00:00
										 |  |  | 	char str[32 + FILE_MAX]; | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 	size_t str_len; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	const char *name = seq->name + 2; | 
					
						
							| 
									
										
										
										
											2010-12-07 07:02:47 +00:00
										 |  |  | 	char col[4]; | 
					
						
							| 
									
										
										
										
											2011-10-11 23:52:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* note, all strings should include 'name' */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (name[0] == '\0') | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:40 +00:00
										 |  |  | 		name = BKE_sequence_give_name(seq); | 
					
						
							| 
									
										
										
										
											2010-03-09 13:52:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (seq->type == SEQ_TYPE_META || seq->type == SEQ_TYPE_ADJUSTMENT) { | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 		str_len = BLI_snprintf(str, sizeof(str), "%s | %d", name, seq->len); | 
					
						
							| 
									
										
										
										
											2009-06-01 16:22:53 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	else if (seq->type == SEQ_TYPE_SCENE) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (seq->scene) { | 
					
						
							|  |  |  | 			if (seq->scene_camera) { | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 				str_len = BLI_snprintf(str, sizeof(str), "%s: %s (%s) | %d", | 
					
						
							|  |  |  | 				                       name, seq->scene->id.name + 2, ((ID *)seq->scene_camera)->name + 2, seq->len); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 				str_len = BLI_snprintf(str, sizeof(str), "%s: %s | %d", | 
					
						
							|  |  |  | 				                       name, seq->scene->id.name + 2, seq->len); | 
					
						
							| 
									
										
										
										
											2010-03-09 13:52:52 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-03-09 13:52:52 +00:00
										 |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 			str_len = BLI_snprintf(str, sizeof(str), "%s | %d", | 
					
						
							|  |  |  | 			                       name, seq->len); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
											  
											
												== 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-06-07 15:49:02 +00:00
										 |  |  | 	else if (seq->type == SEQ_TYPE_MOVIECLIP) { | 
					
						
							| 
									
										
										
										
											2015-01-26 16:03:11 +01:00
										 |  |  | 		if (seq->clip && !STREQ(name, seq->clip->id.name + 2)) { | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 			str_len = BLI_snprintf(str, sizeof(str), "%s: %s | %d", | 
					
						
							|  |  |  | 			                       name, seq->clip->id.name + 2, seq->len); | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 			str_len = BLI_snprintf(str, sizeof(str), "%s | %d", | 
					
						
							|  |  |  | 			                       name, seq->len); | 
					
						
							| 
									
										
										
										
											2012-03-21 18:02:29 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | 	else if (seq->type == SEQ_TYPE_MASK) { | 
					
						
							| 
									
										
										
										
											2015-01-26 16:03:11 +01:00
										 |  |  | 		if (seq->mask && !STREQ(name, seq->mask->id.name + 2)) { | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 			str_len = BLI_snprintf(str, sizeof(str), "%s: %s | %d", | 
					
						
							|  |  |  | 			                       name, seq->mask->id.name + 2, seq->len); | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 			str_len = BLI_snprintf(str, sizeof(str), "%s | %d", | 
					
						
							|  |  |  | 			                       name, seq->len); | 
					
						
							| 
									
										
										
										
											2012-06-07 18:24:36 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	else if (seq->type == SEQ_TYPE_MULTICAM) { | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 		str_len = BLI_snprintf(str, sizeof(str), "Cam %s: %d", | 
					
						
							|  |  |  | 		                       name, seq->multicam_source); | 
					
						
							| 
									
										
										
										
											2010-03-09 13:52:52 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	else if (seq->type == SEQ_TYPE_IMAGE) { | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 		str_len = BLI_snprintf(str, sizeof(str), "%s: %s%s | %d", | 
					
						
							|  |  |  | 		                       name, seq->strip->dir, seq->strip->stripdata->name, seq->len); | 
					
						
							| 
									
										
										
										
											2010-03-09 13:52:52 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-07-01 20:29:18 +02:00
										 |  |  | 	else if (seq->type == SEQ_TYPE_TEXT) { | 
					
						
							|  |  |  | 		TextVars *textdata = seq->effectdata; | 
					
						
							|  |  |  | 		str_len = BLI_snprintf(str, sizeof(str), "%s | %d", | 
					
						
							|  |  |  | 		                       textdata->text, seq->startdisp); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	else if (seq->type & SEQ_TYPE_EFFECT) { | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 		str_len = BLI_snprintf(str, sizeof(str), "%s | %d", | 
					
						
							|  |  |  | 		                       name, seq->len); | 
					
						
							| 
									
										
										
										
											2010-03-09 13:52:52 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	else if (seq->type == SEQ_TYPE_SOUND_RAM) { | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 		if (seq->sound) { | 
					
						
							|  |  |  | 			str_len = BLI_snprintf(str, sizeof(str), "%s: %s | %d", | 
					
						
							|  |  |  | 			                       name, seq->sound->name, seq->len); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			str_len = BLI_snprintf(str, sizeof(str), "%s | %d", | 
					
						
							|  |  |  | 			                       name, seq->len); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-03-09 13:52:52 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	else if (seq->type == SEQ_TYPE_MOVIE) { | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 		str_len = BLI_snprintf(str, sizeof(str), "%s: %s%s | %d", | 
					
						
							|  |  |  | 		                       name, seq->strip->dir, seq->strip->stripdata->name, seq->len); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* should never get here!, but might with files from future */ | 
					
						
							|  |  |  | 		BLI_assert(0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		str_len = BLI_snprintf(str, sizeof(str), "%s | %d", | 
					
						
							|  |  |  | 		                       name, seq->len); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (seq->flag & SELECT) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		col[0] = col[1] = col[2] = 255; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if ((((int)background_col[0] + (int)background_col[1] + (int)background_col[2]) / 3) < 50) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		col[0] = col[1] = col[2] = 80; /* use lighter text color for dark background */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		col[0] = col[1] = col[2] = 0; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	col[3] = 255; | 
					
						
							| 
									
										
										
										
											2010-12-07 07:02:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 	rect.xmin = x1; | 
					
						
							|  |  |  | 	rect.ymin = y1; | 
					
						
							|  |  |  | 	rect.xmax = x2; | 
					
						
							|  |  |  | 	rect.ymax = y2; | 
					
						
							| 
									
										
										
										
											2014-04-17 15:14:07 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-21 18:46:52 +10:00
										 |  |  | 	UI_view2d_text_cache_add_rectf(v2d, &rect, str, str_len, col); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* draws a shaded strip, made from gradient + flat color + gradient */ | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | void draw_shadedstrip(Sequence *seq, unsigned char col[3], float x1, float y1, float x2, float y2) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	float ymid1, ymid2; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (seq->flag & SEQ_MUTE) { | 
					
						
							| 
									
										
										
										
											2015-12-25 22:57:50 +01:00
										 |  |  | 		GPU_basic_shader_bind(GPU_SHADER_STIPPLE | GPU_SHADER_USE_COLOR); | 
					
						
							|  |  |  | 		GPU_basic_shader_stipple(GPU_SHADER_STIPPLE_HALFTONE); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	ymid1 = (y2 - y1) * 0.25f + y1; | 
					
						
							|  |  |  | 	ymid2 = (y2 - y1) * 0.65f + y1; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	glBegin(GL_QUADS); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (seq->flag & SEQ_INVALID_EFFECT) { col[0] = 255; col[1] = 0; col[2] = 255; } | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (seq->flag & SELECT) UI_GetColorPtrShade3ubv(col, col, -50); | 
					
						
							| 
									
										
										
										
											2011-09-11 04:31:09 +00:00
										 |  |  | 	/* else UI_GetColorPtrShade3ubv(col, col, 0); */ /* DO NOTHING */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	glColor3ubv(col); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	glVertex2f(x1, y1); | 
					
						
							|  |  |  | 	glVertex2f(x2, y1); | 
					
						
							| 
									
										
										
										
											2011-06-07 18:34:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (seq->flag & SEQ_INVALID_EFFECT) { col[0] = 255; col[1] = 0; col[2] = 255; } | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (seq->flag & SELECT) UI_GetColorPtrBlendShade3ubv(col, col, col, 0.0, 5); | 
					
						
							| 
									
										
										
										
											2011-09-11 04:31:09 +00:00
										 |  |  | 	else UI_GetColorPtrShade3ubv(col, col, -5); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	glColor3ubv((GLubyte *)col); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	glVertex2f(x2, ymid1); | 
					
						
							|  |  |  | 	glVertex2f(x1, ymid1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glRectf(x1,  ymid1,  x2,  ymid2); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	glBegin(GL_QUADS); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	glVertex2f(x1, ymid2); | 
					
						
							|  |  |  | 	glVertex2f(x2, ymid2); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (seq->flag & SELECT) UI_GetColorPtrShade3ubv(col, col, -15); | 
					
						
							| 
									
										
										
										
											2011-09-11 04:31:09 +00:00
										 |  |  | 	else UI_GetColorPtrShade3ubv(col, col, 25); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	glColor3ubv((GLubyte *)col); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	glVertex2f(x2, y2); | 
					
						
							|  |  |  | 	glVertex2f(x1, y2); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (seq->flag & SEQ_MUTE) { | 
					
						
							| 
									
										
										
										
											2015-12-25 22:57:50 +01:00
										 |  |  | 		GPU_basic_shader_bind(GPU_SHADER_USE_COLOR); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-24 21:11:05 +01:00
										 |  |  | void draw_sequence_extensions(Scene *scene, ARegion *ar, Sequence *seq) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	float x1, x2, y1, y2, pixely, a; | 
					
						
							|  |  |  | 	unsigned char col[3], blendcol[3]; | 
					
						
							|  |  |  | 	View2D *v2d = &ar->v2d; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	x1 = seq->startdisp; | 
					
						
							|  |  |  | 	x2 = seq->enddisp; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	y1 = seq->machine + SEQ_STRIP_OFSBOTTOM; | 
					
						
							|  |  |  | 	y2 = seq->machine + SEQ_STRIP_OFSTOP; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	pixely = BLI_rctf_size_y(&v2d->cur) / BLI_rcti_size_y(&v2d->mask); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (pixely <= 0) return;  /* can happen when the view is split/resized */ | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	blendcol[0] = blendcol[1] = blendcol[2] = 120; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (seq->startofs) { | 
					
						
							|  |  |  | 		glEnable(GL_BLEND); | 
					
						
							|  |  |  | 		glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		color3ubv_from_seq(scene, seq, col); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if (seq->flag & SELECT) { | 
					
						
							|  |  |  | 			UI_GetColorPtrBlendShade3ubv(col, blendcol, col, 0.3, -40); | 
					
						
							|  |  |  | 			glColor4ub(col[0], col[1], col[2], 170); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			UI_GetColorPtrBlendShade3ubv(col, blendcol, col, 0.6, 0); | 
					
						
							|  |  |  | 			glColor4ub(col[0], col[1], col[2], 110); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glRectf((float)(seq->start), y1 - SEQ_STRIP_OFSBOTTOM, x1, y1); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if (seq->flag & SELECT) glColor4ub(col[0], col[1], col[2], 255); | 
					
						
							|  |  |  | 		else glColor4ub(col[0], col[1], col[2], 160); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		fdrawbox((float)(seq->start), y1 - SEQ_STRIP_OFSBOTTOM, x1, y1);  //outline
 | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glDisable(GL_BLEND); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (seq->endofs) { | 
					
						
							|  |  |  | 		glEnable(GL_BLEND); | 
					
						
							|  |  |  | 		glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		color3ubv_from_seq(scene, seq, col); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if (seq->flag & SELECT) { | 
					
						
							|  |  |  | 			UI_GetColorPtrBlendShade3ubv(col, blendcol, col, 0.3, -40); | 
					
						
							|  |  |  | 			glColor4ub(col[0], col[1], col[2], 170); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			UI_GetColorPtrBlendShade3ubv(col, blendcol, col, 0.6, 0); | 
					
						
							|  |  |  | 			glColor4ub(col[0], col[1], col[2], 110); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glRectf(x2, y2, (float)(seq->start + seq->len), y2 + SEQ_STRIP_OFSBOTTOM); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if (seq->flag & SELECT) glColor4ub(col[0], col[1], col[2], 255); | 
					
						
							|  |  |  | 		else glColor4ub(col[0], col[1], col[2], 160); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		fdrawbox(x2, y2, (float)(seq->start + seq->len), y2 + SEQ_STRIP_OFSBOTTOM); //outline
 | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glDisable(GL_BLEND); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (seq->startstill) { | 
					
						
							|  |  |  | 		color3ubv_from_seq(scene, seq, col); | 
					
						
							|  |  |  | 		UI_GetColorPtrBlendShade3ubv(col, blendcol, col, 0.75, 40); | 
					
						
							|  |  |  | 		glColor3ubv((GLubyte *)col); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		draw_shadedstrip(seq, col, x1, y1, (float)(seq->start), y2); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* feint pinstripes, helps see exactly which is extended and which isn't,
 | 
					
						
							| 
									
										
										
										
											2014-12-09 21:42:25 +01:00
										 |  |  | 		 * especially when the extension is very small */ | 
					
						
							| 
									
										
										
										
											2014-11-24 21:11:05 +01:00
										 |  |  | 		if (seq->flag & SELECT) UI_GetColorPtrBlendShade3ubv(col, col, col, 0.0, 24); | 
					
						
							|  |  |  | 		else UI_GetColorPtrShade3ubv(col, col, -16); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glColor3ubv((GLubyte *)col); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		for (a = y1; a < y2; a += pixely * 2.0f) { | 
					
						
							|  |  |  | 			fdrawline(x1,  a,  (float)(seq->start),  a); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (seq->endstill) { | 
					
						
							|  |  |  | 		color3ubv_from_seq(scene, seq, col); | 
					
						
							|  |  |  | 		UI_GetColorPtrBlendShade3ubv(col, blendcol, col, 0.75, 40); | 
					
						
							|  |  |  | 		glColor3ubv((GLubyte *)col); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		draw_shadedstrip(seq, col, (float)(seq->start + seq->len), y1, x2, y2); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* feint pinstripes, helps see exactly which is extended and which isn't,
 | 
					
						
							| 
									
										
										
										
											2014-12-09 21:42:25 +01:00
										 |  |  | 		 * especially when the extension is very small */ | 
					
						
							| 
									
										
										
										
											2014-11-24 21:11:05 +01:00
										 |  |  | 		if (seq->flag & SELECT) UI_GetColorPtrShade3ubv(col, col, 24); | 
					
						
							|  |  |  | 		else UI_GetColorPtrShade3ubv(col, col, -16); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		glColor3ubv((GLubyte *)col); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		for (a = y1; a < y2; a += pixely * 2.0f) { | 
					
						
							|  |  |  | 			fdrawline((float)(seq->start + seq->len),  a,  x2,  a); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2012-03-03 16:31:46 +00:00
										 |  |  |  * Draw a sequence strip, bounds check already made | 
					
						
							|  |  |  |  * ARegion is currently only used to get the windows width in pixels | 
					
						
							|  |  |  |  * so wave file sample drawing precision is zoom adjusted | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | static void draw_seq_strip(const bContext *C, SpaceSeq *sseq, Scene *scene, ARegion *ar, Sequence *seq, int outline_tint, float pixelx) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	View2D *v2d = &ar->v2d; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	float x1, x2, y1, y2; | 
					
						
							| 
									
										
										
										
											2010-12-20 03:59:22 +00:00
										 |  |  | 	unsigned char col[3], background_col[3], is_single_image; | 
					
						
							| 
									
										
										
										
											2012-06-20 17:10:40 +00:00
										 |  |  | 	const float handsize_clamped = draw_seq_handle_size_get_clamped(seq, pixelx); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* we need to know if this is a single image/color or not for drawing */ | 
					
						
							| 
									
										
										
										
											2012-08-08 11:15:40 +00:00
										 |  |  | 	is_single_image = (char)BKE_sequence_single_check(seq); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* body */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	x1 = (seq->startstill) ? seq->start : seq->startdisp; | 
					
						
							|  |  |  | 	y1 = seq->machine + SEQ_STRIP_OFSBOTTOM; | 
					
						
							|  |  |  | 	x2 = (seq->endstill) ? (seq->start + seq->len) : seq->enddisp; | 
					
						
							|  |  |  | 	y2 = seq->machine + SEQ_STRIP_OFSTOP; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	/* get the correct color per strip type*/ | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 	//color3ubv_from_seq(scene, seq, col);
 | 
					
						
							|  |  |  | 	color3ubv_from_seq(scene, seq, background_col); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* draw the main strip body */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (is_single_image) {  /* single image */ | 
					
						
							| 
									
										
										
										
											2012-08-13 17:36:29 +00:00
										 |  |  | 		draw_shadedstrip(seq, background_col, | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 		                 BKE_sequence_tx_get_final_left(seq, false), y1, | 
					
						
							|  |  |  | 		                 BKE_sequence_tx_get_final_right(seq, false), y2); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else {  /* normal operation */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		draw_shadedstrip(seq, background_col, x1, y1, x2, y2); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-01-06 23:09:56 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (!is_single_image) { | 
					
						
							|  |  |  | 		if ((sseq->draw_flag & SEQ_DRAW_OFFSET_EXT) || (seq == special_seq_update)) { | 
					
						
							|  |  |  | 			draw_sequence_extensions(scene, ar, seq); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2014-12-09 21:42:25 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-20 17:10:40 +00:00
										 |  |  | 	draw_seq_handle(v2d, seq, handsize_clamped, SEQ_LEFTHANDLE); | 
					
						
							|  |  |  | 	draw_seq_handle(v2d, seq, handsize_clamped, SEQ_RIGHTHANDLE); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* draw the strip outline */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	x1 = seq->startdisp; | 
					
						
							|  |  |  | 	x2 = seq->enddisp; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 	/* draw sound wave */ | 
					
						
							| 
									
										
										
										
											2012-06-07 15:49:02 +00:00
										 |  |  | 	if (seq->type == SEQ_TYPE_SOUND_RAM) { | 
					
						
							| 
									
										
										
										
											2014-11-26 10:44:06 +01:00
										 |  |  | 		if (!(sseq->flag & SEQ_NO_WAVEFORMS)) { | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 			drawseqwave(C, sseq, scene, seq, x1, y1, x2, y2, BLI_rctf_size_x(&ar->v2d.cur) / ar->winx); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-02-07 23:41:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-03 09:28:16 +00:00
										 |  |  | 	/* draw lock */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (seq->flag & SEQ_LOCK) { | 
					
						
							| 
									
										
										
										
											2015-12-25 22:57:50 +01:00
										 |  |  | 		GPU_basic_shader_bind(GPU_SHADER_STIPPLE | GPU_SHADER_USE_COLOR); | 
					
						
							| 
									
										
										
										
											2011-08-03 09:28:16 +00:00
										 |  |  | 		glEnable(GL_BLEND); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* light stripes */ | 
					
						
							|  |  |  | 		glColor4ub(255, 255, 255, 32); | 
					
						
							| 
									
										
										
										
											2015-12-25 22:57:50 +01:00
										 |  |  | 		GPU_basic_shader_stipple(GPU_SHADER_STIPPLE_DIAG_STRIPES); | 
					
						
							| 
									
										
										
										
											2011-08-03 09:28:16 +00:00
										 |  |  | 		glRectf(x1, y1, x2, y2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* dark stripes */ | 
					
						
							|  |  |  | 		glColor4ub(0, 0, 0, 32); | 
					
						
							| 
									
										
										
										
											2015-12-25 22:57:50 +01:00
										 |  |  | 		GPU_basic_shader_stipple(GPU_SHADER_STIPPLE_DIAG_STRIPES_SWAP); | 
					
						
							| 
									
										
										
										
											2011-08-03 09:28:16 +00:00
										 |  |  | 		glRectf(x1, y1, x2, y2); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-25 22:57:50 +01:00
										 |  |  | 		GPU_basic_shader_bind(GPU_SHADER_USE_COLOR); | 
					
						
							| 
									
										
										
										
											2011-08-03 09:28:16 +00:00
										 |  |  | 		glDisable(GL_BLEND); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-04 18:30:28 +00:00
										 |  |  | 	if (!BKE_sequence_is_valid_check(seq)) { | 
					
						
							| 
									
										
										
										
											2015-12-25 22:57:50 +01:00
										 |  |  | 		GPU_basic_shader_bind(GPU_SHADER_STIPPLE | GPU_SHADER_USE_COLOR); | 
					
						
							| 
									
										
										
										
											2012-08-13 17:36:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* panic! */ | 
					
						
							|  |  |  | 		glColor4ub(255, 0, 0, 255); | 
					
						
							| 
									
										
										
										
											2015-12-25 22:57:50 +01:00
										 |  |  | 		GPU_basic_shader_stipple(GPU_SHADER_STIPPLE_DIAG_STRIPES); | 
					
						
							| 
									
										
										
										
											2012-08-13 17:36:29 +00:00
										 |  |  | 		glRectf(x1, y1, x2, y2); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-25 22:57:50 +01:00
										 |  |  | 		GPU_basic_shader_bind(GPU_SHADER_USE_COLOR); | 
					
						
							| 
									
										
										
										
											2012-08-13 17:36:29 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 	color3ubv_from_seq(scene, seq, col); | 
					
						
							| 
									
										
										
										
											2013-06-24 22:41:37 +00:00
										 |  |  | 	if ((G.moving & G_TRANSFORM_SEQ) && (seq->flag & SELECT)) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (seq->flag & SEQ_OVERLAP) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			col[0] = 255; col[1] = col[2] = 40; | 
					
						
							| 
									
										
										
										
											2011-07-06 13:15:22 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			UI_GetColorPtrShade3ubv(col, col, 120 + outline_tint); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-07-06 13:15:22 +00:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2011-09-11 04:31:09 +00:00
										 |  |  | 		UI_GetColorPtrShade3ubv(col, col, outline_tint); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	glColor3ubv((GLubyte *)col); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (seq->flag & SEQ_MUTE) { | 
					
						
							|  |  |  | 		glEnable(GL_LINE_STIPPLE); | 
					
						
							|  |  |  | 		glLineStipple(1, 0x8888); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2014-11-09 21:20:40 +01:00
										 |  |  | 	UI_draw_roundbox_shade_x(GL_LINE_LOOP, x1, y1, x2, y2, 0.0, 0.1, 0.0); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	if (seq->flag & SEQ_MUTE) { | 
					
						
							|  |  |  | 		glDisable(GL_LINE_STIPPLE); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2014-12-10 15:26:41 +01:00
										 |  |  | 	if ((seq->type == SEQ_TYPE_META) || | 
					
						
							|  |  |  | 	    ((seq->type == SEQ_TYPE_SCENE) && (seq->flag & SEQ_SCENE_STRIPS))) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		drawmeta_contents(scene, seq, x1, y1, x2, y2); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-04 01:56:04 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	/* calculate if seq is long enough to print a name */ | 
					
						
							| 
									
										
										
										
											2012-06-20 17:10:40 +00:00
										 |  |  | 	x1 = seq->startdisp + handsize_clamped; | 
					
						
							|  |  |  | 	x2 = seq->enddisp   - handsize_clamped; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* info text on the strip */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if (x1 < v2d->cur.xmin) x1 = v2d->cur.xmin; | 
					
						
							|  |  |  | 	else if (x1 > v2d->cur.xmax) x1 = v2d->cur.xmax; | 
					
						
							|  |  |  | 	if (x2 < v2d->cur.xmin) x2 = v2d->cur.xmin; | 
					
						
							|  |  |  | 	else if (x2 > v2d->cur.xmax) x2 = v2d->cur.xmax; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* nice text here would require changing the view matrix for texture text */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if ((x2 - x1) / pixelx > 32) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		draw_seq_text(v2d, seq, x1, x2, y1, y2, background_col); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-05 02:12:50 +11:00
										 |  |  | void sequencer_special_update_set(Sequence *seq) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2015-01-05 02:12:50 +11:00
										 |  |  | 	special_seq_update = seq; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-05 02:12:50 +11:00
										 |  |  | Sequence *ED_sequencer_special_preview_get(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return special_seq_update; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ED_sequencer_special_preview_set(bContext *C, const int mval[2]) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Scene *scene = CTX_data_scene(C); | 
					
						
							|  |  |  | 	ARegion *ar = CTX_wm_region(C); | 
					
						
							|  |  |  | 	int hand; | 
					
						
							|  |  |  | 	Sequence *seq; | 
					
						
							|  |  |  | 	seq = find_nearest_seq(scene, &ar->v2d, &hand, mval); | 
					
						
							|  |  |  | 	sequencer_special_update_set(seq); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ED_sequencer_special_preview_clear(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	sequencer_special_update_set(NULL); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | ImBuf *sequencer_ibuf_get(struct Main *bmain, Scene *scene, SpaceSeq *sseq, int cfra, int frame_ofs, const char *viewname) | 
					
						
							| 
									
										
										
										
											2012-08-23 16:14:52 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	SeqRenderData context; | 
					
						
							|  |  |  | 	ImBuf *ibuf; | 
					
						
							|  |  |  | 	int rectx, recty; | 
					
						
							| 
									
										
										
										
											2013-06-02 02:25:40 +00:00
										 |  |  | 	float render_size; | 
					
						
							| 
									
										
										
										
											2012-08-23 16:14:52 +00:00
										 |  |  | 	float proxy_size = 100.0; | 
					
						
							| 
									
										
										
										
											2012-11-21 09:36:36 +00:00
										 |  |  | 	short is_break = G.is_break; | 
					
						
							| 
									
										
										
										
											2012-08-23 16:14:52 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	render_size = sseq->render_size; | 
					
						
							|  |  |  | 	if (render_size == 0) { | 
					
						
							|  |  |  | 		render_size = scene->r.size; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		proxy_size = render_size; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (render_size < 0) { | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	rectx = (render_size * (float)scene->r.xsch) / 100.0f + 0.5f; | 
					
						
							|  |  |  | 	recty = (render_size * (float)scene->r.ysch) / 100.0f + 0.5f; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-04 22:46:54 +11:00
										 |  |  | 	BKE_sequencer_new_render_data( | 
					
						
							|  |  |  | 	        bmain->eval_ctx, bmain, scene, | 
					
						
							|  |  |  | 	        rectx, recty, proxy_size, | 
					
						
							|  |  |  | 	        &context); | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | 	context.view_id = BKE_scene_multiview_view_id_get(&scene->r, viewname); | 
					
						
							| 
									
										
										
										
											2012-08-23 16:14:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-21 09:36:36 +00:00
										 |  |  | 	/* sequencer could start rendering, in this case we need to be sure it wouldn't be canceled
 | 
					
						
							|  |  |  | 	 * by Esc pressed somewhere in the past | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 	G.is_break = false; | 
					
						
							| 
									
										
										
										
											2012-11-21 09:36:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-23 16:14:52 +00:00
										 |  |  | 	if (special_seq_update) | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		ibuf = BKE_sequencer_give_ibuf_direct(&context, cfra + frame_ofs, special_seq_update); | 
					
						
							| 
									
										
										
										
											2012-08-23 16:14:52 +00:00
										 |  |  | 	else if (!U.prefetchframes) // XXX || (G.f & G_PLAYANIM) == 0) { | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		ibuf = BKE_sequencer_give_ibuf(&context, cfra + frame_ofs, sseq->chanshown); | 
					
						
							| 
									
										
										
										
											2012-08-23 16:14:52 +00:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2014-01-19 00:16:19 +06:00
										 |  |  | 		ibuf = BKE_sequencer_give_ibuf_threaded(&context, cfra + frame_ofs, sseq->chanshown); | 
					
						
							| 
									
										
										
										
											2012-08-23 16:14:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-21 09:36:36 +00:00
										 |  |  | 	/* restore state so real rendering would be canceled (if needed) */ | 
					
						
							|  |  |  | 	G.is_break = is_break; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-23 16:14:52 +00:00
										 |  |  | 	return ibuf; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | static void sequencer_check_scopes(SequencerScopes *scopes, ImBuf *ibuf) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (scopes->reference_ibuf != ibuf) { | 
					
						
							|  |  |  | 		if (scopes->zebra_ibuf) { | 
					
						
							|  |  |  | 			IMB_freeImBuf(scopes->zebra_ibuf); | 
					
						
							|  |  |  | 			scopes->zebra_ibuf = NULL; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (scopes->waveform_ibuf) { | 
					
						
							|  |  |  | 			IMB_freeImBuf(scopes->waveform_ibuf); | 
					
						
							|  |  |  | 			scopes->waveform_ibuf = NULL; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (scopes->sep_waveform_ibuf) { | 
					
						
							|  |  |  | 			IMB_freeImBuf(scopes->sep_waveform_ibuf); | 
					
						
							|  |  |  | 			scopes->sep_waveform_ibuf = NULL; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (scopes->vector_ibuf) { | 
					
						
							|  |  |  | 			IMB_freeImBuf(scopes->vector_ibuf); | 
					
						
							|  |  |  | 			scopes->vector_ibuf = NULL; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (scopes->histogram_ibuf) { | 
					
						
							|  |  |  | 			IMB_freeImBuf(scopes->histogram_ibuf); | 
					
						
							|  |  |  | 			scopes->histogram_ibuf = NULL; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static ImBuf *sequencer_make_scope(Scene *scene, ImBuf *ibuf, ImBuf *(*make_scope_cb) (ImBuf *ibuf)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ImBuf *display_ibuf = IMB_dupImBuf(ibuf); | 
					
						
							|  |  |  | 	ImBuf *scope; | 
					
						
							| 
									
										
										
										
											2013-04-02 17:12:21 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2013-04-02 12:41:11 +00:00
										 |  |  | 	IMB_colormanagement_imbuf_make_display_space(display_ibuf, &scene->view_settings, | 
					
						
							| 
									
										
										
										
											2012-09-24 11:56:07 +00:00
										 |  |  | 		                                             &scene->display_settings); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 
 | 
					
						
							|  |  |  | 	scope = make_scope_cb(display_ibuf); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	IMB_freeImBuf(display_ibuf); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return scope; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-16 13:19:22 +11:00
										 |  |  | static void sequencer_display_size(Scene *scene, SpaceSeq *sseq, float r_viewrect[2]) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	float render_size, proxy_size; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (sseq->render_size == SEQ_PROXY_RENDER_SIZE_SCENE) { | 
					
						
							|  |  |  | 		render_size = (float)scene->r.size / 100.0f; | 
					
						
							|  |  |  | 		proxy_size = 1.0f; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		render_size = (float)sseq->render_size / 100.0f; | 
					
						
							|  |  |  | 		proxy_size = render_size; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	r_viewrect[0] = (render_size * (float)scene->r.xsch); | 
					
						
							|  |  |  | 	r_viewrect[1] = (render_size * (float)scene->r.ysch); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* rectx = viewrectx + 0.5f; */ /* UNUSED */ | 
					
						
							|  |  |  | 	/* recty = viewrecty + 0.5f; */ /* UNUSED */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (sseq->mainb == SEQ_DRAW_IMG_IMBUF) { | 
					
						
							|  |  |  | 		r_viewrect[0] *= scene->r.xasp / scene->r.yasp; | 
					
						
							|  |  |  | 		r_viewrect[0] /= proxy_size; | 
					
						
							|  |  |  | 		r_viewrect[1] /= proxy_size; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | static void sequencer_draw_gpencil(const bContext *C) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* draw grease-pencil (image aligned) */ | 
					
						
							|  |  |  | 	ED_gpencil_draw_2dimage(C); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* ortho at pixel level */ | 
					
						
							|  |  |  | 	UI_view2d_view_restore(C); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* draw grease-pencil (screen aligned) */ | 
					
						
							|  |  |  | 	ED_gpencil_draw_view2d(C, 0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* draws content borders plus safety borders if needed */ | 
					
						
							|  |  |  | static void sequencer_draw_borders(const SpaceSeq *sseq, const View2D *v2d, const Scene *scene) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	float x1 = v2d->tot.xmin; | 
					
						
							|  |  |  | 	float y1 = v2d->tot.ymin; | 
					
						
							|  |  |  | 	float x2 = v2d->tot.xmax; | 
					
						
							|  |  |  | 	float y2 = v2d->tot.ymax; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-16 23:23:40 +11:00
										 |  |  | 	glLineWidth(1.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | 	/* border */ | 
					
						
							|  |  |  | 	setlinestyle(3); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	UI_ThemeColorBlendShade(TH_WIRE, TH_BACK, 1.0, 0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_LINE_LOOP); | 
					
						
							|  |  |  | 	glVertex2f(x1 - 0.5f, y1 - 0.5f); | 
					
						
							|  |  |  | 	glVertex2f(x1 - 0.5f, y2 + 0.5f); | 
					
						
							|  |  |  | 	glVertex2f(x2 + 0.5f, y2 + 0.5f); | 
					
						
							|  |  |  | 	glVertex2f(x2 + 0.5f, y1 - 0.5f); | 
					
						
							|  |  |  | 	glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* safety border */ | 
					
						
							|  |  |  | 	if (sseq->flag & SEQ_SHOW_SAFE_MARGINS) { | 
					
						
							|  |  |  | 		UI_draw_safe_areas( | 
					
						
							|  |  |  | 		        x1, x2, y1, y2, | 
					
						
							|  |  |  | 		        scene->safe_areas.title, | 
					
						
							|  |  |  | 		        scene->safe_areas.action); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (sseq->flag & SEQ_SHOW_SAFE_CENTER) { | 
					
						
							|  |  |  | 			UI_draw_safe_areas( | 
					
						
							|  |  |  | 			        x1, x2, y1, y2, | 
					
						
							|  |  |  | 			        scene->safe_areas.title_center, | 
					
						
							|  |  |  | 			        scene->safe_areas.action_center); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	setlinestyle(0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* draws checkerboard background for transparent content */ | 
					
						
							| 
									
										
										
										
											2016-01-25 11:41:13 +11:00
										 |  |  | static void sequencer_draw_background( | 
					
						
							|  |  |  |         const SpaceSeq *sseq, View2D *v2d, const float viewrect[2], const bool draw_overlay) | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* setting up the view */ | 
					
						
							|  |  |  | 	UI_view2d_totRect_set(v2d, viewrect[0] + 0.5f, viewrect[1] + 0.5f); | 
					
						
							|  |  |  | 	UI_view2d_curRect_validate(v2d); | 
					
						
							|  |  |  | 	UI_view2d_view_ortho(v2d); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* only draw alpha for main buffer */ | 
					
						
							|  |  |  | 	if (sseq->mainb == SEQ_DRAW_IMG_IMBUF) { | 
					
						
							| 
									
										
										
										
											2016-01-25 11:41:13 +11:00
										 |  |  | 		if ((sseq->flag & SEQ_USE_ALPHA) && !draw_overlay) { | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | 			glEnable(GL_BLEND); | 
					
						
							|  |  |  | 			glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			fdrawcheckerboard(v2d->tot.xmin, v2d->tot.ymin, v2d->tot.xmax, v2d->tot.ymax); | 
					
						
							|  |  |  | 			glColor4f(1.0, 1.0, 1.0, 1.0); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | void draw_image_seq(const bContext *C, Scene *scene, ARegion *ar, SpaceSeq *sseq, int cfra, int frame_ofs, bool draw_overlay, bool draw_backdrop) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	struct Main *bmain = CTX_data_main(C); | 
					
						
							|  |  |  | 	struct ImBuf *ibuf = NULL; | 
					
						
							|  |  |  | 	struct ImBuf *scope = NULL; | 
					
						
							| 
									
										
										
										
											2010-02-07 19:07:56 +00:00
										 |  |  | 	struct View2D *v2d = &ar->v2d; | 
					
						
							| 
									
										
										
										
											2012-09-06 04:45:25 +00:00
										 |  |  | 	/* int rectx, recty; */ /* UNUSED */ | 
					
						
							| 
									
										
										
										
											2015-02-16 13:19:22 +11:00
										 |  |  | 	float viewrect[2]; | 
					
						
							| 
									
										
										
										
											2012-03-23 20:50:38 +00:00
										 |  |  | 	float col[3]; | 
					
						
							| 
									
										
										
										
											2010-02-07 19:07:56 +00:00
										 |  |  | 	GLuint texid; | 
					
						
							| 
									
										
										
										
											2013-04-04 12:20:13 +00:00
										 |  |  | 	void *display_buffer; | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	void *cache_handle = NULL; | 
					
						
							| 
									
										
										
										
											2014-04-11 11:25:41 +10:00
										 |  |  | 	const bool is_imbuf = ED_space_sequencer_check_show_imbuf(sseq); | 
					
						
							| 
									
										
										
										
											2013-04-04 12:20:13 +00:00
										 |  |  | 	int format, type; | 
					
						
							|  |  |  | 	bool glsl_used = false; | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | 	const bool draw_gpencil = ((sseq->flag & SEQ_SHOW_GPENCIL) && sseq->gpd); | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | 	const char *names[2] = {STEREO_LEFT_NAME, STEREO_RIGHT_NAME}; | 
					
						
							| 
									
										
										
										
											2015-05-04 12:17:49 +02:00
										 |  |  | 	bool draw_metadata = false; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 	if (G.is_rendering == false && (scene->r.seq_flag & R_SEQ_GL_PREV) == 0) { | 
					
						
							| 
									
										
										
										
											2012-11-09 16:49:17 +00:00
										 |  |  | 		/* stop all running jobs, except screen one. currently previews frustrate Render
 | 
					
						
							|  |  |  | 		 * needed to make so sequencer's rendering doesn't conflict with compositor | 
					
						
							|  |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2013-09-23 19:35:21 +00:00
										 |  |  | 		WM_jobs_kill_type(CTX_wm_manager(C), NULL, WM_JOB_TYPE_COMPOSITE); | 
					
						
							| 
									
										
										
										
											2013-01-07 14:25:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if ((scene->r.seq_flag & R_SEQ_GL_PREV) == 0) { | 
					
						
							|  |  |  | 			/* in case of final rendering used for preview, kill all previews,
 | 
					
						
							|  |  |  | 			 * otherwise threading conflict will happen in rendering module | 
					
						
							|  |  |  | 			 */ | 
					
						
							| 
									
										
										
										
											2013-09-23 19:35:21 +00:00
										 |  |  | 			WM_jobs_kill_type(CTX_wm_manager(C), NULL, WM_JOB_TYPE_RENDER_PREVIEW); | 
					
						
							| 
									
										
										
										
											2013-01-07 14:25:29 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-11-09 16:49:17 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-16 12:57:29 +11:00
										 |  |  | 	if ((!draw_overlay || sseq->overlay_type == SEQ_DRAW_OVERLAY_REFERENCE) && !draw_backdrop) { | 
					
						
							|  |  |  | 		UI_GetThemeColor3fv(TH_SEQ_PREVIEW, col); | 
					
						
							|  |  |  | 		glClearColor(col[0], col[1], col[2], 0.0); | 
					
						
							|  |  |  | 		glClear(GL_COLOR_BUFFER_BIT); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | 	/* without this colors can flicker from previous opengl state */ | 
					
						
							|  |  |  | 	glColor4ub(255, 255, 255, 255); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-16 12:57:29 +11:00
										 |  |  | 	/* only initialize the preview if a render is in progress */ | 
					
						
							|  |  |  | 	if (G.is_rendering) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (sseq->render_size == SEQ_PROXY_RENDER_SIZE_NONE) { | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | 	/* for now we only support Left/Right */ | 
					
						
							|  |  |  | 	ibuf = sequencer_ibuf_get(bmain, scene, sseq, cfra, frame_ofs, names[sseq->multiview_eye]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | 	if ((ibuf == NULL) || | 
					
						
							|  |  |  | 	    (ibuf->rect == NULL && ibuf->rect_float == NULL)) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-06-12 19:38:46 +02:00
										 |  |  | 		/* gpencil can also be drawn without a valid imbuf */ | 
					
						
							| 
									
										
										
										
											2016-01-25 11:41:13 +11:00
										 |  |  | 		if ((draw_gpencil && is_imbuf) && !draw_overlay) { | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | 			sequencer_display_size(scene, sseq, viewrect); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-25 11:41:13 +11:00
										 |  |  | 			sequencer_draw_background(sseq, v2d, viewrect, false); | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | 			sequencer_draw_borders(sseq, v2d, scene); | 
					
						
							| 
									
										
										
										
											2015-02-16 12:57:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | 			sequencer_draw_gpencil(C); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2015-02-16 12:57:29 +11:00
										 |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-02-16 12:57:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-16 13:19:22 +11:00
										 |  |  | 	sequencer_display_size(scene, sseq, viewrect); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-21 12:13:02 +02:00
										 |  |  | 	if (!draw_backdrop && (sseq->mainb != SEQ_DRAW_IMG_IMBUF || sseq->zebra != 0)) { | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		SequencerScopes *scopes = &sseq->scopes; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		sequencer_check_scopes(scopes, ibuf); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		switch (sseq->mainb) { | 
					
						
							|  |  |  | 			case SEQ_DRAW_IMG_IMBUF: | 
					
						
							|  |  |  | 				if (!scopes->zebra_ibuf) { | 
					
						
							|  |  |  | 					ImBuf *display_ibuf = IMB_dupImBuf(ibuf); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-24 11:56:07 +00:00
										 |  |  | 					if (display_ibuf->rect_float) { | 
					
						
							|  |  |  | 						IMB_colormanagement_imbuf_make_display_space(display_ibuf, &scene->view_settings, | 
					
						
							|  |  |  | 						                                             &scene->display_settings); | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 					scopes->zebra_ibuf = make_zebra_view_from_ibuf(display_ibuf, sseq->zebra); | 
					
						
							|  |  |  | 					IMB_freeImBuf(display_ibuf); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				scope = scopes->zebra_ibuf; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case SEQ_DRAW_IMG_WAVEFORM: | 
					
						
							|  |  |  | 				if ((sseq->flag & SEQ_DRAW_COLOR_SEPARATED) != 0) { | 
					
						
							|  |  |  | 					if (!scopes->sep_waveform_ibuf) | 
					
						
							|  |  |  | 						scopes->sep_waveform_ibuf = sequencer_make_scope(scene, ibuf, make_sep_waveform_view_from_ibuf); | 
					
						
							|  |  |  | 					scope = scopes->sep_waveform_ibuf; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							|  |  |  | 					if (!scopes->waveform_ibuf) | 
					
						
							|  |  |  | 						scopes->waveform_ibuf = sequencer_make_scope(scene, ibuf, make_waveform_view_from_ibuf); | 
					
						
							|  |  |  | 					scope = scopes->waveform_ibuf; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case SEQ_DRAW_IMG_VECTORSCOPE: | 
					
						
							|  |  |  | 				if (!scopes->vector_ibuf) | 
					
						
							|  |  |  | 					scopes->vector_ibuf = sequencer_make_scope(scene, ibuf, make_vectorscope_view_from_ibuf); | 
					
						
							|  |  |  | 				scope = scopes->vector_ibuf; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case SEQ_DRAW_IMG_HISTOGRAM: | 
					
						
							|  |  |  | 				if (!scopes->histogram_ibuf) | 
					
						
							|  |  |  | 					scopes->histogram_ibuf = sequencer_make_scope(scene, ibuf, make_histogram_view_from_ibuf); | 
					
						
							|  |  |  | 				scope = scopes->histogram_ibuf; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-08 15:40:55 +11:00
										 |  |  | 		/* future files may have new scopes we don't catch above */ | 
					
						
							|  |  |  | 		if (scope) { | 
					
						
							|  |  |  | 			scopes->reference_ibuf = ibuf; | 
					
						
							| 
									
										
										
										
											2015-03-25 22:15:56 +01:00
										 |  |  | 			if (sseq->mainb == SEQ_DRAW_IMG_IMBUF) { | 
					
						
							|  |  |  | 				/* scopes drawn in image preview use viewrect from orig ibuf - currently that's only zebra */ | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2015-03-25 21:52:54 +01:00
										 |  |  | 				viewrect[0] = scope->x; | 
					
						
							|  |  |  | 				viewrect[1] = scope->y; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2014-01-08 15:40:55 +11:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			scopes->reference_ibuf = NULL; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 	if (!draw_backdrop) { | 
					
						
							| 
									
										
										
										
											2016-01-25 11:41:13 +11:00
										 |  |  | 		sequencer_draw_background(sseq, v2d, viewrect, draw_overlay); | 
					
						
							| 
									
										
										
										
											2013-04-26 18:56:15 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-23 16:57:11 +00:00
										 |  |  | 	if (scope) { | 
					
						
							|  |  |  | 		IMB_freeImBuf(ibuf); | 
					
						
							|  |  |  | 		ibuf = scope; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		if (ibuf->rect_float && ibuf->rect == NULL) { | 
					
						
							|  |  |  | 			IMB_rect_from_float(ibuf); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		display_buffer = (unsigned char *)ibuf->rect; | 
					
						
							| 
									
										
										
										
											2013-04-04 12:20:13 +00:00
										 |  |  | 		format = GL_RGBA; | 
					
						
							|  |  |  | 		type = GL_UNSIGNED_BYTE; | 
					
						
							| 
									
										
										
										
											2010-01-09 00:16:35 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2013-04-27 15:01:17 +00:00
										 |  |  | 		bool force_fallback = false; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-29 15:50:12 +00:00
										 |  |  | 		force_fallback |= (U.image_draw_method != IMAGE_DRAW_METHOD_GLSL); | 
					
						
							| 
									
										
										
										
											2013-04-27 18:21:16 +00:00
										 |  |  | 		force_fallback |= (ibuf->dither != 0.0f); | 
					
						
							| 
									
										
										
										
											2013-04-27 15:01:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if (force_fallback) { | 
					
						
							|  |  |  | 			/* Fallback to CPU based color space conversion */ | 
					
						
							|  |  |  | 			glsl_used = false; | 
					
						
							| 
									
										
										
										
											2013-04-27 18:21:16 +00:00
										 |  |  | 			format = GL_RGBA; | 
					
						
							|  |  |  | 			type = GL_UNSIGNED_BYTE; | 
					
						
							|  |  |  | 			display_buffer = NULL; | 
					
						
							| 
									
										
										
										
											2013-04-27 15:01:17 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else if (ibuf->rect_float) { | 
					
						
							| 
									
										
										
										
											2013-04-04 12:20:13 +00:00
										 |  |  | 			display_buffer = ibuf->rect_float; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if (ibuf->channels == 4) { | 
					
						
							|  |  |  | 				format = GL_RGBA; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else if (ibuf->channels == 3) { | 
					
						
							|  |  |  | 				format = GL_RGB; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				BLI_assert(!"Incompatible number of channels for float buffer in sequencer"); | 
					
						
							|  |  |  | 				format = GL_RGBA; | 
					
						
							|  |  |  | 				display_buffer = NULL; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			type = GL_FLOAT; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if (ibuf->float_colorspace) { | 
					
						
							| 
									
										
										
										
											2013-12-13 12:36:45 +06:00
										 |  |  | 				glsl_used = IMB_colormanagement_setup_glsl_draw_from_space_ctx(C, ibuf->float_colorspace, ibuf->dither, true); | 
					
						
							| 
									
										
										
										
											2013-04-04 12:20:13 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2013-12-13 12:36:45 +06:00
										 |  |  | 				glsl_used = IMB_colormanagement_setup_glsl_draw_ctx(C, ibuf->dither, true); | 
					
						
							| 
									
										
										
										
											2013-04-04 12:20:13 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else if (ibuf->rect) { | 
					
						
							|  |  |  | 			display_buffer = ibuf->rect; | 
					
						
							|  |  |  | 			format = GL_RGBA; | 
					
						
							|  |  |  | 			type = GL_UNSIGNED_BYTE; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-13 12:36:45 +06:00
										 |  |  | 			glsl_used = IMB_colormanagement_setup_glsl_draw_from_space_ctx(C, ibuf->rect_colorspace, ibuf->dither, false); | 
					
						
							| 
									
										
										
										
											2013-04-04 12:20:13 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			format = GL_RGBA; | 
					
						
							|  |  |  | 			type = GL_UNSIGNED_BYTE; | 
					
						
							|  |  |  | 			display_buffer = NULL; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2013-04-27 15:01:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* there's a data to be displayed, but GLSL is not initialized
 | 
					
						
							|  |  |  | 		 * properly, in this case we fallback to CPU-based display transform | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		if ((ibuf->rect || ibuf->rect_float) && !glsl_used) { | 
					
						
							|  |  |  | 			display_buffer = IMB_display_buffer_acquire_ctx(C, ibuf, &cache_handle); | 
					
						
							|  |  |  | 			format = GL_RGBA; | 
					
						
							|  |  |  | 			type = GL_UNSIGNED_BYTE; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-26 18:56:15 +00:00
										 |  |  | 	glColor4f(1.0, 1.0, 1.0, 1.0); | 
					
						
							| 
									
										
										
										
											2013-04-01 09:15:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-05 22:11:31 +01:00
										 |  |  | 	GPU_basic_shader_bind(GPU_SHADER_TEXTURE_2D | GPU_SHADER_USE_COLOR); | 
					
						
							| 
									
										
										
										
											2010-02-07 19:07:56 +00:00
										 |  |  | 	glGenTextures(1, (GLuint *)&texid); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glBindTexture(GL_TEXTURE_2D, texid); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST); | 
					
						
							|  |  |  | 	glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-26 18:56:15 +00:00
										 |  |  | 	if (type == GL_FLOAT) | 
					
						
							|  |  |  | 		glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA16F_ARB, ibuf->x, ibuf->y, 0, format, type, display_buffer); | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA8, ibuf->x, ibuf->y, 0, format, type, display_buffer); | 
					
						
							| 
									
										
										
										
											2013-01-08 15:34:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 	if (draw_backdrop) { | 
					
						
							|  |  |  | 		glMatrixMode(GL_PROJECTION); | 
					
						
							|  |  |  | 		glPushMatrix(); | 
					
						
							|  |  |  | 		glLoadIdentity(); | 
					
						
							|  |  |  | 		glMatrixMode(GL_MODELVIEW); | 
					
						
							|  |  |  | 		glPushMatrix(); | 
					
						
							|  |  |  | 		glLoadIdentity(); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-08 10:03:29 +00:00
										 |  |  | 	glBegin(GL_QUADS); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-12 13:24:29 +00:00
										 |  |  | 	if (draw_overlay) { | 
					
						
							|  |  |  | 		if (sseq->overlay_type == SEQ_DRAW_OVERLAY_RECT) { | 
					
						
							|  |  |  | 			rctf tot_clip; | 
					
						
							| 
									
										
										
										
											2012-09-15 11:48:20 +00:00
										 |  |  | 			tot_clip.xmin = v2d->tot.xmin + (fabsf(BLI_rctf_size_x(&v2d->tot)) * scene->ed->over_border.xmin); | 
					
						
							|  |  |  | 			tot_clip.ymin = v2d->tot.ymin + (fabsf(BLI_rctf_size_y(&v2d->tot)) * scene->ed->over_border.ymin); | 
					
						
							|  |  |  | 			tot_clip.xmax = v2d->tot.xmin + (fabsf(BLI_rctf_size_x(&v2d->tot)) * scene->ed->over_border.xmax); | 
					
						
							|  |  |  | 			tot_clip.ymax = v2d->tot.ymin + (fabsf(BLI_rctf_size_y(&v2d->tot)) * scene->ed->over_border.ymax); | 
					
						
							| 
									
										
										
										
											2012-08-12 13:24:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			glTexCoord2f(scene->ed->over_border.xmin, scene->ed->over_border.ymin); glVertex2f(tot_clip.xmin, tot_clip.ymin); | 
					
						
							|  |  |  | 			glTexCoord2f(scene->ed->over_border.xmin, scene->ed->over_border.ymax); glVertex2f(tot_clip.xmin, tot_clip.ymax); | 
					
						
							|  |  |  | 			glTexCoord2f(scene->ed->over_border.xmax, scene->ed->over_border.ymax); glVertex2f(tot_clip.xmax, tot_clip.ymax); | 
					
						
							|  |  |  | 			glTexCoord2f(scene->ed->over_border.xmax, scene->ed->over_border.ymin); glVertex2f(tot_clip.xmax, tot_clip.ymin); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else if (sseq->overlay_type == SEQ_DRAW_OVERLAY_REFERENCE) { | 
					
						
							|  |  |  | 			glTexCoord2f(0.0f, 0.0f); glVertex2f(v2d->tot.xmin, v2d->tot.ymin); | 
					
						
							|  |  |  | 			glTexCoord2f(0.0f, 1.0f); glVertex2f(v2d->tot.xmin, v2d->tot.ymax); | 
					
						
							|  |  |  | 			glTexCoord2f(1.0f, 1.0f); glVertex2f(v2d->tot.xmax, v2d->tot.ymax); | 
					
						
							|  |  |  | 			glTexCoord2f(1.0f, 0.0f); glVertex2f(v2d->tot.xmax, v2d->tot.ymin); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-07-08 10:03:29 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 	else if (draw_backdrop) { | 
					
						
							| 
									
										
										
										
											2015-05-04 12:17:49 +02:00
										 |  |  | 		float aspect; | 
					
						
							| 
									
										
										
										
											2015-02-16 13:19:22 +11:00
										 |  |  | 		float image_aspect = viewrect[0] / viewrect[1]; | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 		float imagex, imagey; | 
					
						
							| 
									
										
										
										
											2015-05-04 12:17:49 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		aspect = BLI_rcti_size_x(&ar->winrct) / (float)BLI_rcti_size_y(&ar->winrct); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 		if (aspect >= image_aspect) { | 
					
						
							| 
									
										
										
										
											2014-11-26 10:44:06 +01:00
										 |  |  | 			imagex = image_aspect / aspect; | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 			imagey = 1.0f; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2014-11-26 10:44:06 +01:00
										 |  |  | 			imagex = 1.0f; | 
					
						
							|  |  |  | 			imagey = aspect / image_aspect; | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2015-05-04 12:17:49 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 		glTexCoord2f(0.0f, 0.0f); glVertex2f(-imagex, -imagey); | 
					
						
							|  |  |  | 		glTexCoord2f(0.0f, 1.0f); glVertex2f(-imagex, imagey); | 
					
						
							|  |  |  | 		glTexCoord2f(1.0f, 1.0f); glVertex2f(imagex, imagey); | 
					
						
							| 
									
										
										
										
											2014-11-26 10:44:06 +01:00
										 |  |  | 		glTexCoord2f(1.0f, 0.0f); glVertex2f(imagex, -imagey); | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-08 10:03:29 +00:00
										 |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2015-05-04 12:17:49 +02:00
										 |  |  | 		draw_metadata = ((sseq->flag & SEQ_SHOW_METADATA) != 0); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		glTexCoord2f(0.0f, 0.0f); glVertex2f(v2d->tot.xmin, v2d->tot.ymin); | 
					
						
							|  |  |  | 		glTexCoord2f(0.0f, 1.0f); glVertex2f(v2d->tot.xmin, v2d->tot.ymax); | 
					
						
							|  |  |  | 		glTexCoord2f(1.0f, 1.0f); glVertex2f(v2d->tot.xmax, v2d->tot.ymax); | 
					
						
							|  |  |  | 		glTexCoord2f(1.0f, 0.0f); glVertex2f(v2d->tot.xmax, v2d->tot.ymin); | 
					
						
							| 
									
										
										
										
											2010-07-08 10:03:29 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-04-29 17:11:40 +00:00
										 |  |  | 	glEnd(); | 
					
						
							| 
									
										
										
										
											2015-05-04 12:17:49 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-28 01:45:23 +01:00
										 |  |  | 	glBindTexture(GL_TEXTURE_2D, 0); | 
					
						
							| 
									
										
										
										
											2015-12-05 22:11:31 +01:00
										 |  |  | 	GPU_basic_shader_bind(GPU_SHADER_USE_COLOR); | 
					
						
							| 
									
										
										
										
											2013-04-01 09:15:37 +00:00
										 |  |  | 	if (sseq->mainb == SEQ_DRAW_IMG_IMBUF && sseq->flag & SEQ_USE_ALPHA) | 
					
						
							| 
									
										
										
										
											2013-02-27 10:26:58 +00:00
										 |  |  | 		glDisable(GL_BLEND); | 
					
						
							| 
									
										
										
										
											2010-02-07 19:07:56 +00:00
										 |  |  | 	glDeleteTextures(1, &texid); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-04 12:20:13 +00:00
										 |  |  | 	if (glsl_used) | 
					
						
							|  |  |  | 		IMB_colormanagement_finish_glsl_draw(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 	if (cache_handle) | 
					
						
							|  |  |  | 		IMB_display_buffer_release(cache_handle); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!scope) | 
					
						
							|  |  |  | 		IMB_freeImBuf(ibuf); | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-04 12:17:49 +02:00
										 |  |  | 	if (draw_metadata) { | 
					
						
							| 
									
										
										
										
											2015-10-05 20:46:53 +11:00
										 |  |  | 		ED_region_image_metadata_draw(0.0, 0.0, ibuf, &v2d->tot, 1.0, 1.0); | 
					
						
							| 
									
										
										
										
											2015-05-04 12:17:49 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 	if (draw_backdrop) { | 
					
						
							| 
									
										
										
										
											2015-05-04 12:17:49 +02:00
										 |  |  | 		glPopMatrix(); | 
					
						
							|  |  |  | 		glMatrixMode(GL_PROJECTION); | 
					
						
							|  |  |  | 		glPopMatrix(); | 
					
						
							|  |  |  | 		glMatrixMode(GL_MODELVIEW); | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-07-16 23:17:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | 	if (sseq->mainb == SEQ_DRAW_IMG_IMBUF) { | 
					
						
							|  |  |  | 		sequencer_draw_borders(sseq, v2d, scene); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (draw_gpencil && is_imbuf) { | 
					
						
							|  |  |  | 		sequencer_draw_gpencil(C); | 
					
						
							| 
									
										
										
										
											2012-12-17 02:34:53 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-04-21 17:35:11 +02:00
										 |  |  | 	else { | 
					
						
							|  |  |  | 		/* ortho at pixel level */ | 
					
						
							|  |  |  | 		UI_view2d_view_restore(C); | 
					
						
							| 
									
										
										
										
											2012-12-17 02:34:53 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-08-01 12:59:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* NOTE: sequencer mask editing isnt finished, the draw code is working but editing not,
 | 
					
						
							|  |  |  | 	 * for now just disable drawing since the strip frame will likely be offset */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-07 19:24:49 +00:00
										 |  |  | 	//if (sc->mode == SC_MODE_MASKEDIT) {
 | 
					
						
							| 
									
										
										
										
											2012-08-01 12:59:38 +00:00
										 |  |  | 	if (0 && sseq->mainb == SEQ_DRAW_IMG_IMBUF) { | 
					
						
							| 
									
										
										
										
											2012-07-24 19:29:24 +00:00
										 |  |  | 		Mask *mask = BKE_sequencer_mask_get(scene); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (mask) { | 
					
						
							|  |  |  | 			int width, height; | 
					
						
							| 
									
										
										
										
											2012-09-13 02:28:48 +00:00
										 |  |  | 			float aspx = 1.0f, aspy = 1.0f; | 
					
						
							| 
									
										
										
										
											2012-07-26 22:41:40 +00:00
										 |  |  | 			// ED_mask_get_size(C, &width, &height);
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			//Scene *scene = CTX_data_scene(C);
 | 
					
						
							|  |  |  | 			width = (scene->r.size * scene->r.xsch) / 100; | 
					
						
							|  |  |  | 			height = (scene->r.size * scene->r.ysch) / 100; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-24 19:29:24 +00:00
										 |  |  | 			ED_mask_draw_region(mask, ar, | 
					
						
							| 
									
										
										
										
											2013-10-12 14:09:05 +00:00
										 |  |  | 			                    0, 0, 0,  /* TODO */ | 
					
						
							| 
									
										
										
										
											2012-07-24 19:29:24 +00:00
										 |  |  | 			                    width, height, | 
					
						
							| 
									
										
										
										
											2012-09-13 02:28:48 +00:00
										 |  |  | 			                    aspx, aspy, | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 			                    false, true, | 
					
						
							| 
									
										
										
										
											2012-07-24 19:29:24 +00:00
										 |  |  | 			                    NULL, C); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-06-07 19:24:49 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2010-10-16 08:03:28 +00:00
										 |  |  | void drawprefetchseqspace(Scene *scene, ARegion *UNUSED(ar), SpaceSeq *sseq) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int rectx, recty; | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 	int render_size = sseq->render_size; | 
					
						
							| 
									
										
										
										
											2009-06-14 18:54:35 +00:00
										 |  |  | 	int proxy_size = 100.0;  | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 	if (render_size == 0) { | 
					
						
							|  |  |  | 		render_size = scene->r.size; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2009-06-14 18:54:35 +00:00
										 |  |  | 		proxy_size = render_size; | 
					
						
							| 
									
										
										
										
											2009-06-08 20:08:19 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	if (render_size < 0) { | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	rectx = (render_size * scene->r.xsch) / 100; | 
					
						
							|  |  |  | 	recty = (render_size * scene->r.ysch) / 100; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (sseq->mainb != SEQ_DRAW_SEQUENCE) { | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		give_ibuf_prefetch_request( | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		    rectx, recty, (scene->r.cfra), sseq->chanshown, | 
					
						
							|  |  |  | 		    proxy_size); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2010-11-21 20:00:31 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | /* draw backdrop of the sequencer strips view */ | 
					
						
							|  |  |  | static void draw_seq_backdrop(View2D *v2d) | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 	int i; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-07-03 19:09:07 +00:00
										 |  |  | 	/* darker gray overlay over the view backdrop */ | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	UI_ThemeColorShade(TH_BACK, -20); | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 	glRectf(v2d->cur.xmin,  -1.0,  v2d->cur.xmax,  1.0); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* Alternating horizontal stripes */ | 
					
						
							| 
									
										
										
										
											2012-10-23 13:28:22 +00:00
										 |  |  | 	i = max_ii(1, ((int)v2d->cur.ymin) - 1); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	glBegin(GL_QUADS); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	while (i < v2d->cur.ymax) { | 
					
						
							|  |  |  | 		if (((int)i) & 1) | 
					
						
							|  |  |  | 			UI_ThemeColorShade(TH_BACK, -15); | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			UI_ThemeColorShade(TH_BACK, -25); | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		glVertex2f(v2d->cur.xmax, i); | 
					
						
							|  |  |  | 		glVertex2f(v2d->cur.xmin, i); | 
					
						
							|  |  |  | 		glVertex2f(v2d->cur.xmin, i + 1); | 
					
						
							|  |  |  | 		glVertex2f(v2d->cur.xmax, i + 1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		i += 1.0; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	glEnd(); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 	/* Darker lines separating the horizontal bands */ | 
					
						
							| 
									
										
										
										
											2012-10-23 13:28:22 +00:00
										 |  |  | 	i = max_ii(1, ((int)v2d->cur.ymin) - 1); | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 	UI_ThemeColor(TH_GRID); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	glBegin(GL_LINES); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	while (i < v2d->cur.ymax) { | 
					
						
							|  |  |  | 		glVertex2f(v2d->cur.xmax, i); | 
					
						
							|  |  |  | 		glVertex2f(v2d->cur.xmin, i); | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		i += 1.0; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	glEnd(); | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | /* draw the contents of the sequencer strips view */ | 
					
						
							|  |  |  | static void draw_seq_strips(const bContext *C, Editing *ed, ARegion *ar) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	Scene *scene = CTX_data_scene(C); | 
					
						
							|  |  |  | 	View2D *v2d = &ar->v2d; | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 	SpaceSeq *sseq = CTX_wm_space_seq(C); | 
					
						
							| 
									
										
										
										
											2012-05-11 10:04:55 +00:00
										 |  |  | 	Sequence *last_seq = BKE_sequencer_active_get(scene); | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 	int sel = 0, j; | 
					
						
							| 
									
										
										
										
											2012-09-15 11:48:20 +00:00
										 |  |  | 	float pixelx = BLI_rctf_size_x(&v2d->cur) / BLI_rcti_size_x(&v2d->mask); | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* loop through twice, first unselected, then selected */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	for (j = 0; j < 2; j++) { | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 		Sequence *seq; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		int outline_tint = (j) ? -60 : -150; /* highlighting around strip edges indicating selection */ | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* loop through strips, checking for those that are visible */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		for (seq = ed->seqbasep->first; seq; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 			/* boundbox and selection tests for NOT drawing the strip... */ | 
					
						
							| 
									
										
										
										
											2011-07-06 13:15:22 +00:00
										 |  |  | 			if ((seq->flag & SELECT) != sel) continue; | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 			else if (seq == last_seq) continue; | 
					
						
							| 
									
										
										
										
											2012-10-23 16:21:55 +00:00
										 |  |  | 			else if (min_ii(seq->startdisp, seq->start) > v2d->cur.xmax) continue; | 
					
						
							|  |  |  | 			else if (max_ii(seq->enddisp, seq->start + seq->len) < v2d->cur.xmin) continue; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 			else if (seq->machine + 1.0f < v2d->cur.ymin) continue; | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 			else if (seq->machine > v2d->cur.ymax) continue; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 			 | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 			/* strip passed all tests unscathed... so draw it now */ | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 			draw_seq_strip(C, sseq, scene, ar, seq, outline_tint, pixelx); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* draw selected next time round */ | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		sel = SELECT; | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* draw the last selected last (i.e. 'active' in other parts of Blender), removes some overlapping error */ | 
					
						
							|  |  |  | 	if (last_seq) | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 		draw_seq_strip(C, sseq, scene, ar, last_seq, 120, pixelx); | 
					
						
							| 
									
										
										
										
											2015-01-05 02:12:50 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* draw highlight when previewing a single strip */ | 
					
						
							|  |  |  | 	if (special_seq_update) { | 
					
						
							|  |  |  | 		const Sequence *seq = special_seq_update; | 
					
						
							|  |  |  | 		glEnable(GL_BLEND); | 
					
						
							|  |  |  | 		glColor4ub(255, 255, 255, 48); | 
					
						
							|  |  |  | 		glRectf(seq->startdisp, seq->machine + SEQ_STRIP_OFSBOTTOM, seq->enddisp, seq->machine + SEQ_STRIP_OFSTOP); | 
					
						
							|  |  |  | 		glDisable(GL_BLEND); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-16 08:03:28 +00:00
										 |  |  | static void seq_draw_sfra_efra(Scene *scene, View2D *v2d) | 
					
						
							| 
									
										
										
										
											2014-10-16 12:01:01 +02:00
										 |  |  | { | 
					
						
							|  |  |  | 	const Editing *ed = BKE_sequencer_editing_get(scene, false); | 
					
						
							|  |  |  | 	const int frame_sta = PSFRA; | 
					
						
							| 
									
										
										
										
											2015-06-25 20:10:30 +02:00
										 |  |  | 	const int frame_end = PEFRA + 1; | 
					
						
							| 
									
										
										
										
											2014-10-16 12:01:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-06 20:19:22 +00:00
										 |  |  | 	glEnable(GL_BLEND); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* draw darkened area outside of active timeline 
 | 
					
						
							|  |  |  | 	 * frame range used is preview range or scene range */ | 
					
						
							|  |  |  | 	UI_ThemeColorShadeAlpha(TH_BACK, -25, -100); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-25 20:10:30 +02:00
										 |  |  | 	if (frame_sta < frame_end) { | 
					
						
							| 
									
										
										
										
											2014-10-16 12:01:01 +02:00
										 |  |  | 		glRectf(v2d->cur.xmin, v2d->cur.ymin, (float)frame_sta, v2d->cur.ymax); | 
					
						
							|  |  |  | 		glRectf((float)frame_end, v2d->cur.ymin, v2d->cur.xmax, v2d->cur.ymax); | 
					
						
							| 
									
										
										
										
											2010-06-06 20:19:22 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		glRectf(v2d->cur.xmin, v2d->cur.ymin, v2d->cur.xmax, v2d->cur.ymax); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	UI_ThemeColorShade(TH_BACK, -60); | 
					
						
							|  |  |  | 	/* thin lines where the actual frames are */ | 
					
						
							| 
									
										
										
										
											2014-10-16 12:01:01 +02:00
										 |  |  | 	fdrawline(frame_sta, v2d->cur.ymin, frame_sta, v2d->cur.ymax); | 
					
						
							|  |  |  | 	fdrawline(frame_end, v2d->cur.ymin, frame_end, v2d->cur.ymax); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-16 23:18:49 +02:00
										 |  |  | 	if (ed && !BLI_listbase_is_empty(&ed->metastack)) { | 
					
						
							| 
									
										
										
										
											2014-10-16 12:01:01 +02:00
										 |  |  | 		MetaStack *ms = ed->metastack.last; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		glColor4ub(255, 255, 255, 8); | 
					
						
							|  |  |  | 		glRectf(ms->disp_range[0], v2d->cur.ymin, ms->disp_range[1], v2d->cur.ymax); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		UI_ThemeColorShade(TH_BACK, -40); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		fdrawline(ms->disp_range[0], v2d->cur.ymin, ms->disp_range[0], v2d->cur.ymax); | 
					
						
							|  |  |  | 		fdrawline(ms->disp_range[1], v2d->cur.ymin, ms->disp_range[1], v2d->cur.ymax); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-06 20:19:22 +00:00
										 |  |  | 	glDisable(GL_BLEND); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | /* Draw Timeline/Strip Editor Mode for Sequencer */ | 
					
						
							|  |  |  | void draw_timeline_seq(const bContext *C, ARegion *ar) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	Scene *scene = CTX_data_scene(C); | 
					
						
							| 
									
										
										
										
											2014-03-20 15:45:20 +06:00
										 |  |  | 	Editing *ed = BKE_sequencer_editing_get(scene, false); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	SpaceSeq *sseq = CTX_wm_space_seq(C); | 
					
						
							|  |  |  | 	View2D *v2d = &ar->v2d; | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 	View2DScrollers *scrollers; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	short unit = 0, flag = 0; | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 	float col[3]; | 
					
						
							| 
									
										
										
										
											2009-11-19 02:58:48 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 	/* clear and setup matrix */ | 
					
						
							|  |  |  | 	UI_GetThemeColor3fv(TH_BACK, col); | 
					
						
							|  |  |  | 	if (ed && ed->metastack.first)  | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		glClearColor(col[0], col[1], col[2] - 0.1f, 0.0f); | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 	else  | 
					
						
							| 
									
										
										
										
											2011-03-30 05:07:12 +00:00
										 |  |  | 		glClearColor(col[0], col[1], col[2], 0.0f); | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 	glClear(GL_COLOR_BUFFER_BIT); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | 	UI_view2d_view_ortho(v2d); | 
					
						
							| 
									
										
										
										
											2009-11-19 02:58:48 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* calculate extents of sequencer strips/data 
 | 
					
						
							|  |  |  | 	 * NOTE: needed for the scrollers later | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	boundbox_seq(scene, &v2d->tot); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* draw backdrop */ | 
					
						
							|  |  |  | 	draw_seq_backdrop(v2d); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-07-22 11:20:14 +00:00
										 |  |  | 	/* regular grid-pattern over the rest of the view (i.e. 25-frame grid lines) */ | 
					
						
							|  |  |  | 	// NOTE: the gridlines are currently spaced every 25 frames, which is only fine for 25 fps, but maybe not for 30...
 | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | 	UI_view2d_constant_grid_draw(v2d); | 
					
						
							| 
									
										
										
										
											2013-04-10 16:59:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-24 18:18:35 +01:00
										 |  |  | 	if (sseq->draw_flag & SEQ_DRAW_BACKDROP) { | 
					
						
							|  |  |  | 		draw_image_seq(C, scene, ar, sseq, scene->r.cfra, 0, false, true); | 
					
						
							|  |  |  | 		UI_view2d_view_ortho(v2d); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2013-04-10 16:59:55 +00:00
										 |  |  | 	ED_region_draw_cb_draw(C, ar, REGION_DRAW_PRE_VIEW); | 
					
						
							| 
									
										
										
										
											2011-07-22 11:20:14 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	seq_draw_sfra_efra(scene, v2d); | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* sequence strips (if there is data available to be drawn) */ | 
					
						
							|  |  |  | 	if (ed) { | 
					
						
							|  |  |  | 		/* draw the data */ | 
					
						
							|  |  |  | 		draw_seq_strips(C, ed, ar); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* text draw cached (for sequence names), in pixelspace now */ | 
					
						
							|  |  |  | 		UI_view2d_text_cache_draw(ar); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* current frame */ | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | 	UI_view2d_view_ortho(v2d); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	if ((sseq->flag & SEQ_DRAWFRAMES) == 0)      flag |= DRAWCFRA_UNIT_SECONDS; | 
					
						
							|  |  |  | 	if ((sseq->flag & SEQ_NO_DRAW_CFRANUM) == 0) flag |= DRAWCFRA_SHOW_NUMBOX; | 
					
						
							| 
									
										
										
										
											2009-11-19 02:58:48 +00:00
										 |  |  | 	ANIM_draw_cfra(C, v2d, flag); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-26 12:22:43 +00:00
										 |  |  | 	/* markers */ | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | 	UI_view2d_view_orthoSpecial(ar, v2d, 1); | 
					
						
							| 
									
										
										
										
											2014-10-28 19:03:13 +01:00
										 |  |  | 	ED_markers_draw(C, DRAW_MARKERS_LINES | DRAW_MARKERS_MARGIN); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-11-17 10:12:35 +00:00
										 |  |  | 	/* preview range */ | 
					
						
							| 
									
										
										
										
											2010-10-14 01:22:14 +00:00
										 |  |  | 	UI_view2d_view_ortho(v2d); | 
					
						
							| 
									
										
										
										
											2013-05-18 10:24:38 +00:00
										 |  |  | 	ANIM_draw_previewrange(C, v2d, 1); | 
					
						
							| 
									
										
										
										
											2010-07-08 10:03:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* overlap playhead */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (scene->ed && scene->ed->over_flag & SEQ_EDIT_OVERLAY_SHOW) { | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		int cfra_over = (scene->ed->over_flag & SEQ_EDIT_OVERLAY_ABS) ? scene->ed->over_cfra : scene->r.cfra + scene->ed->over_ofs; | 
					
						
							| 
									
										
										
										
											2010-07-08 10:03:29 +00:00
										 |  |  | 		glColor3f(0.2, 0.2, 0.2); | 
					
						
							|  |  |  | 		// glRectf(cfra_over, v2d->cur.ymin, scene->ed->over_ofs + scene->r.cfra + 1, v2d->cur.ymax);
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		glBegin(GL_LINES); | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 		glVertex2f(cfra_over, v2d->cur.ymin); | 
					
						
							|  |  |  | 		glVertex2f(cfra_over, v2d->cur.ymax); | 
					
						
							| 
									
										
										
										
											2010-07-08 10:03:29 +00:00
										 |  |  | 		glEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-11-17 10:12:35 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2013-04-10 16:59:55 +00:00
										 |  |  | 	/* callback */ | 
					
						
							|  |  |  | 	ED_region_draw_cb_draw(C, ar, REGION_DRAW_POST_VIEW); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	/* reset view matrix */ | 
					
						
							|  |  |  | 	UI_view2d_view_restore(C); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* scrollers */ | 
					
						
							| 
									
										
										
										
											2014-01-29 20:01:30 +11:00
										 |  |  | 	unit = (sseq->flag & SEQ_DRAWFRAMES) ? V2D_UNIT_FRAMES : V2D_UNIT_SECONDS; | 
					
						
							| 
									
										
										
										
											2012-03-29 22:26:11 +00:00
										 |  |  | 	scrollers = UI_view2d_scrollers_calc(C, v2d, unit, V2D_GRID_CLAMP, V2D_UNIT_VALUES, V2D_GRID_CLAMP); | 
					
						
							| 
									
										
										
										
											2009-01-12 19:02:08 +00:00
										 |  |  | 	UI_view2d_scrollers_draw(C, v2d, scrollers); | 
					
						
							|  |  |  | 	UI_view2d_scrollers_free(scrollers); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 |