|
Packit |
c2c737 |
///////////////////////////////////////////////////////////////////////////
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// Copyright (c) 2004, Industrial Light & Magic, a division of Lucas
|
|
Packit |
c2c737 |
// Digital Ltd. LLC
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// All rights reserved.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// Redistribution and use in source and binary forms, with or without
|
|
Packit |
c2c737 |
// modification, are permitted provided that the following conditions are
|
|
Packit |
c2c737 |
// met:
|
|
Packit |
c2c737 |
// * Redistributions of source code must retain the above copyright
|
|
Packit |
c2c737 |
// notice, this list of conditions and the following disclaimer.
|
|
Packit |
c2c737 |
// * Redistributions in binary form must reproduce the above
|
|
Packit |
c2c737 |
// copyright notice, this list of conditions and the following disclaimer
|
|
Packit |
c2c737 |
// in the documentation and/or other materials provided with the
|
|
Packit |
c2c737 |
// distribution.
|
|
Packit |
c2c737 |
// * Neither the name of Industrial Light & Magic nor the names of
|
|
Packit |
c2c737 |
// its contributors may be used to endorse or promote products derived
|
|
Packit |
c2c737 |
// from this software without specific prior written permission.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
Packit |
c2c737 |
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
Packit |
c2c737 |
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
Packit |
c2c737 |
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
Packit |
c2c737 |
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
Packit |
c2c737 |
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
Packit |
c2c737 |
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
Packit |
c2c737 |
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
Packit |
c2c737 |
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
Packit |
c2c737 |
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
Packit |
c2c737 |
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
///////////////////////////////////////////////////////////////////////////
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
#ifndef INCLUDED_IMF_HEADER_H
|
|
Packit |
c2c737 |
#define INCLUDED_IMF_HEADER_H
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//-----------------------------------------------------------------------------
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// class Header
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
//-----------------------------------------------------------------------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
#include "ImfLineOrder.h"
|
|
Packit |
c2c737 |
#include "ImfCompression.h"
|
|
Packit |
c2c737 |
#include "ImfName.h"
|
|
Packit |
c2c737 |
#include "ImfTileDescription.h"
|
|
Packit |
c2c737 |
#include "ImfInt64.h"
|
|
Packit |
c2c737 |
#include "ImathVec.h"
|
|
Packit |
c2c737 |
#include "ImathBox.h"
|
|
Packit |
c2c737 |
#include "IexBaseExc.h"
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
#include "ImfForward.h"
|
|
Packit |
c2c737 |
#include "ImfNamespace.h"
|
|
Packit |
c2c737 |
#include "ImfExport.h"
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
#include <map>
|
|
Packit |
c2c737 |
#include <iosfwd>
|
|
Packit |
c2c737 |
#include <string>
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
OPENEXR_IMF_INTERNAL_NAMESPACE_HEADER_ENTER
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
using std::string;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
class IMF_EXPORT Header
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
public:
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//----------------------------------------------------------------
|
|
Packit |
c2c737 |
// Default constructor -- the display window and the data window
|
|
Packit |
c2c737 |
// are both set to Box2i (V2i (0, 0), V2i (width-1, height-1).
|
|
Packit |
c2c737 |
//----------------------------------------------------------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Header (int width = 64,
|
|
Packit |
c2c737 |
int height = 64,
|
|
Packit |
c2c737 |
float pixelAspectRatio = 1,
|
|
Packit |
c2c737 |
const IMATH_NAMESPACE::V2f &screenWindowCenter = IMATH_NAMESPACE::V2f (0, 0),
|
|
Packit |
c2c737 |
float screenWindowWidth = 1,
|
|
Packit |
c2c737 |
LineOrder lineOrder = INCREASING_Y,
|
|
Packit |
c2c737 |
Compression = ZIP_COMPRESSION);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//--------------------------------------------------------------------
|
|
Packit |
c2c737 |
// Constructor -- the data window is specified explicitly; the display
|
|
Packit |
c2c737 |
// window is set to Box2i (V2i (0, 0), V2i (width-1, height-1).
|
|
Packit |
c2c737 |
//--------------------------------------------------------------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Header (int width,
|
|
Packit |
c2c737 |
int height,
|
|
Packit |
c2c737 |
const IMATH_NAMESPACE::Box2i &dataWindow,
|
|
Packit |
c2c737 |
float pixelAspectRatio = 1,
|
|
Packit |
c2c737 |
const IMATH_NAMESPACE::V2f &screenWindowCenter = IMATH_NAMESPACE::V2f (0, 0),
|
|
Packit |
c2c737 |
float screenWindowWidth = 1,
|
|
Packit |
c2c737 |
LineOrder lineOrder = INCREASING_Y,
|
|
Packit |
c2c737 |
Compression = ZIP_COMPRESSION);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//----------------------------------------------------------
|
|
Packit |
c2c737 |
// Constructor -- the display window and the data window are
|
|
Packit |
c2c737 |
// both specified explicitly.
|
|
Packit |
c2c737 |
//----------------------------------------------------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Header (const IMATH_NAMESPACE::Box2i &displayWindow,
|
|
Packit |
c2c737 |
const IMATH_NAMESPACE::Box2i &dataWindow,
|
|
Packit |
c2c737 |
float pixelAspectRatio = 1,
|
|
Packit |
c2c737 |
const IMATH_NAMESPACE::V2f &screenWindowCenter = IMATH_NAMESPACE::V2f (0, 0),
|
|
Packit |
c2c737 |
float screenWindowWidth = 1,
|
|
Packit |
c2c737 |
LineOrder lineOrder = INCREASING_Y,
|
|
Packit |
c2c737 |
Compression = ZIP_COMPRESSION);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//-----------------
|
|
Packit |
c2c737 |
// Copy constructor
|
|
Packit |
c2c737 |
//-----------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Header (const Header &other);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//-----------
|
|
Packit |
c2c737 |
// Destructor
|
|
Packit |
c2c737 |
//-----------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
~Header ();
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//-----------
|
|
Packit |
c2c737 |
// Assignment
|
|
Packit |
c2c737 |
//-----------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Header & operator = (const Header &other);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//---------------------------------------------------------------
|
|
Packit |
c2c737 |
// Add an attribute:
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// insert(n,attr) If no attribute with name n exists, a new
|
|
Packit |
c2c737 |
// attribute with name n, and the same type as
|
|
Packit |
c2c737 |
// attr, is added, and the value of attr is
|
|
Packit |
c2c737 |
// copied into the new attribute.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// If an attribute with name n exists, and its
|
|
Packit |
c2c737 |
// type is the same as attr, the value of attr
|
|
Packit |
c2c737 |
// is copied into this attribute.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// If an attribute with name n exists, and its
|
|
Packit |
c2c737 |
// type is different from attr, an IEX_NAMESPACE::TypeExc
|
|
Packit |
c2c737 |
// is thrown.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
//---------------------------------------------------------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
void insert (const char name[],
|
|
Packit |
c2c737 |
const Attribute &attribute);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
void insert (const std::string &name,
|
|
Packit |
c2c737 |
const Attribute &attribute);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//---------------------------------------------------------------
|
|
Packit |
c2c737 |
// Remove an attribute:
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// remove(n) If an attribute with name n exists, then it
|
|
Packit |
c2c737 |
// is removed from the map of present attributes.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// If no attribute with name n exists, then this
|
|
Packit |
c2c737 |
// functions becomes a 'no-op'
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
//---------------------------------------------------------------
|
|
Packit |
c2c737 |
void erase (const char name[]);
|
|
Packit |
c2c737 |
void erase (const std::string &name);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//------------------------------------------------------------------
|
|
Packit |
c2c737 |
// Access to existing attributes:
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// [n] Returns a reference to the attribute
|
|
Packit |
c2c737 |
// with name n. If no attribute with
|
|
Packit |
c2c737 |
// name n exists, an IEX_NAMESPACE::ArgExc is thrown.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// typedAttribute<T>(n) Returns a reference to the attribute
|
|
Packit |
c2c737 |
// with name n and type T. If no attribute
|
|
Packit |
c2c737 |
// with name n exists, an IEX_NAMESPACE::ArgExc is
|
|
Packit |
c2c737 |
// thrown. If an attribute with name n
|
|
Packit |
c2c737 |
// exists, but its type is not T, an
|
|
Packit |
c2c737 |
// IEX_NAMESPACE::TypeExc is thrown.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// findTypedAttribute<T>(n) Returns a pointer to the attribute with
|
|
Packit |
c2c737 |
// name n and type T, or 0 if no attribute
|
|
Packit |
c2c737 |
// with name n and type T exists.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
//------------------------------------------------------------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Attribute & operator [] (const char name[]);
|
|
Packit |
c2c737 |
const Attribute & operator [] (const char name[]) const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Attribute & operator [] (const std::string &name);
|
|
Packit |
c2c737 |
const Attribute & operator [] (const std::string &name) const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
template <class T> T& typedAttribute (const char name[]);
|
|
Packit |
c2c737 |
template <class T> const T& typedAttribute (const char name[]) const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
template <class T> T& typedAttribute (const std::string &name);
|
|
Packit |
c2c737 |
template <class T> const T& typedAttribute (const std::string &name) const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
template <class T> T* findTypedAttribute (const char name[]);
|
|
Packit |
c2c737 |
template <class T> const T* findTypedAttribute (const char name[]) const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
template <class T> T* findTypedAttribute (const std::string &name);
|
|
Packit |
c2c737 |
template <class T> const T* findTypedAttribute (const std::string &name)
|
|
Packit |
c2c737 |
const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//---------------------------------------------
|
|
Packit |
c2c737 |
// Iterator-style access to existing attributes
|
|
Packit |
c2c737 |
//---------------------------------------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
typedef std::map <Name, Attribute *> AttributeMap;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
class Iterator;
|
|
Packit |
c2c737 |
class ConstIterator;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Iterator begin ();
|
|
Packit |
c2c737 |
ConstIterator begin () const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Iterator end ();
|
|
Packit |
c2c737 |
ConstIterator end () const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Iterator find (const char name[]);
|
|
Packit |
c2c737 |
ConstIterator find (const char name[]) const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Iterator find (const std::string &name);
|
|
Packit |
c2c737 |
ConstIterator find (const std::string &name) const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//--------------------------------
|
|
Packit |
c2c737 |
// Access to predefined attributes
|
|
Packit |
c2c737 |
//--------------------------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
IMATH_NAMESPACE::Box2i & displayWindow ();
|
|
Packit |
c2c737 |
const IMATH_NAMESPACE::Box2i & displayWindow () const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
IMATH_NAMESPACE::Box2i & dataWindow ();
|
|
Packit |
c2c737 |
const IMATH_NAMESPACE::Box2i & dataWindow () const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
float & pixelAspectRatio ();
|
|
Packit |
c2c737 |
const float & pixelAspectRatio () const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
IMATH_NAMESPACE::V2f & screenWindowCenter ();
|
|
Packit |
c2c737 |
const IMATH_NAMESPACE::V2f & screenWindowCenter () const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
float & screenWindowWidth ();
|
|
Packit |
c2c737 |
const float & screenWindowWidth () const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
ChannelList & channels ();
|
|
Packit |
c2c737 |
const ChannelList & channels () const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
LineOrder & lineOrder ();
|
|
Packit |
c2c737 |
const LineOrder & lineOrder () const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Compression & compression ();
|
|
Packit |
c2c737 |
const Compression & compression () const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//-----------------------------------------------------
|
|
Packit |
c2c737 |
// Access to required attributes for multipart files
|
|
Packit |
c2c737 |
// They are optional to non-multipart files and mandatory
|
|
Packit |
c2c737 |
// for multipart files.
|
|
Packit |
c2c737 |
//-----------------------------------------------------
|
|
Packit |
c2c737 |
void setName (const string& name);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
string& name();
|
|
Packit |
c2c737 |
const string& name() const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
bool hasName() const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
void setType (const string& Type);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
string& type();
|
|
Packit |
c2c737 |
const string& type() const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
bool hasType() const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
void setVersion (const int version);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
int& version();
|
|
Packit |
c2c737 |
const int& version() const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
bool hasVersion() const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// the chunkCount attribute is set automatically when a file is written.
|
|
Packit |
c2c737 |
// There is no need to set it manually
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
void setChunkCount(int chunks);
|
|
Packit |
c2c737 |
bool hasChunkCount() const;
|
|
Packit |
c2c737 |
const int & chunkCount() const;
|
|
Packit |
c2c737 |
int & chunkCount();
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// for multipart files, return whether the file has a view string attribute
|
|
Packit |
c2c737 |
// (for the deprecated single part multiview format EXR, see ImfMultiView.h)
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
void setView(const string & view);
|
|
Packit |
c2c737 |
bool hasView() const;
|
|
Packit |
c2c737 |
string & view();
|
|
Packit |
c2c737 |
const string & view() const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//----------------------------------------------------------------------
|
|
Packit |
c2c737 |
// Tile Description:
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// The tile description is a TileDescriptionAttribute whose name
|
|
Packit |
c2c737 |
// is "tiles". The "tiles" attribute must be present in any tiled
|
|
Packit |
c2c737 |
// image file. When present, it describes various properties of the
|
|
Packit |
c2c737 |
// tiles that make up the file.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// Convenience functions:
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// setTileDescription(td)
|
|
Packit |
c2c737 |
// calls insert ("tiles", TileDescriptionAttribute (td))
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// tileDescription()
|
|
Packit |
c2c737 |
// returns typedAttribute<TileDescriptionAttribute>("tiles").value()
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// hasTileDescription()
|
|
Packit |
c2c737 |
// return findTypedAttribute<TileDescriptionAttribute>("tiles") != 0
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
//----------------------------------------------------------------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
void setTileDescription (const TileDescription & td);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
TileDescription & tileDescription ();
|
|
Packit |
c2c737 |
const TileDescription & tileDescription () const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
bool hasTileDescription() const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//----------------------------------------------------------------------
|
|
Packit |
c2c737 |
// Preview image:
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// The preview image is a PreviewImageAttribute whose name is "preview".
|
|
Packit |
c2c737 |
// This attribute is special -- while an image file is being written,
|
|
Packit |
c2c737 |
// the pixels of the preview image can be changed repeatedly by calling
|
|
Packit |
c2c737 |
// OutputFile::updatePreviewImage().
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// Convenience functions:
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// setPreviewImage(p)
|
|
Packit |
c2c737 |
// calls insert ("preview", PreviewImageAttribute (p))
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// previewImage()
|
|
Packit |
c2c737 |
// returns typedAttribute<PreviewImageAttribute>("preview").value()
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// hasPreviewImage()
|
|
Packit |
c2c737 |
// return findTypedAttribute<PreviewImageAttribute>("preview") != 0
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
//----------------------------------------------------------------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
void setPreviewImage (const PreviewImage &p);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
PreviewImage & previewImage ();
|
|
Packit |
c2c737 |
const PreviewImage & previewImage () const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
bool hasPreviewImage () const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//-------------------------------------------------------------
|
|
Packit |
c2c737 |
// Sanity check -- examines the header, and throws an exception
|
|
Packit |
c2c737 |
// if it finds something wrong (empty display window, negative
|
|
Packit |
c2c737 |
// pixel aspect ratio, unknown compression sceme etc.)
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// set isTiled to true if you are checking a tiled/multi-res
|
|
Packit |
c2c737 |
// header
|
|
Packit |
c2c737 |
//-------------------------------------------------------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
void sanityCheck (bool isTiled = false,
|
|
Packit |
c2c737 |
bool isMultipartFile = false) const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//----------------------------------------------------------------
|
|
Packit |
c2c737 |
// Maximum image size and maximim tile size:
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// sanityCheck() will throw an exception if the width or height of
|
|
Packit |
c2c737 |
// the data window exceeds the maximum image width or height, or
|
|
Packit |
c2c737 |
// if the size of a tile exceeds the maximum tile width or height.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// At program startup the maximum image and tile width and height
|
|
Packit |
c2c737 |
// are set to zero, meaning that width and height are unlimited.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// Limiting image and tile width and height limits how much memory
|
|
Packit |
c2c737 |
// will be allocated when a file is opened. This can help protect
|
|
Packit |
c2c737 |
// applications from running out of memory while trying to read
|
|
Packit |
c2c737 |
// a damaged image file.
|
|
Packit |
c2c737 |
//----------------------------------------------------------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
static void setMaxImageSize (int maxWidth, int maxHeight);
|
|
Packit |
c2c737 |
static void setMaxTileSize (int maxWidth, int maxHeight);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// Check if the header reads nothing.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
bool readsNothing();
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//------------------------------------------------------------------
|
|
Packit |
c2c737 |
// Input and output:
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// If the header contains a preview image attribute, then writeTo()
|
|
Packit |
c2c737 |
// returns the position of that attribute in the output stream; this
|
|
Packit |
c2c737 |
// information is used by OutputFile::updatePreviewImage().
|
|
Packit |
c2c737 |
// If the header contains no preview image attribute, then writeTo()
|
|
Packit |
c2c737 |
// returns 0.
|
|
Packit |
c2c737 |
//------------------------------------------------------------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Int64 writeTo (OPENEXR_IMF_INTERNAL_NAMESPACE::OStream &os,
|
|
Packit |
c2c737 |
bool isTiled = false) const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
void readFrom (OPENEXR_IMF_INTERNAL_NAMESPACE::IStream &is,
|
|
Packit |
c2c737 |
int &version);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
private:
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
AttributeMap _map;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
bool _readsNothing;
|
|
Packit |
c2c737 |
};
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//----------
|
|
Packit |
c2c737 |
// Iterators
|
|
Packit |
c2c737 |
//----------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
class Header::Iterator
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
public:
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Iterator ();
|
|
Packit |
c2c737 |
Iterator (const Header::AttributeMap::iterator &i);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Iterator & operator ++ ();
|
|
Packit |
c2c737 |
Iterator operator ++ (int);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
const char * name () const;
|
|
Packit |
c2c737 |
Attribute & attribute () const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
private:
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
friend class Header::ConstIterator;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Header::AttributeMap::iterator _i;
|
|
Packit |
c2c737 |
};
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
class Header::ConstIterator
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
public:
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
ConstIterator ();
|
|
Packit |
c2c737 |
ConstIterator (const Header::AttributeMap::const_iterator &i);
|
|
Packit |
c2c737 |
ConstIterator (const Header::Iterator &other);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
ConstIterator & operator ++ ();
|
|
Packit |
c2c737 |
ConstIterator operator ++ (int);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
const char * name () const;
|
|
Packit |
c2c737 |
const Attribute & attribute () const;
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
private:
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
friend bool operator == (const ConstIterator &, const ConstIterator &);
|
|
Packit |
c2c737 |
friend bool operator != (const ConstIterator &, const ConstIterator &);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
Header::AttributeMap::const_iterator _i;
|
|
Packit |
c2c737 |
};
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//------------------------------------------------------------------------
|
|
Packit |
c2c737 |
// Library initialization:
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// In a multithreaded program, staticInitialize() must be called once
|
|
Packit |
c2c737 |
// during startup, before the program accesses any other functions or
|
|
Packit |
c2c737 |
// classes in the IlmImf library. Calling staticInitialize() in this
|
|
Packit |
c2c737 |
// way avoids races during initialization of the library's global
|
|
Packit |
c2c737 |
// variables.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
// Single-threaded programs are not required to call staticInitialize();
|
|
Packit |
c2c737 |
// initialization of the library's global variables happens automatically.
|
|
Packit |
c2c737 |
//
|
|
Packit |
c2c737 |
//------------------------------------------------------------------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
void staticInitialize ();
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//-----------------
|
|
Packit |
c2c737 |
// Inline Functions
|
|
Packit |
c2c737 |
//-----------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
inline
|
|
Packit |
c2c737 |
Header::Iterator::Iterator (): _i()
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
// empty
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
inline
|
|
Packit |
c2c737 |
Header::Iterator::Iterator (const Header::AttributeMap::iterator &i): _i (i)
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
// empty
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
inline Header::Iterator &
|
|
Packit |
c2c737 |
Header::Iterator::operator ++ ()
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
++_i;
|
|
Packit |
c2c737 |
return *this;
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
inline Header::Iterator
|
|
Packit |
c2c737 |
Header::Iterator::operator ++ (int)
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
Iterator tmp = *this;
|
|
Packit |
c2c737 |
++_i;
|
|
Packit |
c2c737 |
return tmp;
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
inline const char *
|
|
Packit |
c2c737 |
Header::Iterator::name () const
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
return *_i->first;
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
inline Attribute &
|
|
Packit |
c2c737 |
Header::Iterator::attribute () const
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
return *_i->second;
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
inline
|
|
Packit |
c2c737 |
Header::ConstIterator::ConstIterator (): _i()
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
// empty
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
inline
|
|
Packit |
c2c737 |
Header::ConstIterator::ConstIterator
|
|
Packit |
c2c737 |
(const Header::AttributeMap::const_iterator &i): _i (i)
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
// empty
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
inline
|
|
Packit |
c2c737 |
Header::ConstIterator::ConstIterator (const Header::Iterator &other):
|
|
Packit |
c2c737 |
_i (other._i)
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
// empty
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
inline Header::ConstIterator &
|
|
Packit |
c2c737 |
Header::ConstIterator::operator ++ ()
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
++_i;
|
|
Packit |
c2c737 |
return *this;
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
inline Header::ConstIterator
|
|
Packit |
c2c737 |
Header::ConstIterator::operator ++ (int)
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
ConstIterator tmp = *this;
|
|
Packit |
c2c737 |
++_i;
|
|
Packit |
c2c737 |
return tmp;
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
inline const char *
|
|
Packit |
c2c737 |
Header::ConstIterator::name () const
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
return *_i->first;
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
inline const Attribute &
|
|
Packit |
c2c737 |
Header::ConstIterator::attribute () const
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
return *_i->second;
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
inline bool
|
|
Packit |
c2c737 |
operator == (const Header::ConstIterator &x, const Header::ConstIterator &y)
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
return x._i == y._i;
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
inline bool
|
|
Packit |
c2c737 |
operator != (const Header::ConstIterator &x, const Header::ConstIterator &y)
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
return !(x == y);
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
//---------------------
|
|
Packit |
c2c737 |
// Template definitions
|
|
Packit |
c2c737 |
//---------------------
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
template <class T>
|
|
Packit |
c2c737 |
T &
|
|
Packit |
c2c737 |
Header::typedAttribute (const char name[])
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
Attribute *attr = &(*this)[name];
|
|
Packit |
c2c737 |
T *tattr = dynamic_cast <T*> (attr);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
if (tattr == 0)
|
|
Packit |
c2c737 |
throw IEX_NAMESPACE::TypeExc ("Unexpected attribute type.");
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
return *tattr;
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
template <class T>
|
|
Packit |
c2c737 |
const T &
|
|
Packit |
c2c737 |
Header::typedAttribute (const char name[]) const
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
const Attribute *attr = &(*this)[name];
|
|
Packit |
c2c737 |
const T *tattr = dynamic_cast <const T*> (attr);
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
if (tattr == 0)
|
|
Packit |
c2c737 |
throw IEX_NAMESPACE::TypeExc ("Unexpected attribute type.");
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
return *tattr;
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
template <class T>
|
|
Packit |
c2c737 |
T &
|
|
Packit |
c2c737 |
Header::typedAttribute (const std::string &name)
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
return typedAttribute<T> (name.c_str());
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
template <class T>
|
|
Packit |
c2c737 |
const T &
|
|
Packit |
c2c737 |
Header::typedAttribute (const std::string &name) const
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
return typedAttribute<T> (name.c_str());
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
template <class T>
|
|
Packit |
c2c737 |
T *
|
|
Packit |
c2c737 |
Header::findTypedAttribute (const char name[])
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
AttributeMap::iterator i = _map.find (name);
|
|
Packit |
c2c737 |
return (i == _map.end())? 0: dynamic_cast <T*> (i->second);
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
template <class T>
|
|
Packit |
c2c737 |
const T *
|
|
Packit |
c2c737 |
Header::findTypedAttribute (const char name[]) const
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
AttributeMap::const_iterator i = _map.find (name);
|
|
Packit |
c2c737 |
return (i == _map.end())? 0: dynamic_cast <const T*> (i->second);
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
template <class T>
|
|
Packit |
c2c737 |
T *
|
|
Packit |
c2c737 |
Header::findTypedAttribute (const std::string &name)
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
return findTypedAttribute<T> (name.c_str());
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
template <class T>
|
|
Packit |
c2c737 |
const T *
|
|
Packit |
c2c737 |
Header::findTypedAttribute (const std::string &name) const
|
|
Packit |
c2c737 |
{
|
|
Packit |
c2c737 |
return findTypedAttribute<T> (name.c_str());
|
|
Packit |
c2c737 |
}
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
OPENEXR_IMF_INTERNAL_NAMESPACE_HEADER_EXIT
|
|
Packit |
c2c737 |
|
|
Packit |
c2c737 |
#endif
|