/***************************************************************** | | AP4 - trun Atoms | | Copyright 2002-2008 Axiomatic Systems, LLC | | | This file is part of Bento4/AP4 (MP4 Atom Processing Library). | | Unless you have obtained Bento4 under a difference license, | this version of Bento4 is Bento4|GPL. | Bento4|GPL 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, or (at your option) | any later version. | | Bento4|GPL 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 Bento4|GPL; see the file COPYING. If not, write to the | Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA | 02111-1307, USA. | ****************************************************************/ /*---------------------------------------------------------------------- | includes +---------------------------------------------------------------------*/ #include "Ap4TrunAtom.h" #include "Ap4Utils.h" /*---------------------------------------------------------------------- | dynamic cast support +---------------------------------------------------------------------*/ AP4_DEFINE_DYNAMIC_CAST_ANCHOR(AP4_TrunAtom) /*---------------------------------------------------------------------- | AP4_TrunAtom::Create +---------------------------------------------------------------------*/ AP4_TrunAtom* AP4_TrunAtom::Create(AP4_Size size, AP4_ByteStream& stream) { AP4_UI08 version; AP4_UI32 flags; if (size < AP4_FULL_ATOM_HEADER_SIZE) return NULL; if (AP4_FAILED(AP4_Atom::ReadFullHeader(stream, version, flags))) return NULL; if (version > 1) return NULL; return new AP4_TrunAtom(size, version, flags, stream); } /*---------------------------------------------------------------------- | AP4_TrunAtom::ComputeRecordFieldsCount +---------------------------------------------------------------------*/ unsigned int AP4_TrunAtom::ComputeRecordFieldsCount(AP4_UI32 flags) { // count the number of bits set to 1 in the second byte of the flags unsigned int count = 0; for (unsigned int i=0; i<8; i++) { if (flags & (1<<(i+8))) ++count; } return count; } /*---------------------------------------------------------------------- | AP4_TrunAtom::ComputeOptionalFieldsCount +---------------------------------------------------------------------*/ unsigned int AP4_TrunAtom::ComputeOptionalFieldsCount(AP4_UI32 flags) { // count the number of bits set to 1 in the LSB of the flags unsigned int count = 0; for (unsigned int i=0; i<8; i++) { if (flags & (1<& entries) { // resize the entry array m_Entries.SetItemCount(entries.ItemCount()); // copy entries AP4_Cardinal entry_count = entries.ItemCount(); for (unsigned int i=0; iOnChildChanged(this); return AP4_SUCCESS; } /*---------------------------------------------------------------------- | AP4_TrunAtom::WriteFields +---------------------------------------------------------------------*/ AP4_Result AP4_TrunAtom::WriteFields(AP4_ByteStream& stream) { AP4_Result result; result = stream.WriteUI32(m_Entries.ItemCount()); if (AP4_FAILED(result)) return result; if (m_Flags & AP4_TRUN_FLAG_DATA_OFFSET_PRESENT) { result = stream.WriteUI32((AP4_UI32)m_DataOffset); if (AP4_FAILED(result)) return result; } if (m_Flags & AP4_TRUN_FLAG_FIRST_SAMPLE_FLAGS_PRESENT) { result = stream.WriteUI32(m_FirstSampleFlags); if (AP4_FAILED(result)) return result; } AP4_UI32 sample_count = m_Entries.ItemCount(); for (unsigned int i=0; i 0) { inspector.StartArray("entries"); AP4_UI32 sample_count = m_Entries.ItemCount(); for (unsigned int i = 0; i < sample_count; i++) { inspector.StartObject(NULL, 0, true); if (m_Flags & AP4_TRUN_FLAG_SAMPLE_DURATION_PRESENT) { inspector.AddField(inspector.GetVerbosity() >= 2 ? "sample_duration" : "d", m_Entries[i].sample_duration); } if (m_Flags & AP4_TRUN_FLAG_SAMPLE_SIZE_PRESENT) { inspector.AddField(inspector.GetVerbosity() >= 2 ? "sample_size" : "s", m_Entries[i].sample_size); } if (m_Flags & AP4_TRUN_FLAG_SAMPLE_FLAGS_PRESENT) { inspector.AddField(inspector.GetVerbosity() >= 2 ? "sample_flags" : "f", m_Entries[i].sample_flags); } if (m_Flags & AP4_TRUN_FLAG_SAMPLE_COMPOSITION_TIME_OFFSET_PRESENT) { inspector.AddField(inspector.GetVerbosity() >= 2 ? "sample_composition_time_offset" : "c", m_Entries[i].sample_composition_time_offset); } inspector.EndObject(); } inspector.EndArray(); } return AP4_SUCCESS; }