| Modifier and Type | Class and Description |
|---|---|
static interface |
FragmentedMp4Extractor.Flags
Flags controlling the behavior of the extractor.
|
| Modifier and Type | Field and Description |
|---|---|
static ExtractorsFactory |
FACTORY
Factory for
FragmentedMp4Extractor instances. |
static int |
FLAG_ENABLE_EMSG_TRACK
Flag to indicate that the extractor should output an event message metadata track.
|
static int |
FLAG_WORKAROUND_EVERY_VIDEO_FRAME_IS_SYNC_FRAME
Flag to work around an issue in some video streams where every frame is marked as a sync frame.
|
static int |
FLAG_WORKAROUND_IGNORE_EDIT_LISTS
Flag to ignore any edit lists in the stream.
|
static int |
FLAG_WORKAROUND_IGNORE_TFDT_BOX
Flag to ignore any tfdt boxes in the stream.
|
RESULT_CONTINUE, RESULT_END_OF_INPUT, RESULT_SEEK| Constructor and Description |
|---|
FragmentedMp4Extractor() |
FragmentedMp4Extractor(int flags) |
FragmentedMp4Extractor(int flags,
TimestampAdjuster timestampAdjuster) |
FragmentedMp4Extractor(int flags,
TimestampAdjuster timestampAdjuster,
Track sideloadedTrack,
DrmInitData sideloadedDrmInitData) |
FragmentedMp4Extractor(int flags,
TimestampAdjuster timestampAdjuster,
Track sideloadedTrack,
DrmInitData sideloadedDrmInitData,
java.util.List<Format> closedCaptionFormats) |
FragmentedMp4Extractor(int flags,
TimestampAdjuster timestampAdjuster,
Track sideloadedTrack,
DrmInitData sideloadedDrmInitData,
java.util.List<Format> closedCaptionFormats,
TrackOutput additionalEmsgTrackOutput) |
| Modifier and Type | Method and Description |
|---|---|
void |
init(ExtractorOutput output)
Initializes the extractor with an
ExtractorOutput. |
int |
read(ExtractorInput input,
PositionHolder seekPosition)
Extracts data read from a provided
ExtractorInput. |
void |
release()
Releases all kept resources.
|
void |
seek(long position,
long timeUs)
Notifies the extractor that a seek has occurred.
|
boolean |
sniff(ExtractorInput input)
Returns whether this extractor can extract samples from the
ExtractorInput, which must
provide data from the start of the stream. |
public static final ExtractorsFactory FACTORY
FragmentedMp4Extractor instances.public static final int FLAG_WORKAROUND_EVERY_VIDEO_FRAME_IS_SYNC_FRAME
This flag does nothing if the stream is not a video stream.
public static final int FLAG_WORKAROUND_IGNORE_TFDT_BOX
public static final int FLAG_ENABLE_EMSG_TRACK
public static final int FLAG_WORKAROUND_IGNORE_EDIT_LISTS
public FragmentedMp4Extractor()
public FragmentedMp4Extractor(int flags)
flags - Flags that control the extractor's behavior.public FragmentedMp4Extractor(int flags,
TimestampAdjuster timestampAdjuster)
flags - Flags that control the extractor's behavior.timestampAdjuster - Adjusts sample timestamps. May be null if no adjustment is needed.public FragmentedMp4Extractor(int flags,
TimestampAdjuster timestampAdjuster,
Track sideloadedTrack,
DrmInitData sideloadedDrmInitData)
flags - Flags that control the extractor's behavior.timestampAdjuster - Adjusts sample timestamps. May be null if no adjustment is needed.sideloadedTrack - Sideloaded track information, in the case that the extractor
will not receive a moov box in the input data. Null if a moov box is expected.sideloadedDrmInitData - The DrmInitData to use for encrypted tracks. If null, the
pssh boxes (if present) will be used.public FragmentedMp4Extractor(int flags,
TimestampAdjuster timestampAdjuster,
Track sideloadedTrack,
DrmInitData sideloadedDrmInitData,
java.util.List<Format> closedCaptionFormats)
flags - Flags that control the extractor's behavior.timestampAdjuster - Adjusts sample timestamps. May be null if no adjustment is needed.sideloadedTrack - Sideloaded track information, in the case that the extractor
will not receive a moov box in the input data. Null if a moov box is expected.sideloadedDrmInitData - The DrmInitData to use for encrypted tracks. If null, the
pssh boxes (if present) will be used.closedCaptionFormats - For tracks that contain SEI messages, the formats of the closed
caption channels to expose.public FragmentedMp4Extractor(int flags,
TimestampAdjuster timestampAdjuster,
Track sideloadedTrack,
DrmInitData sideloadedDrmInitData,
java.util.List<Format> closedCaptionFormats,
@Nullable
TrackOutput additionalEmsgTrackOutput)
flags - Flags that control the extractor's behavior.timestampAdjuster - Adjusts sample timestamps. May be null if no adjustment is needed.sideloadedTrack - Sideloaded track information, in the case that the extractor
will not receive a moov box in the input data. Null if a moov box is expected.sideloadedDrmInitData - The DrmInitData to use for encrypted tracks. If null, the
pssh boxes (if present) will be used.closedCaptionFormats - For tracks that contain SEI messages, the formats of the closed
caption channels to expose.additionalEmsgTrackOutput - An extra track output that will receive all emsg messages
targeting the player, even if FLAG_ENABLE_EMSG_TRACK is not set. Null if special
handling of emsg messages for players is not required.public boolean sniff(ExtractorInput input) throws java.io.IOException, java.lang.InterruptedException
ExtractorExtractorInput, which must
provide data from the start of the stream.
If true is returned, the input's reading position may have been modified.
Otherwise, only its peek position may have been modified.
sniff in interface Extractorinput - The ExtractorInput from which data should be peeked/read.java.io.IOException - If an error occurred reading from the input.java.lang.InterruptedException - If the thread was interrupted.public void init(ExtractorOutput output)
ExtractorExtractorOutput. Called at most once.init in interface Extractoroutput - An ExtractorOutput to receive extracted data.public void seek(long position,
long timeUs)
Extractor
Following a call to this method, the ExtractorInput passed to the next invocation of
Extractor.read(ExtractorInput, PositionHolder) is required to provide data starting from position in the stream. Valid random access positions are the start of the stream and
positions that can be obtained from any SeekMap passed to the ExtractorOutput.
public void release()
Extractorpublic int read(ExtractorInput input, PositionHolder seekPosition) throws java.io.IOException, java.lang.InterruptedException
ExtractorExtractorInput. Must not be called before
Extractor.init(ExtractorOutput).
A single call to this method will block until some progress has been made, but will not block for longer than this. Hence each call will consume only a small amount of input data.
In the common case, Extractor.RESULT_CONTINUE is returned to indicate that the
ExtractorInput passed to the next read is required to provide data continuing from the
position in the stream reached by the returning call. If the extractor requires data to be
provided from a different position, then that position is set in seekPosition and
Extractor.RESULT_SEEK is returned. If the extractor reached the end of the data provided by the
ExtractorInput, then Extractor.RESULT_END_OF_INPUT is returned.
read in interface Extractorinput - The ExtractorInput from which data should be read.seekPosition - If Extractor.RESULT_SEEK is returned, this holder is updated to hold the
position of the required data.RESULT_ values defined in this interface.java.io.IOException - If an error occurred reading from the input.java.lang.InterruptedException - If the thread was interrupted.