Logo Search packages:      
Sourcecode: qtpfsgui version File versions

pfsinexr.cpp

/**
 * @brief load an exr file
 * 
 * This file is a part of Qtpfsgui package.
 * ---------------------------------------------------------------------- 
 * Copyright (C) 2003,2004 Rafal Mantiuk and Grzegorz Krawczyk
 * Copyright (C) 2006,2007 Giuseppe Rota
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 * ---------------------------------------------------------------------- 
 *
 * @author Rafal Mantiuk, <mantiuk@mpi-sb.mpg.de>
 * @author Giuseppe Rota  <grota@users.sourceforge.net>
 */

#include "../Libpfs/pfs.h"
#include <ImfHeader.h>
#include <ImfChannelList.h>
#include <ImfInputFile.h>
#include <ImfRgbaFile.h>
#include <ImfStringAttribute.h>
#include <ImfStandardAttributes.h>
#include <ImfPixelType.h>
#include <iostream>
#include <stdlib.h>
using namespace Imf;
using namespace Imath;

using std::string;

static string escapeString( const string &src )
{
  int pos = 0;
  string ret = src;
  while( pos < (int)ret.size() ) {
    pos = ret.find( "\n", pos );
    if( pos == -1 ) break;
    ret.replace( pos, 1, "\\n" );
    pos+=2;
  }
  return ret;
}

pfs::Frame *readEXRfile (const char *filename) {

    pfs::DOMIO pfsio;
    FILE *inputEXRfile=fopen(filename,"rb");
    InputFile file( filename );

    FrameBuffer frameBuffer;
    Box2i dw = file.header().dataWindow();
    int width  = dw.max.x - dw.min.x + 1;
    int height = dw.max.y - dw.min.y + 1;
    pfs::Frame *frame = pfsio.createFrame( width, height );
    const ChannelList &channels = file.header().channels();
    pfs::Channel *X, *Y, *Z;
      const Channel *rChannel = channels.findChannel( "R" );
      const Channel *gChannel = channels.findChannel( "G" );
      const Channel *bChannel = channels.findChannel( "B" );
      if( rChannel!=NULL && gChannel!=NULL && bChannel!=NULL ) {
//       qDebug("found RGB chans");
        frame->createRGBChannels( X, Y, Z );
//         frame->createXYZChannels( X, Y, Z );

        frameBuffer.insert( "R",      // name
          Slice( Imf::FLOAT,                // type
            (char *)X->getRawData(),
            sizeof(float),      // xStride
            sizeof(float) * width,// yStride
            1, 1,               // x/y sampling
            0.0));                    // fillValue

        frameBuffer.insert( "G",      // name
          Slice( Imf::FLOAT,                // type
            (char *)Y->getRawData(),
            sizeof(float),      // xStride
            sizeof(float) * width,// yStride
            1, 1,               // x/y sampling
            0.0));                    // fillValue

        frameBuffer.insert( "B",      // name
          Slice( Imf::FLOAT,                // type
            (char *)Z->getRawData(),
            sizeof(float),      // xStride
            sizeof(float) * width,// yStride
            1, 1,               // x/y sampling
            0.0)); // fillValue

      } //else qDebug("no rgb channels in exr");


      for( Header::ConstIterator it = file.header().begin();
           it != file.header().end(); it++ ) {
        const char *attribName = it.name();
        const char *colon = strstr( attribName, ":" );
        const StringAttribute *attrib =
          file.header().findTypedAttribute<StringAttribute>(attribName);

        if( attrib == NULL ) continue; // Skip if type is not String
        if( colon == NULL ) {   // frame tag
          frame->getTags()->setString( attribName, escapeString(attrib->value()).c_str() );
        } else {                // channel tag
          string channelName = string( attribName, colon-attribName );
          pfs::Channel *ch = frame->getChannel( channelName.c_str() );
          if( ch == NULL ) {
            continue;
          }
          ch->getTags()->setString(  colon+1, escapeString( attrib->value() ).c_str() );
        }
      }

    file.setFrameBuffer( frameBuffer );
    file.readPixels( dw.min.y, dw.max.y );

      // Rescale values if WhiteLuminance is present
      if( hasWhiteLuminance( file.header() ) ) {
        float scaleFactor = whiteLuminance( file.header() );
        int pixelCount = frame->getHeight()*frame->getWidth();
        for( int i = 0; i < pixelCount; i++ ) {
          (*X)(i) *= scaleFactor;
          (*Y)(i) *= scaleFactor;
          (*Z)(i) *= scaleFactor;
        }
//         const StringAttribute *relativeLum =
//           file.header().findTypedAttribute<StringAttribute>("RELATIVE_LUMINANCE");

        const char *luminanceTag = frame->getTags()->getString( "LUMINANCE" );
        if( luminanceTag == NULL )
          frame->getTags()->setString( "LUMINANCE", "ABSOLUTE" );
      }

//     pfs::transformColorSpace( pfs::CS_RGB, X, Y, Z, pfs::CS_XYZ, X, Y, Z );
    frame->getTags()->setString( "FILE_NAME", filename );
    fclose(inputEXRfile);
    return frame;
}

Generated by  Doxygen 1.6.0   Back to index