TuttleOFX  1
Codec.cpp
Go to the documentation of this file.
00001 // -*- mode: C++; tab-width: 4 -*-
00002 // vi: ts=4
00003 
00004 /*
00005  * Copyright (c) 2009, Patrick A. Palmer.
00006  * All rights reserved.
00007  *
00008  * Redistribution and use in source and binary forms, with or without 
00009  * modification, are permitted provided that the following conditions are met:
00010  *
00011  *   - Redistributions of source code must retain the above copyright notice,
00012  *     this list of conditions and the following disclaimer.
00013  *
00014  *   - Redistributions in binary form must reproduce the above copyright
00015  *     notice, this list of conditions and the following disclaimer in the
00016  *     documentation and/or other materials provided with the distribution.
00017  *
00018  *   - Neither the name of Patrick A. Palmer nor the names of its
00019  *     contributors may be used to endorse or promote products derived from
00020  *     this software without specific prior written permission.
00021  *
00022  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 
00023  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 
00024  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 
00025  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 
00026  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 
00027  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 
00028  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 
00029  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 
00030  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
00031  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
00032  * POSSIBILITY OF SUCH DAMAGE.
00033  */
00034 
00035 #include "DPX.h"
00036 #include "Codec.h"
00037 #include "ElementReadStream.h"
00038 #include "ReaderInternal.h"
00039 
00040 
00041 
00042 
00043 dpx::Codec::Codec() : scanline(0)
00044 {
00045 }
00046 
00047 
00048 dpx::Codec::~Codec()
00049 {
00050         if (this->scanline)
00051                 delete [] scanline;
00052 }
00053 
00054 
00055 void dpx::Codec::Reset()
00056 {
00057         if (this->scanline)
00058         {
00059                 delete [] scanline;
00060                 this->scanline = 0;
00061         }
00062 }
00063 
00064 
00065 bool dpx::Codec::Read(const Header &dpxHeader, ElementReadStream *fd, const int element, const Block &block, void *data, const DataSize size)
00066 {
00067         // scanline buffer
00068         if (this->scanline == 0)
00069         {
00070                 // get the number of components for this element descriptor
00071                 const int numberOfComponents = dpxHeader.ImageElementComponentCount(element);
00072                 
00073                 // bit depth of the image element
00074                 const int bitDepth = dpxHeader.BitDepth(element);
00075                                 
00076                 // size of the scanline buffer is image width * number of components * bytes per component
00077                 int slsize = ((numberOfComponents * dpxHeader.Width() * 
00078                                           (bitDepth / 8 + (bitDepth % 8 ? 1 : 0))) / sizeof(U32))+1;
00079 
00080                 this->scanline = new U32[slsize];
00081         }
00082         
00083         
00084         // read the image block
00085         return ReadImageBlock<ElementReadStream>(dpxHeader, this->scanline, fd, element, block, data, size);
00086 }
00087