| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							|  |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							| 
									
										
										
										
											2019-02-18 07:21:50 +11:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Copyright 2015, Blender Foundation. | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "COM_OutputFileMultiViewOperation.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include "COM_OutputFileOperation.h"
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-04 11:28:09 +01:00
										 |  |  | #include <cstring>
 | 
					
						
							| 
									
										
										
										
											2018-11-07 18:00:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | #include "BLI_listbase.h"
 | 
					
						
							|  |  |  | #include "BLI_path_util.h"
 | 
					
						
							|  |  |  | #include "BLI_string.h"
 | 
					
						
							| 
									
										
										
										
											2018-11-07 18:00:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | #include "BKE_global.h"
 | 
					
						
							| 
									
										
										
										
											2018-11-07 18:00:24 +01:00
										 |  |  | #include "BKE_image.h"
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | #include "BKE_main.h"
 | 
					
						
							|  |  |  | #include "BKE_scene.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "DNA_color_types.h"
 | 
					
						
							|  |  |  | #include "MEM_guardedalloc.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "IMB_colormanagement.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include "IMB_imbuf.h"
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | #include "IMB_imbuf_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-23 17:12:27 +01:00
										 |  |  | namespace blender::compositor { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-01 10:50:02 +10:00
										 |  |  | /************************************ OpenEXR Singlelayer Multiview ******************************/ | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | OutputOpenExrSingleLayerMultiViewOperation::OutputOpenExrSingleLayerMultiViewOperation( | 
					
						
							|  |  |  |     const RenderData *rd, | 
					
						
							|  |  |  |     const bNodeTree *tree, | 
					
						
							|  |  |  |     DataType datatype, | 
					
						
							|  |  |  |     ImageFormatData *format, | 
					
						
							|  |  |  |     const char *path, | 
					
						
							|  |  |  |     const ColorManagedViewSettings *viewSettings, | 
					
						
							|  |  |  |     const ColorManagedDisplaySettings *displaySettings, | 
					
						
							| 
									
										
										
										
											2021-01-13 11:01:44 +01:00
										 |  |  |     const char *viewName, | 
					
						
							|  |  |  |     const bool saveAsRender) | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     : OutputSingleLayerOperation( | 
					
						
							| 
									
										
										
										
											2021-01-13 11:01:44 +01:00
										 |  |  |           rd, tree, datatype, format, path, viewSettings, displaySettings, viewName, saveAsRender) | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void *OutputOpenExrSingleLayerMultiViewOperation::get_handle(const char *filename) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   size_t width = this->getWidth(); | 
					
						
							|  |  |  |   size_t height = this->getHeight(); | 
					
						
							|  |  |  |   SceneRenderView *srv; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (width != 0 && height != 0) { | 
					
						
							|  |  |  |     void *exrhandle; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     exrhandle = IMB_exr_get_handle_name(filename); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     if (!BKE_scene_multiview_is_render_view_first(this->m_rd, this->m_viewName)) { | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       return exrhandle; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     IMB_exr_clear_channels(exrhandle); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (srv = (SceneRenderView *)this->m_rd->views.first; srv; srv = srv->next) { | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       if (BKE_scene_multiview_is_render_view_active(this->m_rd, srv) == false) { | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |         continue; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |       IMB_exr_add_view(exrhandle, srv->name); | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |       add_exr_channels(exrhandle, nullptr, this->m_datatype, srv->name, width, false, nullptr); | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     BLI_make_existing_file(filename); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* prepare the file with all the channels */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |     if (IMB_exr_begin_write( | 
					
						
							|  |  |  |             exrhandle, filename, width, height, this->m_format->exr_codec, nullptr) == 0) { | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       printf("Error Writing Singlelayer Multiview Openexr\n"); | 
					
						
							|  |  |  |       IMB_exr_close(exrhandle); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       IMB_exr_clear_channels(exrhandle); | 
					
						
							|  |  |  |       return exrhandle; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |   return nullptr; | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void OutputOpenExrSingleLayerMultiViewOperation::deinitExecution() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   unsigned int width = this->getWidth(); | 
					
						
							|  |  |  |   unsigned int height = this->getHeight(); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |   if (width != 0 && height != 0) { | 
					
						
							|  |  |  |     void *exrhandle; | 
					
						
							|  |  |  |     char filename[FILE_MAX]; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     BKE_image_path_from_imtype(filename, | 
					
						
							| 
									
										
										
										
											2018-06-05 15:10:33 +02:00
										 |  |  |                                this->m_path, | 
					
						
							|  |  |  |                                BKE_main_blendfile_path_from_global(), | 
					
						
							|  |  |  |                                this->m_rd->cfra, | 
					
						
							|  |  |  |                                R_IMF_IMTYPE_OPENEXR, | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |                                (this->m_rd->scemode & R_EXTENSION) != 0, | 
					
						
							|  |  |  |                                true, | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |                                nullptr); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     exrhandle = this->get_handle(filename); | 
					
						
							| 
									
										
										
										
											2015-06-19 13:00:18 +02:00
										 |  |  |     add_exr_channels(exrhandle, | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |                      nullptr, | 
					
						
							| 
									
										
										
										
											2015-06-19 13:00:18 +02:00
										 |  |  |                      this->m_datatype, | 
					
						
							|  |  |  |                      this->m_viewName, | 
					
						
							|  |  |  |                      width, | 
					
						
							|  |  |  |                      this->m_format->depth == R_IMF_CHAN_DEPTH_16, | 
					
						
							|  |  |  |                      this->m_outputBuffer); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     /* memory can only be freed after we write all views to the file */ | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |     this->m_outputBuffer = nullptr; | 
					
						
							|  |  |  |     this->m_imageInput = nullptr; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     /* ready to close the file */ | 
					
						
							|  |  |  |     if (BKE_scene_multiview_is_render_view_last(this->m_rd, this->m_viewName)) { | 
					
						
							|  |  |  |       IMB_exr_write_channels(exrhandle); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       /* free buffer memory for all the views */ | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |       free_exr_channels(exrhandle, this->m_rd, nullptr, this->m_datatype); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       /* remove exr handle and data */ | 
					
						
							|  |  |  |       IMB_exr_close(exrhandle); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-01 10:50:02 +10:00
										 |  |  | /************************************ OpenEXR Multilayer Multiview *******************************/ | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | OutputOpenExrMultiLayerMultiViewOperation::OutputOpenExrMultiLayerMultiViewOperation( | 
					
						
							| 
									
										
										
										
											2021-01-12 16:19:54 +01:00
										 |  |  |     const Scene *scene, | 
					
						
							| 
									
										
										
										
											2015-06-19 13:00:18 +02:00
										 |  |  |     const RenderData *rd, | 
					
						
							|  |  |  |     const bNodeTree *tree, | 
					
						
							|  |  |  |     const char *path, | 
					
						
							|  |  |  |     char exr_codec, | 
					
						
							|  |  |  |     bool exr_half_float, | 
					
						
							|  |  |  |     const char *viewName) | 
					
						
							| 
									
										
										
										
											2021-01-12 16:19:54 +01:00
										 |  |  |     : OutputOpenExrMultiLayerOperation(scene, rd, tree, path, exr_codec, exr_half_float, viewName) | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void *OutputOpenExrMultiLayerMultiViewOperation::get_handle(const char *filename) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   unsigned int width = this->getWidth(); | 
					
						
							|  |  |  |   unsigned int height = this->getHeight(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (width != 0 && height != 0) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void *exrhandle; | 
					
						
							|  |  |  |     SceneRenderView *srv; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* get a new global handle */ | 
					
						
							|  |  |  |     exrhandle = IMB_exr_get_handle_name(filename); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     if (!BKE_scene_multiview_is_render_view_first(this->m_rd, this->m_viewName)) { | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       return exrhandle; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     IMB_exr_clear_channels(exrhandle); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* check renderdata for amount of views */ | 
					
						
							|  |  |  |     for (srv = (SceneRenderView *)this->m_rd->views.first; srv; srv = srv->next) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       if (BKE_scene_multiview_is_render_view_active(this->m_rd, srv) == false) { | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |         continue; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |       IMB_exr_add_view(exrhandle, srv->name); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-08 00:12:26 +10:00
										 |  |  |       for (unsigned int i = 0; i < this->m_layers.size(); i++) { | 
					
						
							| 
									
										
										
										
											2015-06-19 13:00:18 +02:00
										 |  |  |         add_exr_channels(exrhandle, | 
					
						
							|  |  |  |                          this->m_layers[i].name, | 
					
						
							|  |  |  |                          this->m_layers[i].datatype, | 
					
						
							|  |  |  |                          srv->name, | 
					
						
							|  |  |  |                          width, | 
					
						
							|  |  |  |                          this->m_exr_half_float, | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |                          nullptr); | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     BLI_make_existing_file(filename); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* prepare the file with all the channels for the header */ | 
					
						
							| 
									
										
										
										
											2021-01-12 16:19:54 +01:00
										 |  |  |     StampData *stamp_data = createStampData(); | 
					
						
							|  |  |  |     if (IMB_exr_begin_write(exrhandle, filename, width, height, this->m_exr_codec, stamp_data) == | 
					
						
							|  |  |  |         0) { | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       printf("Error Writing Multilayer Multiview Openexr\n"); | 
					
						
							|  |  |  |       IMB_exr_close(exrhandle); | 
					
						
							| 
									
										
										
										
											2021-01-12 16:19:54 +01:00
										 |  |  |       BKE_stamp_data_free(stamp_data); | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       IMB_exr_clear_channels(exrhandle); | 
					
						
							| 
									
										
										
										
											2021-01-12 16:19:54 +01:00
										 |  |  |       BKE_stamp_data_free(stamp_data); | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       return exrhandle; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |   return nullptr; | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void OutputOpenExrMultiLayerMultiViewOperation::deinitExecution() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   unsigned int width = this->getWidth(); | 
					
						
							|  |  |  |   unsigned int height = this->getHeight(); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |   if (width != 0 && height != 0) { | 
					
						
							|  |  |  |     void *exrhandle; | 
					
						
							|  |  |  |     char filename[FILE_MAX]; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     BKE_image_path_from_imtype(filename, | 
					
						
							| 
									
										
										
										
											2018-06-05 15:10:33 +02:00
										 |  |  |                                this->m_path, | 
					
						
							|  |  |  |                                BKE_main_blendfile_path_from_global(), | 
					
						
							|  |  |  |                                this->m_rd->cfra, | 
					
						
							|  |  |  |                                R_IMF_IMTYPE_MULTILAYER, | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |                                (this->m_rd->scemode & R_EXTENSION) != 0, | 
					
						
							|  |  |  |                                true, | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |                                nullptr); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     exrhandle = this->get_handle(filename); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-08 00:12:26 +10:00
										 |  |  |     for (unsigned int i = 0; i < this->m_layers.size(); i++) { | 
					
						
							| 
									
										
										
										
											2015-06-19 13:00:18 +02:00
										 |  |  |       add_exr_channels(exrhandle, | 
					
						
							|  |  |  |                        this->m_layers[i].name, | 
					
						
							|  |  |  |                        this->m_layers[i].datatype, | 
					
						
							|  |  |  |                        this->m_viewName, | 
					
						
							|  |  |  |                        width, | 
					
						
							|  |  |  |                        this->m_exr_half_float, | 
					
						
							|  |  |  |                        this->m_layers[i].outputBuffer); | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-08 00:12:26 +10:00
										 |  |  |     for (unsigned int i = 0; i < this->m_layers.size(); i++) { | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       /* memory can only be freed after we write all views to the file */ | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |       this->m_layers[i].outputBuffer = nullptr; | 
					
						
							|  |  |  |       this->m_layers[i].imageInput = nullptr; | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     /* ready to close the file */ | 
					
						
							|  |  |  |     if (BKE_scene_multiview_is_render_view_last(this->m_rd, this->m_viewName)) { | 
					
						
							|  |  |  |       IMB_exr_write_channels(exrhandle); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       /* free buffer memory for all the views */ | 
					
						
							| 
									
										
										
										
											2019-09-08 00:12:26 +10:00
										 |  |  |       for (unsigned int i = 0; i < this->m_layers.size(); i++) { | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |         free_exr_channels( | 
					
						
							|  |  |  |             exrhandle, this->m_rd, this->m_layers[i].name, this->m_layers[i].datatype); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       IMB_exr_close(exrhandle); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /******************************** Stereo3D ******************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | OutputStereoOperation::OutputStereoOperation(const RenderData *rd, | 
					
						
							|  |  |  |                                              const bNodeTree *tree, | 
					
						
							|  |  |  |                                              DataType datatype, | 
					
						
							|  |  |  |                                              ImageFormatData *format, | 
					
						
							|  |  |  |                                              const char *path, | 
					
						
							|  |  |  |                                              const char *name, | 
					
						
							|  |  |  |                                              const ColorManagedViewSettings *viewSettings, | 
					
						
							|  |  |  |                                              const ColorManagedDisplaySettings *displaySettings, | 
					
						
							| 
									
										
										
										
											2021-01-13 11:01:44 +01:00
										 |  |  |                                              const char *viewName, | 
					
						
							|  |  |  |                                              const bool saveAsRender) | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     : OutputSingleLayerOperation( | 
					
						
							| 
									
										
										
										
											2021-01-13 11:01:44 +01:00
										 |  |  |           rd, tree, datatype, format, path, viewSettings, displaySettings, viewName, saveAsRender) | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | { | 
					
						
							|  |  |  |   BLI_strncpy(this->m_name, name, sizeof(this->m_name)); | 
					
						
							|  |  |  |   this->m_channels = get_datatype_size(datatype); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void *OutputStereoOperation::get_handle(const char *filename) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   size_t width = this->getWidth(); | 
					
						
							|  |  |  |   size_t height = this->getHeight(); | 
					
						
							|  |  |  |   const char *names[2] = {STEREO_LEFT_NAME, STEREO_RIGHT_NAME}; | 
					
						
							|  |  |  |   size_t i; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (width != 0 && height != 0) { | 
					
						
							|  |  |  |     void *exrhandle; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     exrhandle = IMB_exr_get_handle_name(filename); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     if (!BKE_scene_multiview_is_render_view_first(this->m_rd, this->m_viewName)) { | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       return exrhandle; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     IMB_exr_clear_channels(exrhandle); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     for (i = 0; i < 2; i++) { | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       IMB_exr_add_view(exrhandle, names[i]); | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     return exrhandle; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |   return nullptr; | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void OutputStereoOperation::deinitExecution() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   unsigned int width = this->getWidth(); | 
					
						
							|  |  |  |   unsigned int height = this->getHeight(); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |   if (width != 0 && height != 0) { | 
					
						
							|  |  |  |     void *exrhandle; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     exrhandle = this->get_handle(this->m_path); | 
					
						
							|  |  |  |     float *buf = this->m_outputBuffer; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     /* populate single EXR channel with view data */ | 
					
						
							| 
									
										
										
										
											2015-06-19 13:00:18 +02:00
										 |  |  |     IMB_exr_add_channel(exrhandle, | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |                         nullptr, | 
					
						
							| 
									
										
										
										
											2015-06-19 13:00:18 +02:00
										 |  |  |                         this->m_name, | 
					
						
							|  |  |  |                         this->m_viewName, | 
					
						
							|  |  |  |                         1, | 
					
						
							|  |  |  |                         this->m_channels * width * height, | 
					
						
							|  |  |  |                         buf, | 
					
						
							|  |  |  |                         this->m_format->depth == R_IMF_CHAN_DEPTH_16); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |     this->m_imageInput = nullptr; | 
					
						
							|  |  |  |     this->m_outputBuffer = nullptr; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |     /* create stereo ibuf */ | 
					
						
							|  |  |  |     if (BKE_scene_multiview_is_render_view_last(this->m_rd, this->m_viewName)) { | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |       ImBuf *ibuf[3] = {nullptr}; | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       const char *names[2] = {STEREO_LEFT_NAME, STEREO_RIGHT_NAME}; | 
					
						
							|  |  |  |       char filename[FILE_MAX]; | 
					
						
							|  |  |  |       int i; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       /* get rectf from EXR */ | 
					
						
							|  |  |  |       for (i = 0; i < 2; i++) { | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |         float *rectf = IMB_exr_channel_rect(exrhandle, nullptr, this->m_name, names[i]); | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |         ibuf[i] = IMB_allocImBuf(width, height, this->m_format->planes, 0); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |         ibuf[i]->channels = this->m_channels; | 
					
						
							|  |  |  |         ibuf[i]->rect_float = rectf; | 
					
						
							|  |  |  |         ibuf[i]->mall |= IB_rectfloat; | 
					
						
							|  |  |  |         ibuf[i]->dither = this->m_rd->dither_intensity; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |         /* do colormanagement in the individual views, so it doesn't need to do in the stereo */ | 
					
						
							|  |  |  |         IMB_colormanagement_imbuf_for_write( | 
					
						
							|  |  |  |             ibuf[i], true, false, this->m_viewSettings, this->m_displaySettings, this->m_format); | 
					
						
							|  |  |  |         IMB_prepare_write_ImBuf(IMB_isfloat(ibuf[i]), ibuf[i]); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       /* create stereo buffer */ | 
					
						
							|  |  |  |       ibuf[2] = IMB_stereo3d_ImBuf(this->m_format, ibuf[0], ibuf[1]); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       BKE_image_path_from_imformat(filename, | 
					
						
							| 
									
										
										
										
											2018-06-05 15:10:33 +02:00
										 |  |  |                                    this->m_path, | 
					
						
							|  |  |  |                                    BKE_main_blendfile_path_from_global(), | 
					
						
							|  |  |  |                                    this->m_rd->cfra, | 
					
						
							|  |  |  |                                    this->m_format, | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |                                    (this->m_rd->scemode & R_EXTENSION) != 0, | 
					
						
							|  |  |  |                                    true, | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |                                    nullptr); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       BKE_imbuf_write(ibuf[2], filename, this->m_format); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       /* imbuf knows which rects are not part of ibuf */ | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       for (i = 0; i < 3; i++) { | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |         IMB_freeImBuf(ibuf[i]); | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 10:40:12 -03:00
										 |  |  |       IMB_exr_close(exrhandle); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2021-03-23 17:12:27 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | }  // namespace blender::compositor
 |