Class FragmentedMp4Extractor
- java.lang.Object
-
- com.google.android.exoplayer2.extractor.mp4.FragmentedMp4Extractor
-
- All Implemented Interfaces:
Extractor
@Deprecated public class FragmentedMp4Extractor extends Object implements Extractor
Deprecated.com.google.android.exoplayer2 is deprecated. Please migrate to androidx.media3 (which contains the same ExoPlayer code). See the migration guide for more details, including a script to help with the migration.Extracts data from the FMP4 container format.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static interface
FragmentedMp4Extractor.Flags
Deprecated.Flags controlling the behavior of the extractor.-
Nested classes/interfaces inherited from interface com.google.android.exoplayer2.extractor.Extractor
Extractor.ReadResult
-
-
Field Summary
Fields Modifier and Type Field Description static ExtractorsFactory
FACTORY
Deprecated.Factory forFragmentedMp4Extractor
instances.static int
FLAG_ENABLE_EMSG_TRACK
Deprecated.Flag to indicate that the extractor should output an event message metadata track.static int
FLAG_WORKAROUND_EVERY_VIDEO_FRAME_IS_SYNC_FRAME
Deprecated.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
Deprecated.Flag to ignore any edit lists in the stream.static int
FLAG_WORKAROUND_IGNORE_TFDT_BOX
Deprecated.Flag to ignore any tfdt boxes in the stream.-
Fields inherited from interface com.google.android.exoplayer2.extractor.Extractor
RESULT_CONTINUE, RESULT_END_OF_INPUT, RESULT_SEEK
-
-
Constructor Summary
Constructors Constructor Description FragmentedMp4Extractor()
Deprecated.FragmentedMp4Extractor(@com.google.android.exoplayer2.extractor.mp4.FragmentedMp4Extractor.Flags int flags)
Deprecated.FragmentedMp4Extractor(@com.google.android.exoplayer2.extractor.mp4.FragmentedMp4Extractor.Flags int flags, TimestampAdjuster timestampAdjuster)
Deprecated.FragmentedMp4Extractor(@com.google.android.exoplayer2.extractor.mp4.FragmentedMp4Extractor.Flags int flags, TimestampAdjuster timestampAdjuster, Track sideloadedTrack)
Deprecated.FragmentedMp4Extractor(@com.google.android.exoplayer2.extractor.mp4.FragmentedMp4Extractor.Flags int flags, TimestampAdjuster timestampAdjuster, Track sideloadedTrack, List<Format> closedCaptionFormats)
Deprecated.FragmentedMp4Extractor(@com.google.android.exoplayer2.extractor.mp4.FragmentedMp4Extractor.Flags int flags, TimestampAdjuster timestampAdjuster, Track sideloadedTrack, List<Format> closedCaptionFormats, TrackOutput additionalEmsgTrackOutput)
Deprecated.
-
Method Summary
All Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description void
init(ExtractorOutput output)
Deprecated.Initializes the extractor with anExtractorOutput
.protected Track
modifyTrack(Track track)
Deprecated.int
read(ExtractorInput input, PositionHolder seekPosition)
Deprecated.Extracts data read from a providedExtractorInput
.void
release()
Deprecated.Releases all kept resources.void
seek(long position, long timeUs)
Deprecated.Notifies the extractor that a seek has occurred.boolean
sniff(ExtractorInput input)
Deprecated.Returns whether this extractor can extract samples from theExtractorInput
, which must provide data from the start of the stream.
-
-
-
Field Detail
-
FACTORY
public static final ExtractorsFactory FACTORY
Deprecated.Factory forFragmentedMp4Extractor
instances.
-
FLAG_WORKAROUND_EVERY_VIDEO_FRAME_IS_SYNC_FRAME
public static final int FLAG_WORKAROUND_EVERY_VIDEO_FRAME_IS_SYNC_FRAME
Deprecated.Flag to work around an issue in some video streams where every frame is marked as a sync frame. The workaround overrides the sync frame flags in the stream, forcing them to false except for the first sample in each segment.This flag does nothing if the stream is not a video stream.
- See Also:
- Constant Field Values
-
FLAG_WORKAROUND_IGNORE_TFDT_BOX
public static final int FLAG_WORKAROUND_IGNORE_TFDT_BOX
Deprecated.Flag to ignore any tfdt boxes in the stream.- See Also:
- Constant Field Values
-
FLAG_ENABLE_EMSG_TRACK
public static final int FLAG_ENABLE_EMSG_TRACK
Deprecated.Flag to indicate that the extractor should output an event message metadata track. Any event messages in the stream will be delivered as samples to this track.- See Also:
- Constant Field Values
-
FLAG_WORKAROUND_IGNORE_EDIT_LISTS
public static final int FLAG_WORKAROUND_IGNORE_EDIT_LISTS
Deprecated.Flag to ignore any edit lists in the stream.- See Also:
- Constant Field Values
-
-
Constructor Detail
-
FragmentedMp4Extractor
public FragmentedMp4Extractor()
Deprecated.
-
FragmentedMp4Extractor
public FragmentedMp4Extractor(@com.google.android.exoplayer2.extractor.mp4.FragmentedMp4Extractor.Flags int flags)
Deprecated.- Parameters:
flags
- Flags that control the extractor's behavior.
-
FragmentedMp4Extractor
public FragmentedMp4Extractor(@com.google.android.exoplayer2.extractor.mp4.FragmentedMp4Extractor.Flags int flags, @Nullable TimestampAdjuster timestampAdjuster)
Deprecated.- Parameters:
flags
- Flags that control the extractor's behavior.timestampAdjuster
- Adjusts sample timestamps. May be null if no adjustment is needed.
-
FragmentedMp4Extractor
public FragmentedMp4Extractor(@com.google.android.exoplayer2.extractor.mp4.FragmentedMp4Extractor.Flags int flags, @Nullable TimestampAdjuster timestampAdjuster, @Nullable Track sideloadedTrack)
Deprecated.- Parameters:
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.
-
FragmentedMp4Extractor
public FragmentedMp4Extractor(@com.google.android.exoplayer2.extractor.mp4.FragmentedMp4Extractor.Flags int flags, @Nullable TimestampAdjuster timestampAdjuster, @Nullable Track sideloadedTrack, List<Format> closedCaptionFormats)
Deprecated.- Parameters:
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.closedCaptionFormats
- For tracks that contain SEI messages, the formats of the closed caption channels to expose.
-
FragmentedMp4Extractor
public FragmentedMp4Extractor(@com.google.android.exoplayer2.extractor.mp4.FragmentedMp4Extractor.Flags int flags, @Nullable TimestampAdjuster timestampAdjuster, @Nullable Track sideloadedTrack, List<Format> closedCaptionFormats, @Nullable TrackOutput additionalEmsgTrackOutput)
Deprecated.- Parameters:
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.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 ifFLAG_ENABLE_EMSG_TRACK
is not set. Null if special handling of emsg messages for players is not required.
-
-
Method Detail
-
sniff
public boolean sniff(ExtractorInput input) throws IOException
Deprecated.Description copied from interface:Extractor
Returns whether this extractor can extract samples from theExtractorInput
, which must provide data from the start of the stream.If
true
is returned, theinput
's reading position may have been modified. Otherwise, only its peek position may have been modified.- Specified by:
sniff
in interfaceExtractor
- Parameters:
input
- TheExtractorInput
from which data should be peeked/read.- Returns:
- Whether this extractor can read the provided input.
- Throws:
IOException
- If an error occurred reading from the input.
-
init
public void init(ExtractorOutput output)
Deprecated.Description copied from interface:Extractor
Initializes the extractor with anExtractorOutput
. Called at most once.- Specified by:
init
in interfaceExtractor
- Parameters:
output
- AnExtractorOutput
to receive extracted data.
-
seek
public void seek(long position, long timeUs)
Deprecated.Description copied from interface:Extractor
Notifies the extractor that a seek has occurred.Following a call to this method, the
ExtractorInput
passed to the next invocation ofExtractor.read(ExtractorInput, PositionHolder)
is required to provide data starting fromposition
in the stream. Valid random access positions are the start of the stream and positions that can be obtained from anySeekMap
passed to theExtractorOutput
.
-
release
public void release()
Deprecated.Description copied from interface:Extractor
Releases all kept resources.
-
read
public int read(ExtractorInput input, PositionHolder seekPosition) throws IOException
Deprecated.Description copied from interface:Extractor
Extracts data read from a providedExtractorInput
. Must not be called beforeExtractor.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 theExtractorInput
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 inseekPosition
andExtractor.RESULT_SEEK
is returned. If the extractor reached the end of the data provided by theExtractorInput
, thenExtractor.RESULT_END_OF_INPUT
is returned.When this method throws an
IOException
, extraction may continue by providing anExtractorInput
with an unchangedread position
to a subsequent call to this method.- Specified by:
read
in interfaceExtractor
- Parameters:
input
- TheExtractorInput
from which data should be read.seekPosition
- IfExtractor.RESULT_SEEK
is returned, this holder is updated to hold the position of the required data.- Returns:
- One of the
RESULT_
values defined in this interface. - Throws:
IOException
- If an error occurred reading from or parsing the input.
-
-