Blame IlmImfUtil/ImfImageLevel.cpp

Packit 0d464f
///////////////////////////////////////////////////////////////////////////
Packit 0d464f
//
Packit 0d464f
// Copyright (c) 2014, Industrial Light & Magic, a division of Lucas
Packit 0d464f
// Digital Ltd. LLC
Packit 0d464f
// 
Packit 0d464f
// All rights reserved.
Packit 0d464f
// 
Packit 0d464f
// Redistribution and use in source and binary forms, with or without
Packit 0d464f
// modification, are permitted provided that the following conditions are
Packit 0d464f
// met:
Packit 0d464f
// *       Redistributions of source code must retain the above copyright
Packit 0d464f
// notice, this list of conditions and the following disclaimer.
Packit 0d464f
// *       Redistributions in binary form must reproduce the above
Packit 0d464f
// copyright notice, this list of conditions and the following disclaimer
Packit 0d464f
// in the documentation and/or other materials provided with the
Packit 0d464f
// distribution.
Packit 0d464f
// *       Neither the name of Industrial Light & Magic nor the names of
Packit 0d464f
// its contributors may be used to endorse or promote products derived
Packit 0d464f
// from this software without specific prior written permission. 
Packit 0d464f
// 
Packit 0d464f
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
Packit 0d464f
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
Packit 0d464f
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
Packit 0d464f
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
Packit 0d464f
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
Packit 0d464f
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
Packit 0d464f
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
Packit 0d464f
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
Packit 0d464f
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
Packit 0d464f
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
Packit 0d464f
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Packit 0d464f
//
Packit 0d464f
///////////////////////////////////////////////////////////////////////////
Packit 0d464f
Packit 0d464f
//----------------------------------------------------------------------------
Packit 0d464f
//
Packit 0d464f
//      class ImageLevel
Packit 0d464f
//
Packit 0d464f
//----------------------------------------------------------------------------
Packit 0d464f
Packit 0d464f
#include "ImfImageLevel.h"
Packit 0d464f
#include <Iex.h>
Packit 0d464f
#include <cassert>
Packit 0d464f
Packit 0d464f
using namespace IMATH_NAMESPACE;
Packit 0d464f
using namespace IEX_NAMESPACE;
Packit 0d464f
using namespace std;
Packit 0d464f
Packit 0d464f
OPENEXR_IMF_INTERNAL_NAMESPACE_SOURCE_ENTER
Packit 0d464f
Packit 0d464f
Packit 0d464f
ImageLevel::ImageLevel
Packit 0d464f
    (Image& image,
Packit 0d464f
     int xLevelNumber,
Packit 0d464f
     int yLevelNumber)
Packit 0d464f
:
Packit 0d464f
    _image (image),
Packit 0d464f
    _xLevelNumber (xLevelNumber),
Packit 0d464f
    _yLevelNumber (yLevelNumber),
Packit 0d464f
    _dataWindow (Box2i (V2i (0, 0), V2i (-1, -1)))
Packit 0d464f
{
Packit 0d464f
    // empty
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
ImageLevel::~ImageLevel ()
Packit 0d464f
{
Packit 0d464f
    // empty
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void			
Packit 0d464f
ImageLevel::resize (const Imath::Box2i& dataWindow)
Packit 0d464f
{
Packit 0d464f
    if (dataWindow.max.x < dataWindow.min.x - 1||
Packit 0d464f
        dataWindow.max.y < dataWindow.min.y - 1)
Packit 0d464f
    {
Packit 0d464f
        THROW (ArgExc,
Packit 0d464f
               "Cannot reset data window for image level to "
Packit 0d464f
               "(" << dataWindow.min.x << ", " << dataWindow.min.y << ") - "
Packit 0d464f
               "(" << dataWindow.max.x << ", " << dataWindow.max.y << "). "
Packit 0d464f
               "The new data window is invalid.");
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    _dataWindow = dataWindow;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
ImageLevel::shiftPixels (int dx, int dy)
Packit 0d464f
{
Packit 0d464f
    _dataWindow.min.x += dx;
Packit 0d464f
    _dataWindow.min.y += dy;
Packit 0d464f
    _dataWindow.max.x += dx;
Packit 0d464f
    _dataWindow.max.y += dy;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
ImageLevel::throwChannelExists (const string& name) const
Packit 0d464f
{
Packit 0d464f
    THROW (ArgExc, "Cannot insert a new image channel with "
Packit 0d464f
                   "name \"" << name << "\" into an image level. "
Packit 0d464f
                   "A channel with the same name exists already.");
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
ImageLevel::throwBadChannelName (const string& name) const
Packit 0d464f
{
Packit 0d464f
    THROW (ArgExc, "Attempt to access non-existent "
Packit 0d464f
                   "image channel \"" << name << "\".");
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
ImageLevel::throwBadChannelNameOrType (const string& name) const
Packit 0d464f
{
Packit 0d464f
    THROW (ArgExc, "Image channel \"" << name << "\" does not exist "
Packit 0d464f
                   "or is not of the expected type.");
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
OPENEXR_IMF_INTERNAL_NAMESPACE_SOURCE_EXIT