Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'source/blender/compositor/nodes/COM_DistanceMatteNode.cpp')
-rw-r--r--source/blender/compositor/nodes/COM_DistanceMatteNode.cpp133
1 files changed, 67 insertions, 66 deletions
diff --git a/source/blender/compositor/nodes/COM_DistanceMatteNode.cpp b/source/blender/compositor/nodes/COM_DistanceMatteNode.cpp
index 3c1e73da148..5f001f723e8 100644
--- a/source/blender/compositor/nodes/COM_DistanceMatteNode.cpp
+++ b/source/blender/compositor/nodes/COM_DistanceMatteNode.cpp
@@ -25,73 +25,74 @@
DistanceMatteNode::DistanceMatteNode(bNode *editorNode) : Node(editorNode)
{
- /* pass */
+ /* pass */
}
-void DistanceMatteNode::convertToOperations(NodeConverter &converter, const CompositorContext &/*context*/) const
+void DistanceMatteNode::convertToOperations(NodeConverter &converter,
+ const CompositorContext & /*context*/) const
{
- bNode *editorsnode = getbNode();
- NodeChroma *storage = (NodeChroma *)editorsnode->storage;
-
- NodeInput *inputSocketImage = this->getInputSocket(0);
- NodeInput *inputSocketKey = this->getInputSocket(1);
- NodeOutput *outputSocketImage = this->getOutputSocket(0);
- NodeOutput *outputSocketMatte = this->getOutputSocket(1);
-
- SetAlphaOperation *operationAlpha = new SetAlphaOperation();
- converter.addOperation(operationAlpha);
-
- /* work in RGB color space */
- NodeOperation *operation;
- if (storage->channel == 1) {
- DistanceRGBMatteOperation *matte = new DistanceRGBMatteOperation();
- matte->setSettings(storage);
- converter.addOperation(matte);
-
- converter.mapInputSocket(inputSocketImage, matte->getInputSocket(0));
- converter.mapInputSocket(inputSocketImage, operationAlpha->getInputSocket(0));
-
- converter.mapInputSocket(inputSocketKey, matte->getInputSocket(1));
-
- operation = matte;
- }
- /* work in YCbCr color space */
- else {
- DistanceYCCMatteOperation *matte = new DistanceYCCMatteOperation();
- matte->setSettings(storage);
- converter.addOperation(matte);
-
- ConvertRGBToYCCOperation *operationYCCImage = new ConvertRGBToYCCOperation();
- ConvertRGBToYCCOperation *operationYCCMatte = new ConvertRGBToYCCOperation();
- operationYCCImage->setMode(BLI_YCC_ITU_BT709);
- operationYCCMatte->setMode(BLI_YCC_ITU_BT709);
- converter.addOperation(operationYCCImage);
- converter.addOperation(operationYCCMatte);
-
- converter.mapInputSocket(inputSocketImage, operationYCCImage->getInputSocket(0));
- converter.addLink(operationYCCImage->getOutputSocket(), matte->getInputSocket(0));
- converter.addLink(operationYCCImage->getOutputSocket(), operationAlpha->getInputSocket(0));
-
- converter.mapInputSocket(inputSocketKey, operationYCCMatte->getInputSocket(0));
- converter.addLink(operationYCCMatte->getOutputSocket(), matte->getInputSocket(1));
-
- operation = matte;
- }
-
- converter.mapOutputSocket(outputSocketMatte, operation->getOutputSocket(0));
- converter.addLink(operation->getOutputSocket(), operationAlpha->getInputSocket(1));
-
- if (storage->channel != 1) {
- ConvertYCCToRGBOperation *inv_convert = new ConvertYCCToRGBOperation();
- inv_convert->setMode(BLI_YCC_ITU_BT709);
-
- converter.addOperation(inv_convert);
- converter.addLink(operationAlpha->getOutputSocket(0), inv_convert->getInputSocket(0));
- converter.mapOutputSocket(outputSocketImage, inv_convert->getOutputSocket());
- converter.addPreview(inv_convert->getOutputSocket());
- }
- else {
- converter.mapOutputSocket(outputSocketImage, operationAlpha->getOutputSocket());
- converter.addPreview(operationAlpha->getOutputSocket());
- }
+ bNode *editorsnode = getbNode();
+ NodeChroma *storage = (NodeChroma *)editorsnode->storage;
+
+ NodeInput *inputSocketImage = this->getInputSocket(0);
+ NodeInput *inputSocketKey = this->getInputSocket(1);
+ NodeOutput *outputSocketImage = this->getOutputSocket(0);
+ NodeOutput *outputSocketMatte = this->getOutputSocket(1);
+
+ SetAlphaOperation *operationAlpha = new SetAlphaOperation();
+ converter.addOperation(operationAlpha);
+
+ /* work in RGB color space */
+ NodeOperation *operation;
+ if (storage->channel == 1) {
+ DistanceRGBMatteOperation *matte = new DistanceRGBMatteOperation();
+ matte->setSettings(storage);
+ converter.addOperation(matte);
+
+ converter.mapInputSocket(inputSocketImage, matte->getInputSocket(0));
+ converter.mapInputSocket(inputSocketImage, operationAlpha->getInputSocket(0));
+
+ converter.mapInputSocket(inputSocketKey, matte->getInputSocket(1));
+
+ operation = matte;
+ }
+ /* work in YCbCr color space */
+ else {
+ DistanceYCCMatteOperation *matte = new DistanceYCCMatteOperation();
+ matte->setSettings(storage);
+ converter.addOperation(matte);
+
+ ConvertRGBToYCCOperation *operationYCCImage = new ConvertRGBToYCCOperation();
+ ConvertRGBToYCCOperation *operationYCCMatte = new ConvertRGBToYCCOperation();
+ operationYCCImage->setMode(BLI_YCC_ITU_BT709);
+ operationYCCMatte->setMode(BLI_YCC_ITU_BT709);
+ converter.addOperation(operationYCCImage);
+ converter.addOperation(operationYCCMatte);
+
+ converter.mapInputSocket(inputSocketImage, operationYCCImage->getInputSocket(0));
+ converter.addLink(operationYCCImage->getOutputSocket(), matte->getInputSocket(0));
+ converter.addLink(operationYCCImage->getOutputSocket(), operationAlpha->getInputSocket(0));
+
+ converter.mapInputSocket(inputSocketKey, operationYCCMatte->getInputSocket(0));
+ converter.addLink(operationYCCMatte->getOutputSocket(), matte->getInputSocket(1));
+
+ operation = matte;
+ }
+
+ converter.mapOutputSocket(outputSocketMatte, operation->getOutputSocket(0));
+ converter.addLink(operation->getOutputSocket(), operationAlpha->getInputSocket(1));
+
+ if (storage->channel != 1) {
+ ConvertYCCToRGBOperation *inv_convert = new ConvertYCCToRGBOperation();
+ inv_convert->setMode(BLI_YCC_ITU_BT709);
+
+ converter.addOperation(inv_convert);
+ converter.addLink(operationAlpha->getOutputSocket(0), inv_convert->getInputSocket(0));
+ converter.mapOutputSocket(outputSocketImage, inv_convert->getOutputSocket());
+ converter.addPreview(inv_convert->getOutputSocket());
+ }
+ else {
+ converter.mapOutputSocket(outputSocketImage, operationAlpha->getOutputSocket());
+ converter.addPreview(operationAlpha->getOutputSocket());
+ }
}