diff options
Diffstat (limited to 'src/core/ScanlineHelper.cpp')
-rw-r--r-- | src/core/ScanlineHelper.cpp | 123 |
1 files changed, 123 insertions, 0 deletions
diff --git a/src/core/ScanlineHelper.cpp b/src/core/ScanlineHelper.cpp new file mode 100644 index 0000000..b090ae7 --- /dev/null +++ b/src/core/ScanlineHelper.cpp @@ -0,0 +1,123 @@ +/* +Copyright (c) 2003-2010 Sony Pictures Imageworks Inc., et al. +All Rights Reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are +met: +* Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. +* Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. +* Neither the name of Sony Pictures Imageworks nor the names of its + contributors may be used to endorse or promote products derived from + this software without specific prior written permission. +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +*/ + +#include <OpenColorIO/OpenColorIO.h> +#include "ScanlineHelper.h" + +#include <cassert> +#include <cstdlib> +#include <sstream> + +OCIO_NAMESPACE_ENTER +{ + namespace + { + const int PIXELS_PER_LINE = 4096; + } + + //////////////////////////////////////////////////////////////////////////// + + ScanlineHelper::ScanlineHelper(ImageDesc& img): + m_buffer(0), + m_imagePixelIndex(0), + m_numPixelsCopied(0), + m_yIndex(0), + m_inPlaceMode(false) + { + m_img.init(img); + + if(m_img.isPackedRGBA()) + { + m_inPlaceMode = true; + } + else + { + // TODO: Re-use memory from thread-safe memory pool, rather + // than doing a new allocation each time. + + m_buffer = (float*)malloc(sizeof(float)*PIXELS_PER_LINE*4); + } + } + + ScanlineHelper::~ScanlineHelper() + { + free(m_buffer); + } + + // Copy from the src image to our scanline, in our preferred + // pixel layout. + + void ScanlineHelper::prepRGBAScanline(float** buffer, long* numPixels) + { + if(m_inPlaceMode) + { + // TODO: what if scanline is too short, or too long? + if(m_yIndex >= m_img.height) + { + *numPixels = 0; + return; + } + + char* rowPtr = reinterpret_cast<char*>(m_img.rData); + rowPtr += m_img.yStrideBytes*m_yIndex; + + *buffer = reinterpret_cast<float*>(rowPtr); + *numPixels = m_img.width; + } + else + { + PackRGBAFromImageDesc(m_img, m_buffer, + &m_numPixelsCopied, + PIXELS_PER_LINE, + m_imagePixelIndex); + *buffer = m_buffer; + *numPixels = m_numPixelsCopied; + } + } + + // Write back the result of our work, from the scanline to our + // destination image. + + void ScanlineHelper::finishRGBAScanline() + { + if(m_inPlaceMode) + { + m_yIndex += 1; + } + else + { + UnpackRGBAToImageDesc(m_img, + m_buffer, + m_numPixelsCopied, + m_imagePixelIndex); + m_imagePixelIndex += m_numPixelsCopied; + } + } + +} +OCIO_NAMESPACE_EXIT |