diff options
author | Campbell Barton <ideasman42@gmail.com> | 2019-04-17 07:17:24 +0300 |
---|---|---|
committer | Campbell Barton <ideasman42@gmail.com> | 2019-04-17 07:21:24 +0300 |
commit | e12c08e8d170b7ca40f204a5b0423c23a9fbc2c1 (patch) | |
tree | 8cf3453d12edb177a218ef8009357518ec6cab6a /source/blender/compositor/operations/COM_KeyingClipOperation.cpp | |
parent | b3dabc200a4b0399ec6b81f2ff2730d07b44fcaa (diff) |
ClangFormat: apply to source, most of intern
Apply clang format as proposed in T53211.
For details on usage and instructions for migrating branches
without conflicts, see:
https://wiki.blender.org/wiki/Tools/ClangFormat
Diffstat (limited to 'source/blender/compositor/operations/COM_KeyingClipOperation.cpp')
-rw-r--r-- | source/blender/compositor/operations/COM_KeyingClipOperation.cpp | 155 |
1 files changed, 78 insertions, 77 deletions
diff --git a/source/blender/compositor/operations/COM_KeyingClipOperation.cpp b/source/blender/compositor/operations/COM_KeyingClipOperation.cpp index f4600c753ba..89fa8a8d303 100644 --- a/source/blender/compositor/operations/COM_KeyingClipOperation.cpp +++ b/source/blender/compositor/operations/COM_KeyingClipOperation.cpp @@ -25,99 +25,100 @@ KeyingClipOperation::KeyingClipOperation() : NodeOperation() { - this->addInputSocket(COM_DT_VALUE); - this->addOutputSocket(COM_DT_VALUE); + this->addInputSocket(COM_DT_VALUE); + this->addOutputSocket(COM_DT_VALUE); - this->m_kernelRadius = 3; - this->m_kernelTolerance = 0.1f; + this->m_kernelRadius = 3; + this->m_kernelTolerance = 0.1f; - this->m_clipBlack = 0.0f; - this->m_clipWhite = 1.0f; + this->m_clipBlack = 0.0f; + this->m_clipWhite = 1.0f; - this->m_isEdgeMatte = false; + this->m_isEdgeMatte = false; - this->setComplex(true); + this->setComplex(true); } void *KeyingClipOperation::initializeTileData(rcti *rect) { - void *buffer = getInputOperation(0)->initializeTileData(rect); + void *buffer = getInputOperation(0)->initializeTileData(rect); - return buffer; + return buffer; } void KeyingClipOperation::executePixel(float output[4], int x, int y, void *data) { - const int delta = this->m_kernelRadius; - const float tolerance = this->m_kernelTolerance; - - MemoryBuffer *inputBuffer = (MemoryBuffer *)data; - float *buffer = inputBuffer->getBuffer(); - - int bufferWidth = inputBuffer->getWidth(); - int bufferHeight = inputBuffer->getHeight(); - - float value = buffer[(y * bufferWidth + x)]; - - bool ok = false; - int start_x = max_ff(0, x - delta + 1), - start_y = max_ff(0, y - delta + 1), - end_x = min_ff(x + delta - 1, bufferWidth - 1), - end_y = min_ff(y + delta - 1, bufferHeight - 1); - - int count = 0, totalCount = (end_x - start_x + 1) * (end_y - start_y + 1) - 1; - int thresholdCount = ceil((float) totalCount * 0.9f); - - if (delta == 0) { - ok = true; - } - - for (int cx = start_x; ok == false && cx <= end_x; ++cx) { - for (int cy = start_y; ok == false && cy <= end_y; ++cy) { - if (UNLIKELY(cx == x && cy == y)) { - continue; - } - - int bufferIndex = (cy * bufferWidth + cx); - float currentValue = buffer[bufferIndex]; - - if (fabsf(currentValue - value) < tolerance) { - count++; - if (count >= thresholdCount) { - ok = true; - } - } - } - } - - if (this->m_isEdgeMatte) { - if (ok) - output[0] = 0.0f; - else - output[0] = 1.0f; - } - else { - output[0] = value; - - if (ok) { - if (output[0] < this->m_clipBlack) - output[0] = 0.0f; - else if (output[0] >= this->m_clipWhite) - output[0] = 1.0f; - else - output[0] = (output[0] - this->m_clipBlack) / (this->m_clipWhite - this->m_clipBlack); - } - } + const int delta = this->m_kernelRadius; + const float tolerance = this->m_kernelTolerance; + + MemoryBuffer *inputBuffer = (MemoryBuffer *)data; + float *buffer = inputBuffer->getBuffer(); + + int bufferWidth = inputBuffer->getWidth(); + int bufferHeight = inputBuffer->getHeight(); + + float value = buffer[(y * bufferWidth + x)]; + + bool ok = false; + int start_x = max_ff(0, x - delta + 1), start_y = max_ff(0, y - delta + 1), + end_x = min_ff(x + delta - 1, bufferWidth - 1), + end_y = min_ff(y + delta - 1, bufferHeight - 1); + + int count = 0, totalCount = (end_x - start_x + 1) * (end_y - start_y + 1) - 1; + int thresholdCount = ceil((float)totalCount * 0.9f); + + if (delta == 0) { + ok = true; + } + + for (int cx = start_x; ok == false && cx <= end_x; ++cx) { + for (int cy = start_y; ok == false && cy <= end_y; ++cy) { + if (UNLIKELY(cx == x && cy == y)) { + continue; + } + + int bufferIndex = (cy * bufferWidth + cx); + float currentValue = buffer[bufferIndex]; + + if (fabsf(currentValue - value) < tolerance) { + count++; + if (count >= thresholdCount) { + ok = true; + } + } + } + } + + if (this->m_isEdgeMatte) { + if (ok) + output[0] = 0.0f; + else + output[0] = 1.0f; + } + else { + output[0] = value; + + if (ok) { + if (output[0] < this->m_clipBlack) + output[0] = 0.0f; + else if (output[0] >= this->m_clipWhite) + output[0] = 1.0f; + else + output[0] = (output[0] - this->m_clipBlack) / (this->m_clipWhite - this->m_clipBlack); + } + } } -bool KeyingClipOperation::determineDependingAreaOfInterest(rcti *input, ReadBufferOperation *readOperation, rcti *output) +bool KeyingClipOperation::determineDependingAreaOfInterest(rcti *input, + ReadBufferOperation *readOperation, + rcti *output) { - rcti newInput; + rcti newInput; - newInput.xmin = input->xmin - this->m_kernelRadius; - newInput.ymin = input->ymin - this->m_kernelRadius; - newInput.xmax = input->xmax + this->m_kernelRadius; - newInput.ymax = input->ymax + this->m_kernelRadius; + newInput.xmin = input->xmin - this->m_kernelRadius; + newInput.ymin = input->ymin - this->m_kernelRadius; + newInput.xmax = input->xmax + this->m_kernelRadius; + newInput.ymax = input->ymax + this->m_kernelRadius; - return NodeOperation::determineDependingAreaOfInterest(&newInput, readOperation, output); + return NodeOperation::determineDependingAreaOfInterest(&newInput, readOperation, output); } |