| 
									
										
										
										
											2013-09-05 09:39:38 +00: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 2011, Blender Foundation. | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "COM_MixOperation.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-22 14:11:10 +11:00
										 |  |  | #include "BLI_math.h"
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-23 17:12:27 +01:00
										 |  |  | namespace blender::compositor { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | /* ******** Mix Base Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixBaseOperation::MixBaseOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2021-03-19 14:26:24 +01:00
										 |  |  |   this->addInputSocket(DataType::Value); | 
					
						
							|  |  |  |   this->addInputSocket(DataType::Color); | 
					
						
							|  |  |  |   this->addInputSocket(DataType::Color); | 
					
						
							|  |  |  |   this->addOutputSocket(DataType::Color); | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |   this->m_inputValueOperation = nullptr; | 
					
						
							|  |  |  |   this->m_inputColor1Operation = nullptr; | 
					
						
							|  |  |  |   this->m_inputColor2Operation = nullptr; | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   this->setUseValueAlphaMultiply(false); | 
					
						
							|  |  |  |   this->setUseClamp(false); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void MixBaseOperation::initExecution() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   this->m_inputValueOperation = this->getInputSocketReader(0); | 
					
						
							|  |  |  |   this->m_inputColor1Operation = this->getInputSocketReader(1); | 
					
						
							|  |  |  |   this->m_inputColor2Operation = this->getInputSocketReader(2); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixBaseOperation::executePixelSampled(float output[4], float x, float y, PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   float valuem = 1.0f - value; | 
					
						
							|  |  |  |   output[0] = valuem * (inputColor1[0]) + value * (inputColor2[0]); | 
					
						
							|  |  |  |   output[1] = valuem * (inputColor1[1]) + value * (inputColor2[1]); | 
					
						
							|  |  |  |   output[2] = valuem * (inputColor1[2]) + value * (inputColor2[2]); | 
					
						
							|  |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | void MixBaseOperation::determineResolution(unsigned int resolution[2], | 
					
						
							|  |  |  |                                            unsigned int preferredResolution[2]) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-04-15 16:06:12 +02:00
										 |  |  |   NodeOperationInput *socket; | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   unsigned int tempPreferredResolution[2] = {0, 0}; | 
					
						
							|  |  |  |   unsigned int tempResolution[2]; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   socket = this->getInputSocket(1); | 
					
						
							|  |  |  |   socket->determineResolution(tempResolution, tempPreferredResolution); | 
					
						
							|  |  |  |   if ((tempResolution[0] != 0) && (tempResolution[1] != 0)) { | 
					
						
							|  |  |  |     this->setResolutionInputSocketIndex(1); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     socket = this->getInputSocket(2); | 
					
						
							|  |  |  |     socket->determineResolution(tempResolution, tempPreferredResolution); | 
					
						
							|  |  |  |     if ((tempResolution[0] != 0) && (tempResolution[1] != 0)) { | 
					
						
							|  |  |  |       this->setResolutionInputSocketIndex(2); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       this->setResolutionInputSocketIndex(0); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   NodeOperation::determineResolution(resolution, preferredResolution); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void MixBaseOperation::deinitExecution() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-11-06 17:49:09 +01:00
										 |  |  |   this->m_inputValueOperation = nullptr; | 
					
						
							|  |  |  |   this->m_inputColor1Operation = nullptr; | 
					
						
							|  |  |  |   this->m_inputColor2Operation = nullptr; | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Add Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixAddOperation::MixAddOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixAddOperation::executePixelSampled(float output[4], float x, float y, PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   output[0] = inputColor1[0] + value * inputColor2[0]; | 
					
						
							|  |  |  |   output[1] = inputColor1[1] + value * inputColor2[1]; | 
					
						
							|  |  |  |   output[2] = inputColor1[2] + value * inputColor2[2]; | 
					
						
							|  |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Blend Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixBlendOperation::MixBlendOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixBlendOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                             float x, | 
					
						
							|  |  |  |                                             float y, | 
					
						
							|  |  |  |                                             PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  |   float value; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   value = inputValue[0]; | 
					
						
							| 
									
										
										
										
											2018-06-17 17:05:29 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   float valuem = 1.0f - value; | 
					
						
							|  |  |  |   output[0] = valuem * (inputColor1[0]) + value * (inputColor2[0]); | 
					
						
							|  |  |  |   output[1] = valuem * (inputColor1[1]) + value * (inputColor2[1]); | 
					
						
							|  |  |  |   output[2] = valuem * (inputColor1[2]) + value * (inputColor2[2]); | 
					
						
							|  |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Burn Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixColorBurnOperation::MixColorBurnOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-25 15:59:04 +10:00
										 |  |  | void MixColorBurnOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                                 float x, | 
					
						
							|  |  |  |                                                 float y, | 
					
						
							|  |  |  |                                                 PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  |   float tmp; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   float valuem = 1.0f - value; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   tmp = valuem + value * inputColor2[0]; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   if (tmp <= 0.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[0] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   else { | 
					
						
							|  |  |  |     tmp = 1.0f - (1.0f - inputColor1[0]) / tmp; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     if (tmp < 0.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |       output[0] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							|  |  |  |     else if (tmp > 1.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |       output[0] = 1.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |       output[0] = tmp; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   tmp = valuem + value * inputColor2[1]; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   if (tmp <= 0.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[1] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   else { | 
					
						
							|  |  |  |     tmp = 1.0f - (1.0f - inputColor1[1]) / tmp; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     if (tmp < 0.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |       output[1] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							|  |  |  |     else if (tmp > 1.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |       output[1] = 1.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |       output[1] = tmp; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   tmp = valuem + value * inputColor2[2]; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   if (tmp <= 0.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[2] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   else { | 
					
						
							|  |  |  |     tmp = 1.0f - (1.0f - inputColor1[2]) / tmp; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     if (tmp < 0.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |       output[2] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							|  |  |  |     else if (tmp > 1.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |       output[2] = 1.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |       output[2] = tmp; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   output[3] = inputColor1[3]; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Color Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixColorOperation::MixColorOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixColorOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                             float x, | 
					
						
							|  |  |  |                                             float y, | 
					
						
							|  |  |  |                                             PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   float valuem = 1.0f - value; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   float colH, colS, colV; | 
					
						
							|  |  |  |   rgb_to_hsv(inputColor2[0], inputColor2[1], inputColor2[2], &colH, &colS, &colV); | 
					
						
							|  |  |  |   if (colS != 0.0f) { | 
					
						
							|  |  |  |     float rH, rS, rV; | 
					
						
							|  |  |  |     float tmpr, tmpg, tmpb; | 
					
						
							|  |  |  |     rgb_to_hsv(inputColor1[0], inputColor1[1], inputColor1[2], &rH, &rS, &rV); | 
					
						
							|  |  |  |     hsv_to_rgb(colH, colS, rV, &tmpr, &tmpg, &tmpb); | 
					
						
							|  |  |  |     output[0] = (valuem * inputColor1[0]) + (value * tmpr); | 
					
						
							|  |  |  |     output[1] = (valuem * inputColor1[1]) + (value * tmpg); | 
					
						
							|  |  |  |     output[2] = (valuem * inputColor1[2]) + (value * tmpb); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     copy_v3_v3(output, inputColor1); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Darken Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixDarkenOperation::MixDarkenOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixDarkenOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                              float x, | 
					
						
							|  |  |  |                                              float y, | 
					
						
							|  |  |  |                                              PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   float valuem = 1.0f - value; | 
					
						
							| 
									
										
										
										
											2014-04-28 17:38:34 +02:00
										 |  |  |   output[0] = min_ff(inputColor1[0], inputColor2[0]) * value + inputColor1[0] * valuem; | 
					
						
							|  |  |  |   output[1] = min_ff(inputColor1[1], inputColor2[1]) * value + inputColor1[1] * valuem; | 
					
						
							|  |  |  |   output[2] = min_ff(inputColor1[2], inputColor2[2]) * value + inputColor1[2] * valuem; | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Difference Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixDifferenceOperation::MixDifferenceOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixDifferenceOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                                  float x, | 
					
						
							|  |  |  |                                                  float y, | 
					
						
							|  |  |  |                                                  PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   float valuem = 1.0f - value; | 
					
						
							| 
									
										
										
										
											2015-08-25 08:50:53 +10:00
										 |  |  |   output[0] = valuem * inputColor1[0] + value * fabsf(inputColor1[0] - inputColor2[0]); | 
					
						
							|  |  |  |   output[1] = valuem * inputColor1[1] + value * fabsf(inputColor1[1] - inputColor2[1]); | 
					
						
							|  |  |  |   output[2] = valuem * inputColor1[2] + value * fabsf(inputColor1[2] - inputColor2[2]); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Difference Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixDivideOperation::MixDivideOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixDivideOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                              float x, | 
					
						
							|  |  |  |                                              float y, | 
					
						
							|  |  |  |                                              PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   float valuem = 1.0f - value; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   if (inputColor2[0] != 0.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[0] = valuem * (inputColor1[0]) + value * (inputColor1[0]) / inputColor2[0]; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[0] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (inputColor2[1] != 0.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[1] = valuem * (inputColor1[1]) + value * (inputColor1[1]) / inputColor2[1]; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[1] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (inputColor2[2] != 0.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[2] = valuem * (inputColor1[2]) + value * (inputColor1[2]) / inputColor2[2]; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[2] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Dodge Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixDodgeOperation::MixDodgeOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixDodgeOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                             float x, | 
					
						
							|  |  |  |                                             float y, | 
					
						
							|  |  |  |                                             PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  |   float tmp; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   if (inputColor1[0] != 0.0f) { | 
					
						
							|  |  |  |     tmp = 1.0f - value * inputColor2[0]; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     if (tmp <= 0.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |       output[0] = 1.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     else { | 
					
						
							|  |  |  |       tmp = inputColor1[0] / tmp; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       if (tmp > 1.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |         output[0] = 1.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       } | 
					
						
							|  |  |  |       else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |         output[0] = tmp; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[0] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   if (inputColor1[1] != 0.0f) { | 
					
						
							|  |  |  |     tmp = 1.0f - value * inputColor2[1]; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     if (tmp <= 0.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |       output[1] = 1.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     else { | 
					
						
							|  |  |  |       tmp = inputColor1[1] / tmp; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       if (tmp > 1.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |         output[1] = 1.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       } | 
					
						
							|  |  |  |       else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |         output[1] = tmp; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[1] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   if (inputColor1[2] != 0.0f) { | 
					
						
							|  |  |  |     tmp = 1.0f - value * inputColor2[2]; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     if (tmp <= 0.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |       output[2] = 1.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     else { | 
					
						
							|  |  |  |       tmp = inputColor1[2] / tmp; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       if (tmp > 1.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |         output[2] = 1.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       } | 
					
						
							|  |  |  |       else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |         output[2] = tmp; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[2] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   output[3] = inputColor1[3]; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Glare Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixGlareOperation::MixGlareOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixGlareOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                             float x, | 
					
						
							|  |  |  |                                             float y, | 
					
						
							|  |  |  |                                             PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  |   float value; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   value = inputValue[0]; | 
					
						
							| 
									
										
										
										
											2016-02-14 10:12:45 +01:00
										 |  |  |   float mf = 2.0f - 2.0f * fabsf(value - 0.5f); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   if (inputColor1[0] < 0.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     inputColor1[0] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (inputColor1[1] < 0.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     inputColor1[1] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (inputColor1[2] < 0.0f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     inputColor1[2] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-05 14:54:32 +01:00
										 |  |  |   output[0] = mf * MAX2(inputColor1[0] + value * (inputColor2[0] - inputColor1[0]), 0.0f); | 
					
						
							|  |  |  |   output[1] = mf * MAX2(inputColor1[1] + value * (inputColor2[1] - inputColor1[1]), 0.0f); | 
					
						
							|  |  |  |   output[2] = mf * MAX2(inputColor1[2] + value * (inputColor2[2] - inputColor1[2]), 0.0f); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Hue Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixHueOperation::MixHueOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixHueOperation::executePixelSampled(float output[4], float x, float y, PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   float valuem = 1.0f - value; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   float colH, colS, colV; | 
					
						
							|  |  |  |   rgb_to_hsv(inputColor2[0], inputColor2[1], inputColor2[2], &colH, &colS, &colV); | 
					
						
							|  |  |  |   if (colS != 0.0f) { | 
					
						
							|  |  |  |     float rH, rS, rV; | 
					
						
							|  |  |  |     float tmpr, tmpg, tmpb; | 
					
						
							|  |  |  |     rgb_to_hsv(inputColor1[0], inputColor1[1], inputColor1[2], &rH, &rS, &rV); | 
					
						
							|  |  |  |     hsv_to_rgb(colH, rS, rV, &tmpr, &tmpg, &tmpb); | 
					
						
							|  |  |  |     output[0] = valuem * (inputColor1[0]) + value * tmpr; | 
					
						
							|  |  |  |     output[1] = valuem * (inputColor1[1]) + value * tmpg; | 
					
						
							|  |  |  |     output[2] = valuem * (inputColor1[2]) + value * tmpb; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     copy_v3_v3(output, inputColor1); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   output[3] = inputColor1[3]; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Lighten Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixLightenOperation::MixLightenOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixLightenOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                               float x, | 
					
						
							|  |  |  |                                               float y, | 
					
						
							|  |  |  |                                               PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   float tmp; | 
					
						
							|  |  |  |   tmp = value * inputColor2[0]; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   if (tmp > inputColor1[0]) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[0] = tmp; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[0] = inputColor1[0]; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   tmp = value * inputColor2[1]; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   if (tmp > inputColor1[1]) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[1] = tmp; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[1] = inputColor1[1]; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   tmp = value * inputColor2[2]; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   if (tmp > inputColor1[2]) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[2] = tmp; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[2] = inputColor1[2]; | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   output[3] = inputColor1[3]; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Linear Light Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixLinearLightOperation::MixLinearLightOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixLinearLightOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                                   float x, | 
					
						
							|  |  |  |                                                   float y, | 
					
						
							|  |  |  |                                                   PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   if (inputColor2[0] > 0.5f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[0] = inputColor1[0] + value * (2.0f * (inputColor2[0] - 0.5f)); | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[0] = inputColor1[0] + value * (2.0f * (inputColor2[0]) - 1.0f); | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (inputColor2[1] > 0.5f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[1] = inputColor1[1] + value * (2.0f * (inputColor2[1] - 0.5f)); | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[1] = inputColor1[1] + value * (2.0f * (inputColor2[1]) - 1.0f); | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (inputColor2[2] > 0.5f) { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[2] = inputColor1[2] + value * (2.0f * (inputColor2[2] - 0.5f)); | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  |     output[2] = inputColor1[2] + value * (2.0f * (inputColor2[2]) - 1.0f); | 
					
						
							| 
									
										
										
										
											2019-04-23 11:21:22 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Multiply Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixMultiplyOperation::MixMultiplyOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixMultiplyOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                                float x, | 
					
						
							|  |  |  |                                                float y, | 
					
						
							|  |  |  |                                                PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   float valuem = 1.0f - value; | 
					
						
							|  |  |  |   output[0] = inputColor1[0] * (valuem + value * inputColor2[0]); | 
					
						
							|  |  |  |   output[1] = inputColor1[1] * (valuem + value * inputColor2[1]); | 
					
						
							|  |  |  |   output[2] = inputColor1[2] * (valuem + value * inputColor2[2]); | 
					
						
							|  |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 16:23:34 +11:00
										 |  |  | /* ******** Mix Overlay Operation ******** */ | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixOverlayOperation::MixOverlayOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixOverlayOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                               float x, | 
					
						
							|  |  |  |                                               float y, | 
					
						
							|  |  |  |                                               PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   float valuem = 1.0f - value; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (inputColor1[0] < 0.5f) { | 
					
						
							|  |  |  |     output[0] = inputColor1[0] * (valuem + 2.0f * value * inputColor2[0]); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     output[0] = 1.0f - (valuem + 2.0f * value * (1.0f - inputColor2[0])) * (1.0f - inputColor1[0]); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (inputColor1[1] < 0.5f) { | 
					
						
							|  |  |  |     output[1] = inputColor1[1] * (valuem + 2.0f * value * inputColor2[1]); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     output[1] = 1.0f - (valuem + 2.0f * value * (1.0f - inputColor2[1])) * (1.0f - inputColor1[1]); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (inputColor1[2] < 0.5f) { | 
					
						
							|  |  |  |     output[2] = inputColor1[2] * (valuem + 2.0f * value * inputColor2[2]); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     output[2] = 1.0f - (valuem + 2.0f * value * (1.0f - inputColor2[2])) * (1.0f - inputColor1[2]); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Saturation Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixSaturationOperation::MixSaturationOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixSaturationOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                                  float x, | 
					
						
							|  |  |  |                                                  float y, | 
					
						
							|  |  |  |                                                  PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   float valuem = 1.0f - value; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   float rH, rS, rV; | 
					
						
							|  |  |  |   rgb_to_hsv(inputColor1[0], inputColor1[1], inputColor1[2], &rH, &rS, &rV); | 
					
						
							|  |  |  |   if (rS != 0.0f) { | 
					
						
							|  |  |  |     float colH, colS, colV; | 
					
						
							|  |  |  |     rgb_to_hsv(inputColor2[0], inputColor2[1], inputColor2[2], &colH, &colS, &colV); | 
					
						
							|  |  |  |     hsv_to_rgb(rH, (valuem * rS + value * colS), rV, &output[0], &output[1], &output[2]); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     copy_v3_v3(output, inputColor1); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Screen Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixScreenOperation::MixScreenOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixScreenOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                              float x, | 
					
						
							|  |  |  |                                              float y, | 
					
						
							|  |  |  |                                              PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   float valuem = 1.0f - value; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   output[0] = 1.0f - (valuem + value * (1.0f - inputColor2[0])) * (1.0f - inputColor1[0]); | 
					
						
							|  |  |  |   output[1] = 1.0f - (valuem + value * (1.0f - inputColor2[1])) * (1.0f - inputColor1[1]); | 
					
						
							|  |  |  |   output[2] = 1.0f - (valuem + value * (1.0f - inputColor2[2])) * (1.0f - inputColor1[2]); | 
					
						
							|  |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Soft Light Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixSoftLightOperation::MixSoftLightOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixSoftLightOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                                 float x, | 
					
						
							|  |  |  |                                                 float y, | 
					
						
							|  |  |  |                                                 PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   float valuem = 1.0f - value; | 
					
						
							|  |  |  |   float scr, scg, scb; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* first calculate non-fac based Screen mix */ | 
					
						
							|  |  |  |   scr = 1.0f - (1.0f - inputColor2[0]) * (1.0f - inputColor1[0]); | 
					
						
							|  |  |  |   scg = 1.0f - (1.0f - inputColor2[1]) * (1.0f - inputColor1[1]); | 
					
						
							|  |  |  |   scb = 1.0f - (1.0f - inputColor2[2]) * (1.0f - inputColor1[2]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   output[0] = valuem * (inputColor1[0]) + | 
					
						
							|  |  |  |               value * (((1.0f - inputColor1[0]) * inputColor2[0] * (inputColor1[0])) + | 
					
						
							|  |  |  |                        (inputColor1[0] * scr)); | 
					
						
							|  |  |  |   output[1] = valuem * (inputColor1[1]) + | 
					
						
							|  |  |  |               value * (((1.0f - inputColor1[1]) * inputColor2[1] * (inputColor1[1])) + | 
					
						
							|  |  |  |                        (inputColor1[1] * scg)); | 
					
						
							|  |  |  |   output[2] = valuem * (inputColor1[2]) + | 
					
						
							|  |  |  |               value * (((1.0f - inputColor1[2]) * inputColor2[2] * (inputColor1[2])) + | 
					
						
							|  |  |  |                        (inputColor1[2] * scb)); | 
					
						
							|  |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Subtract Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixSubtractOperation::MixSubtractOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixSubtractOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                                float x, | 
					
						
							|  |  |  |                                                float y, | 
					
						
							|  |  |  |                                                PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   output[0] = inputColor1[0] - value * (inputColor2[0]); | 
					
						
							|  |  |  |   output[1] = inputColor1[1] - value * (inputColor2[1]); | 
					
						
							|  |  |  |   output[2] = inputColor1[2] - value * (inputColor2[2]); | 
					
						
							|  |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ******** Mix Value Operation ******** */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 15:58:58 +02:00
										 |  |  | MixValueOperation::MixValueOperation() | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   /* pass */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  | void MixValueOperation::executePixelSampled(float output[4], | 
					
						
							|  |  |  |                                             float x, | 
					
						
							|  |  |  |                                             float y, | 
					
						
							|  |  |  |                                             PixelSampler sampler) | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   float inputColor1[4]; | 
					
						
							|  |  |  |   float inputColor2[4]; | 
					
						
							|  |  |  |   float inputValue[4]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-19 11:06:16 +01:00
										 |  |  |   this->m_inputValueOperation->readSampled(inputValue, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor1Operation->readSampled(inputColor1, x, y, sampler); | 
					
						
							|  |  |  |   this->m_inputColor2Operation->readSampled(inputColor2, x, y, sampler); | 
					
						
							| 
									
										
										
										
											2013-09-05 09:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   float value = inputValue[0]; | 
					
						
							|  |  |  |   if (this->useValueAlphaMultiply()) { | 
					
						
							|  |  |  |     value *= inputColor2[3]; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   float valuem = 1.0f - value; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   float rH, rS, rV; | 
					
						
							|  |  |  |   float colH, colS, colV; | 
					
						
							|  |  |  |   rgb_to_hsv(inputColor1[0], inputColor1[1], inputColor1[2], &rH, &rS, &rV); | 
					
						
							|  |  |  |   rgb_to_hsv(inputColor2[0], inputColor2[1], inputColor2[2], &colH, &colS, &colV); | 
					
						
							|  |  |  |   hsv_to_rgb(rH, rS, (valuem * rV + value * colV), &output[0], &output[1], &output[2]); | 
					
						
							|  |  |  |   output[3] = inputColor1[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   clampIfNeeded(output); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2021-03-23 17:12:27 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | }  // namespace blender::compositor
 |