2
* Copyright 2011, Blender Foundation.
4
* This program is free software; you can redistribute it and/or
5
* modify it under the terms of the GNU General Public License
6
* as published by the Free Software Foundation; either version 2
7
* of the License, or (at your option) any later version.
9
* This program is distributed in the hope that it will be useful,
10
* but WITHOUT ANY WARRANTY; without even the implied warranty of
11
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12
* GNU General Public License for more details.
14
* You should have received a copy of the GNU General Public License
15
* along with this program; if not, write to the Free Software Foundation,
16
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
22
#include "COM_ConvertRGBToYCCOperation.h"
23
#include "BLI_math_color.h"
25
ConvertRGBToYCCOperation::ConvertRGBToYCCOperation() : NodeOperation()
27
this->addInputSocket(COM_DT_COLOR);
28
this->addOutputSocket(COM_DT_COLOR);
29
this->m_inputOperation = NULL;
32
void ConvertRGBToYCCOperation::initExecution()
34
this->m_inputOperation = this->getInputSocketReader(0);
37
void ConvertRGBToYCCOperation::setMode(int mode)
41
this->m_mode = BLI_YCC_ITU_BT709;
44
this->m_mode = BLI_YCC_JFIF_0_255;
48
this->m_mode = BLI_YCC_ITU_BT601;
53
void ConvertRGBToYCCOperation::executePixel(float output[4], float x, float y, PixelSampler sampler)
58
this->m_inputOperation->read(inputColor, x, y, sampler);
59
rgb_to_ycc(inputColor[0], inputColor[1], inputColor[2], &color[0], &color[1], &color[2], this->m_mode);
61
/* divided by 255 to normalize for viewing in */
62
/* R,G,B --> Y,Cb,Cr */
63
mul_v3_v3fl(output, color, 1.0f / 255.0f);
64
output[3] = inputColor[3];
67
void ConvertRGBToYCCOperation::deinitExecution()
69
this->m_inputOperation = NULL;