/* * Copyright 2008 CoreMedia AG, Hamburg * * Licensed under the Apache License, Version 2.0 (the License); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an AS IS BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.coremedia.iso.boxes; import com.coremedia.iso.BoxParser; import com.coremedia.iso.IsoBufferWrapper; import com.coremedia.iso.IsoOutputStream; import java.io.IOException; /** * The sample description table gives detailed information about the coding type used, and any initialization * information needed for that coding. <br> * The information stored in the sample description box after the entry-count is both track-type specific as * documented here, and can also have variants within a track type (e.g. different codings may use different * specific information after some common fields, even within a video track).<br> * For video tracks, a VisualSampleEntry is used; for audio tracks, an AudioSampleEntry. Hint tracks use an * entry format specific to their protocol, with an appropriate name. Timed Text tracks use a TextSampleEntry * For hint tracks, the sample description contains appropriate declarative data for the streaming protocol being * used, and the format of the hint track. The definition of the sample description is specific to the protocol. * Multiple descriptions may be used within a track.<br> * The 'protocol' and 'codingname' fields are registered identifiers that uniquely identify the streaming protocol or * compression format decoder to be used. A given protocol or codingname may have optional or required * extensions to the sample description (e.g. codec initialization parameters). All such extensions shall be within * boxes; these boxes occur after the required fields. Unrecognized boxes shall be ignored. * <br> * Defined in ISO/IEC 14496-12 * * @see com.coremedia.iso.boxes.sampleentry.VisualSampleEntry * @see com.coremedia.iso.boxes.sampleentry.TextSampleEntry * @see com.coremedia.iso.boxes.sampleentry.AudioSampleEntry * @see com.coremedia.iso.boxes.rtp.RtpHintSampleEntry */ public class SampleDescriptionBox extends FullContainerBox { public static final String TYPE = "stsd"; public SampleDescriptionBox() { super(TYPE); } @Override protected long getContentSize() { long size = 4; for (Box box : boxes) { size += box.getSize(); } return size; } @Override public void parse(IsoBufferWrapper in, long size, BoxParser boxParser, Box lastMovieFragmentBox) throws IOException { parseHeader(in, size); long entryCount = in.readUInt32(); if (entryCount > Integer.MAX_VALUE) { throw new IOException("The parser cannot deal with more than Integer.MAX_VALUE subboxes"); } long sp = in.position(); for (int i = 0; i < entryCount; i++) { boxes.add(boxParser.parseBox(in, this, lastMovieFragmentBox)); } if (in.position() - offset < size) { // System.out.println("dead bytes found in " + box); long length = (size - (in.position() - offset)); setDeadBytes(in.getSegment(in.position(), length)); } } @Override protected void getContent(IsoOutputStream isos) throws IOException { isos.writeUInt32(boxes.size()); for (Box boxe : boxes) { boxe.getBox(isos); } } }