/* * Copyright 2012 Sebastian Annies, 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 org.mp4parser.muxer; import org.mp4parser.boxes.iso14496.part12.CompositionTimeToSample; import org.mp4parser.boxes.iso14496.part12.SampleDependencyTypeBox; import org.mp4parser.boxes.iso14496.part12.SampleDescriptionBox; import org.mp4parser.boxes.iso14496.part12.SubSampleInformationBox; import org.mp4parser.boxes.samplegrouping.GroupEntry; import java.io.Closeable; import java.util.List; import java.util.Map; /** * Represents a Track. A track is a timed sequence of related samples.<br> * <b>NOTE:</b> * For media data, a track corresponds to a sequence of images or sampled audio; for hint tracks, a track * corresponds to a streaming channel. */ public interface Track extends Closeable { SampleDescriptionBox getSampleDescriptionBox(); /** * Each samples is covers a small time span in a video. This method * returns the duration for each sample in track timescale. The array * must contain exactly as many samples as {@link #getSamples()} contains. * * @return an array of ticks */ long[] getSampleDurations(); /** * The duration of the track in track timescale. It's the sum of all samples' duration and does NOT include * any edits. * * @return the track's duration */ long getDuration(); List<CompositionTimeToSample.Entry> getCompositionTimeEntries(); long[] getSyncSamples(); List<SampleDependencyTypeBox.Entry> getSampleDependencies(); TrackMetaData getTrackMetaData(); String getHandler(); /** * The list of all samples. * * @return this track's samples */ List<Sample> getSamples(); public SubSampleInformationBox getSubsampleInformationBox(); /** * A name for identification purposes. Might return the underlying filename or network address or any * other identifier. For informational/debug only. This is no metadata! * * @return the track's name */ public String getName(); public List<Edit> getEdits(); public Map<GroupEntry, long[]> getSampleGroups(); }