diff options
| author | jhurst <jhurst@cinecert.com> | 2021-05-20 17:09:42 -0700 |
|---|---|---|
| committer | jhurst <jhurst@cinecert.com> | 2021-05-20 17:09:42 -0700 |
| commit | 0ded8c32372315f86978b752ee95641331a60e2f (patch) | |
| tree | 0b44ed6f08bb705a234eb886bc4bf6814abd81d4 /src/Metadata.cpp | |
| parent | face28d822719aa6028ffca21097225c2a94e4ca (diff) | |
Added JPEGXSPictureSubDescriptor
Diffstat (limited to 'src/Metadata.cpp')
| -rw-r--r-- | src/Metadata.cpp | 131 |
1 files changed, 131 insertions, 0 deletions
diff --git a/src/Metadata.cpp b/src/Metadata.cpp index 455ba2a..400b826 100644 --- a/src/Metadata.cpp +++ b/src/Metadata.cpp @@ -89,6 +89,7 @@ static InterchangeObject* PHDRMetadataTrackSubDescriptor_Factory(const Dictionar static InterchangeObject* PIMFDynamicMetadataDescriptor_Factory(const Dictionary* Dict) { return new PIMFDynamicMetadataDescriptor(Dict); } static InterchangeObject* IABEssenceDescriptor_Factory(const Dictionary* Dict) { return new IABEssenceDescriptor(Dict); } static InterchangeObject* IABSoundfieldLabelSubDescriptor_Factory(const Dictionary* Dict) { return new IABSoundfieldLabelSubDescriptor(Dict); } +static InterchangeObject* JPEGXSPictureSubDescriptor_Factory(const Dictionary* Dict) { return new JPEGXSPictureSubDescriptor(Dict); } void @@ -144,6 +145,7 @@ ASDCP::MXF::Metadata_InitTypes(const Dictionary* Dict) SetObjectFactory(Dict->ul(MDD_PIMFDynamicMetadataDescriptor), PIMFDynamicMetadataDescriptor_Factory); SetObjectFactory(Dict->ul(MDD_IABEssenceDescriptor), IABEssenceDescriptor_Factory); SetObjectFactory(Dict->ul(MDD_IABSoundfieldLabelSubDescriptor), IABSoundfieldLabelSubDescriptor_Factory); + SetObjectFactory(Dict->ul(MDD_JPEGXSPictureSubDescriptor), JPEGXSPictureSubDescriptor_Factory); } //------------------------------------------------------------------------------------------ @@ -5347,6 +5349,135 @@ IABSoundfieldLabelSubDescriptor::WriteToBuffer(ASDCP::FrameBuffer& Buffer) return InterchangeObject::WriteToBuffer(Buffer); } +//------------------------------------------------------------------------------------------ +// JPEGXSPictureSubDescriptor + +// + +JPEGXSPictureSubDescriptor::JPEGXSPictureSubDescriptor(const Dictionary* d) : InterchangeObject(d), JPEGXSPpih(0), JPEGXSPlev(0), JPEGXSWf(0), JPEGXSHf(0), JPEGXSNc(0) +{ + assert(m_Dict); + m_UL = m_Dict->ul(MDD_JPEGXSPictureSubDescriptor); +} + +JPEGXSPictureSubDescriptor::JPEGXSPictureSubDescriptor(const JPEGXSPictureSubDescriptor& rhs) : InterchangeObject(rhs.m_Dict) +{ + assert(m_Dict); + m_UL = m_Dict->ul(MDD_JPEGXSPictureSubDescriptor); + Copy(rhs); +} + + +// +ASDCP::Result_t +JPEGXSPictureSubDescriptor::InitFromTLVSet(TLVReader& TLVSet) +{ + assert(m_Dict); + Result_t result = InterchangeObject::InitFromTLVSet(TLVSet); + if ( ASDCP_SUCCESS(result) ) result = TLVSet.ReadUi16(OBJ_READ_ARGS(JPEGXSPictureSubDescriptor, JPEGXSPpih)); + if ( ASDCP_SUCCESS(result) ) result = TLVSet.ReadUi16(OBJ_READ_ARGS(JPEGXSPictureSubDescriptor, JPEGXSPlev)); + if ( ASDCP_SUCCESS(result) ) result = TLVSet.ReadUi16(OBJ_READ_ARGS(JPEGXSPictureSubDescriptor, JPEGXSWf)); + if ( ASDCP_SUCCESS(result) ) result = TLVSet.ReadUi16(OBJ_READ_ARGS(JPEGXSPictureSubDescriptor, JPEGXSHf)); + if ( ASDCP_SUCCESS(result) ) result = TLVSet.ReadUi8(OBJ_READ_ARGS(JPEGXSPictureSubDescriptor, JPEGXSNc)); + if ( ASDCP_SUCCESS(result) ) result = TLVSet.ReadObject(OBJ_READ_ARGS(JPEGXSPictureSubDescriptor, JPEGXSComponentTable)); + if ( ASDCP_SUCCESS(result) ) { + result = TLVSet.ReadUi16(OBJ_READ_ARGS_OPT(JPEGXSPictureSubDescriptor, JPEGXSCw)); + JPEGXSCw.set_has_value( result == RESULT_OK ); + } + if ( ASDCP_SUCCESS(result) ) { + result = TLVSet.ReadUi16(OBJ_READ_ARGS_OPT(JPEGXSPictureSubDescriptor, JPEGXSHsl)); + JPEGXSHsl.set_has_value( result == RESULT_OK ); + } + if ( ASDCP_SUCCESS(result) ) { + result = TLVSet.ReadUi32(OBJ_READ_ARGS_OPT(JPEGXSPictureSubDescriptor, JPEGXSMaximumBitRate)); + JPEGXSMaximumBitRate.set_has_value( result == RESULT_OK ); + } + return result; +} + +// +ASDCP::Result_t +JPEGXSPictureSubDescriptor::WriteToTLVSet(TLVWriter& TLVSet) +{ + assert(m_Dict); + Result_t result = InterchangeObject::WriteToTLVSet(TLVSet); + if ( ASDCP_SUCCESS(result) ) result = TLVSet.WriteUi16(OBJ_WRITE_ARGS(JPEGXSPictureSubDescriptor, JPEGXSPpih)); + if ( ASDCP_SUCCESS(result) ) result = TLVSet.WriteUi16(OBJ_WRITE_ARGS(JPEGXSPictureSubDescriptor, JPEGXSPlev)); + if ( ASDCP_SUCCESS(result) ) result = TLVSet.WriteUi16(OBJ_WRITE_ARGS(JPEGXSPictureSubDescriptor, JPEGXSWf)); + if ( ASDCP_SUCCESS(result) ) result = TLVSet.WriteUi16(OBJ_WRITE_ARGS(JPEGXSPictureSubDescriptor, JPEGXSHf)); + if ( ASDCP_SUCCESS(result) ) result = TLVSet.WriteUi8(OBJ_WRITE_ARGS(JPEGXSPictureSubDescriptor, JPEGXSNc)); + if ( ASDCP_SUCCESS(result) ) result = TLVSet.WriteObject(OBJ_WRITE_ARGS(JPEGXSPictureSubDescriptor, JPEGXSComponentTable)); + if ( ASDCP_SUCCESS(result) && ! JPEGXSCw.empty() ) result = TLVSet.WriteUi16(OBJ_WRITE_ARGS_OPT(JPEGXSPictureSubDescriptor, JPEGXSCw)); + if ( ASDCP_SUCCESS(result) && ! JPEGXSHsl.empty() ) result = TLVSet.WriteUi16(OBJ_WRITE_ARGS_OPT(JPEGXSPictureSubDescriptor, JPEGXSHsl)); + if ( ASDCP_SUCCESS(result) && ! JPEGXSMaximumBitRate.empty() ) result = TLVSet.WriteUi32(OBJ_WRITE_ARGS_OPT(JPEGXSPictureSubDescriptor, JPEGXSMaximumBitRate)); + return result; +} + +// +void +JPEGXSPictureSubDescriptor::Copy(const JPEGXSPictureSubDescriptor& rhs) +{ + InterchangeObject::Copy(rhs); + JPEGXSPpih = rhs.JPEGXSPpih; + JPEGXSPlev = rhs.JPEGXSPlev; + JPEGXSWf = rhs.JPEGXSWf; + JPEGXSHf = rhs.JPEGXSHf; + JPEGXSNc = rhs.JPEGXSNc; + JPEGXSComponentTable = rhs.JPEGXSComponentTable; + JPEGXSCw = rhs.JPEGXSCw; + JPEGXSHsl = rhs.JPEGXSHsl; + JPEGXSMaximumBitRate = rhs.JPEGXSMaximumBitRate; +} + +// +InterchangeObject* +JPEGXSPictureSubDescriptor::Clone() const +{ + return new JPEGXSPictureSubDescriptor(*this); +} + +// +void +JPEGXSPictureSubDescriptor::Dump(FILE* stream) +{ + char identbuf[IdentBufferLen]; + *identbuf = 0; + + if ( stream == 0 ) + stream = stderr; + + InterchangeObject::Dump(stream); + fprintf(stream, " %22s = %d\n", "JPEGXSPpih", JPEGXSPpih); + fprintf(stream, " %22s = %d\n", "JPEGXSPlev", JPEGXSPlev); + fprintf(stream, " %22s = %d\n", "JPEGXSWf", JPEGXSWf); + fprintf(stream, " %22s = %d\n", "JPEGXSHf", JPEGXSHf); + fprintf(stream, " %22s = %d\n", "JPEGXSNc", JPEGXSNc); + fprintf(stream, " %22s = %s\n", "JPEGXSComponentTable", JPEGXSComponentTable.EncodeString(identbuf, IdentBufferLen)); + if ( ! JPEGXSCw.empty() ) { + fprintf(stream, " %22s = %d\n", "JPEGXSCw", JPEGXSCw.get()); + } + if ( ! JPEGXSHsl.empty() ) { + fprintf(stream, " %22s = %d\n", "JPEGXSHsl", JPEGXSHsl.get()); + } + if ( ! JPEGXSMaximumBitRate.empty() ) { + fprintf(stream, " %22s = %d\n", "JPEGXSMaximumBitRate", JPEGXSMaximumBitRate.get()); + } +} + +// +ASDCP::Result_t +JPEGXSPictureSubDescriptor::InitFromBuffer(const byte_t* p, ui32_t l) +{ + return InterchangeObject::InitFromBuffer(p, l); +} + +// +ASDCP::Result_t +JPEGXSPictureSubDescriptor::WriteToBuffer(ASDCP::FrameBuffer& Buffer) +{ + return InterchangeObject::WriteToBuffer(Buffer); +} + // // end Metadata.cpp // |
