diff options
| author | Carl Hetherington <cth@carlh.net> | 2012-07-16 19:25:13 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2012-07-16 19:25:13 +0100 |
| commit | ec1097e8426461b854b38e7b14bc73995c365e0a (patch) | |
| tree | 19c8e41ff4061f48ba23524bc8e38f5398c1f21a /asdcplib/src/JP2K_Codestream_Parser.cpp | |
| parent | 7d48446b5efdf795df1ce22d6d9ed3ebe85d3381 (diff) | |
asdcplib 1.9.45
Diffstat (limited to 'asdcplib/src/JP2K_Codestream_Parser.cpp')
| -rwxr-xr-x | asdcplib/src/JP2K_Codestream_Parser.cpp | 221 |
1 files changed, 221 insertions, 0 deletions
diff --git a/asdcplib/src/JP2K_Codestream_Parser.cpp b/asdcplib/src/JP2K_Codestream_Parser.cpp new file mode 100755 index 00000000..02d05671 --- /dev/null +++ b/asdcplib/src/JP2K_Codestream_Parser.cpp @@ -0,0 +1,221 @@ +/* +Copyright (c) 2004-2009, John Hurst +All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions +are met: +1. Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. +2. 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. +3. The name of the author may not be used to endorse or promote products + derived from this software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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. +*/ +/*! \file Codestream_Parser.cpp + \version $Id: JP2K_Codestream_Parser.cpp,v 1.7 2009/04/09 19:16:49 msheby Exp $ + \brief AS-DCP library, JPEG 2000 codestream essence reader implementation +*/ + +#include <KM_fileio.h> +#include <AS_DCP.h> +#include <JP2K.h> +#include <assert.h> +#include <KM_log.h> +using Kumu::DefaultLogSink; + +//------------------------------------------------------------------------------------------ + +class ASDCP::JP2K::CodestreamParser::h__CodestreamParser +{ + ASDCP_NO_COPY_CONSTRUCT(h__CodestreamParser); + +public: + PictureDescriptor m_PDesc; + Kumu::FileReader m_File; + + h__CodestreamParser() + { + memset(&m_PDesc, 0, sizeof(m_PDesc)); + m_PDesc.EditRate = Rational(24,1); + m_PDesc.SampleRate = m_PDesc.EditRate; + } + + ~h__CodestreamParser() {} + + Result_t OpenReadFrame(const char* filename, FrameBuffer& FB) + { + ASDCP_TEST_NULL_STR(filename); + m_File.Close(); + Result_t result = m_File.OpenRead(filename); + + if ( ASDCP_SUCCESS(result) ) + { + Kumu::fsize_t file_size = m_File.Size(); + + if ( FB.Capacity() < file_size ) + { + DefaultLogSink().Error("FrameBuf.Capacity: %u frame length: %u\n", FB.Capacity(), (ui32_t)file_size); + return RESULT_SMALLBUF; + } + } + + ui32_t read_count; + + if ( ASDCP_SUCCESS(result) ) + result = m_File.Read(FB.Data(), FB.Capacity(), &read_count); + + if ( ASDCP_SUCCESS(result) ) + FB.Size(read_count); + + if ( ASDCP_SUCCESS(result) ) + { + byte_t start_of_data = 0; // out param + result = ParseMetadataIntoDesc(FB, m_PDesc, &start_of_data); + + if ( ASDCP_SUCCESS(result) ) + FB.PlaintextOffset(start_of_data); + } + + return result; + } +}; + +ASDCP::Result_t +ASDCP::JP2K::ParseMetadataIntoDesc(const FrameBuffer& FB, PictureDescriptor& PDesc, byte_t* start_of_data) +{ + Result_t result = RESULT_OK; + Marker NextMarker; + ui32_t i; + const byte_t* p = FB.RoData(); + const byte_t* end_p = p + FB.Size(); + + while ( p < end_p && ASDCP_SUCCESS(result) ) + { + result = GetNextMarker(&p, NextMarker); + + if ( ASDCP_FAILURE(result) ) + { + result = RESULT_RAW_ESS; + break; + } + + switch ( NextMarker.m_Type ) + { + case MRK_SOD: + if ( start_of_data != 0 ) + *start_of_data = p - FB.RoData(); + + p = end_p; + break; + + case MRK_SIZ: + { + Accessor::SIZ SIZ_(NextMarker); + PDesc.StoredWidth = SIZ_.Xsize(); + PDesc.StoredHeight = SIZ_.Ysize(); + PDesc.AspectRatio = Rational(SIZ_.Xsize(), SIZ_.Ysize()); + PDesc.Rsize = SIZ_.Rsize(); + PDesc.Xsize = SIZ_.Xsize(); + PDesc.Ysize = SIZ_.Ysize(); + PDesc.XOsize = SIZ_.XOsize(); + PDesc.YOsize = SIZ_.YOsize(); + PDesc.XTsize = SIZ_.XTsize(); + PDesc.YTsize = SIZ_.YTsize(); + PDesc.XTOsize = SIZ_.XTOsize(); + PDesc.YTOsize = SIZ_.YTOsize(); + PDesc.Csize = SIZ_.Csize(); + + if ( PDesc.Csize != 3 ) + { + DefaultLogSink().Error("Unexpected number of components: %u\n", PDesc.Csize); + return RESULT_RAW_FORMAT; + } + + for ( i = 0; i < PDesc.Csize; i++ ) + SIZ_.ReadComponent(i, PDesc.ImageComponents[i]); + } + break; + + case MRK_COD: + memset(&PDesc.CodingStyleDefault, 0, sizeof(CodingStyleDefault_t)); + + if ( NextMarker.m_DataSize > sizeof(CodingStyleDefault_t) ) + { + DefaultLogSink().Error("Unexpectedly large CodingStyle data: %u\n", NextMarker.m_DataSize); + return RESULT_RAW_FORMAT; + } + + memcpy(&PDesc.CodingStyleDefault, NextMarker.m_Data, NextMarker.m_DataSize); + break; + + case MRK_QCD: + memset(&PDesc.QuantizationDefault, 0, sizeof(QuantizationDefault_t)); + + if ( NextMarker.m_DataSize < 16 ) + { + DefaultLogSink().Error("No quantization signaled\n"); + return RESULT_RAW_FORMAT; + } + + if ( NextMarker.m_DataSize > MaxDefaults ) + { + DefaultLogSink().Error("Quantization Default length exceeds maximum %d\n", NextMarker.m_DataSize); + return RESULT_RAW_FORMAT; + } + + memcpy(&PDesc.QuantizationDefault, NextMarker.m_Data, NextMarker.m_DataSize); + PDesc.QuantizationDefault.SPqcdLength = NextMarker.m_DataSize - 1; + break; + } + } + + return result; +} + +//------------------------------------------------------------------------------------------ + +ASDCP::JP2K::CodestreamParser::CodestreamParser() +{ +} + +ASDCP::JP2K::CodestreamParser::~CodestreamParser() +{ +} + +// Opens the stream for reading, parses enough data to provide a complete +// set of stream metadata for the MXFWriter below. +ASDCP::Result_t +ASDCP::JP2K::CodestreamParser::OpenReadFrame(const char* filename, FrameBuffer& FB) const +{ + const_cast<ASDCP::JP2K::CodestreamParser*>(this)->m_Parser = new h__CodestreamParser; + return m_Parser->OpenReadFrame(filename, FB); +} + +// +ASDCP::Result_t +ASDCP::JP2K::CodestreamParser::FillPictureDescriptor(PictureDescriptor& PDesc) const +{ + if ( m_Parser.empty() ) + return RESULT_INIT; + + PDesc = m_Parser->m_PDesc; + return RESULT_OK; +} + + +// +// end Codestream_Parser.cpp +// |
