Class Mp3Extractor
- java.lang.Object
-
- com.google.android.exoplayer2.extractor.mp3.Mp3Extractor
-
- All Implemented Interfaces:
Extractor
@Deprecated public final class Mp3Extractor 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 MP3 container format.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static interfaceMp3Extractor.FlagsDeprecated.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 ExtractorsFactoryFACTORYDeprecated.Factory forMp3Extractorinstances.static intFLAG_DISABLE_ID3_METADATADeprecated.Flag to disable parsing of ID3 metadata.static intFLAG_ENABLE_CONSTANT_BITRATE_SEEKINGDeprecated.Flag to force enable seeking using a constant bitrate assumption in cases where seeking would otherwise not be possible.static intFLAG_ENABLE_CONSTANT_BITRATE_SEEKING_ALWAYSDeprecated.LikeFLAG_ENABLE_CONSTANT_BITRATE_SEEKING, except that seeking is also enabled in cases where the content length (and hence the duration of the media) is unknown.static intFLAG_ENABLE_INDEX_SEEKINGDeprecated.Flag to force index seeking, in which a time-to-byte mapping is built as the file is read.-
Fields inherited from interface com.google.android.exoplayer2.extractor.Extractor
RESULT_CONTINUE, RESULT_END_OF_INPUT, RESULT_SEEK
-
-
Constructor Summary
Constructors Constructor Description Mp3Extractor()Deprecated.Mp3Extractor(@com.google.android.exoplayer2.extractor.mp3.Mp3Extractor.Flags int flags)Deprecated.Mp3Extractor(@com.google.android.exoplayer2.extractor.mp3.Mp3Extractor.Flags int flags, long forcedFirstSampleTimestampUs)Deprecated.
-
Method Summary
All Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voiddisableSeeking()Deprecated.Disables the extractor from being able to seek through the media.voidinit(ExtractorOutput output)Deprecated.Initializes the extractor with anExtractorOutput.intread(ExtractorInput input, PositionHolder seekPosition)Deprecated.Extracts data read from a providedExtractorInput.voidrelease()Deprecated.Releases all kept resources.voidseek(long position, long timeUs)Deprecated.Notifies the extractor that a seek has occurred.booleansniff(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 forMp3Extractorinstances.
-
FLAG_ENABLE_CONSTANT_BITRATE_SEEKING
public static final int FLAG_ENABLE_CONSTANT_BITRATE_SEEKING
Deprecated.Flag to force enable seeking using a constant bitrate assumption in cases where seeking would otherwise not be possible.This flag is ignored if
FLAG_ENABLE_INDEX_SEEKINGis set.- See Also:
- Constant Field Values
-
FLAG_ENABLE_CONSTANT_BITRATE_SEEKING_ALWAYS
public static final int FLAG_ENABLE_CONSTANT_BITRATE_SEEKING_ALWAYS
Deprecated.LikeFLAG_ENABLE_CONSTANT_BITRATE_SEEKING, except that seeking is also enabled in cases where the content length (and hence the duration of the media) is unknown. Application code should ensure that requested seek positions are valid when using this flag, or be ready to handle playback failures reported throughPlayer.Listener.onPlayerError(com.google.android.exoplayer2.PlaybackException)withPlaybackException.errorCodeset toPlaybackException.ERROR_CODE_IO_READ_POSITION_OUT_OF_RANGE.If this flag is set, then the behavior enabled by
FLAG_ENABLE_CONSTANT_BITRATE_SEEKINGis implicitly enabled.This flag is ignored if
FLAG_ENABLE_INDEX_SEEKINGis set.- See Also:
- Constant Field Values
-
FLAG_ENABLE_INDEX_SEEKING
public static final int FLAG_ENABLE_INDEX_SEEKING
Deprecated.Flag to force index seeking, in which a time-to-byte mapping is built as the file is read.This seeker may require to scan a significant portion of the file to compute a seek point. Therefore, it should only be used if one of the following is true:
- The file is small.
- The bitrate is variable (or it's unknown whether it's variable) and the file does not provide precise enough seeking metadata.
- See Also:
- Constant Field Values
-
FLAG_DISABLE_ID3_METADATA
public static final int FLAG_DISABLE_ID3_METADATA
Deprecated.Flag to disable parsing of ID3 metadata. Can be set to save memory if ID3 metadata is not required.- See Also:
- Constant Field Values
-
-
Constructor Detail
-
Mp3Extractor
public Mp3Extractor()
Deprecated.
-
Mp3Extractor
public Mp3Extractor(@com.google.android.exoplayer2.extractor.mp3.Mp3Extractor.Flags int flags)
Deprecated.- Parameters:
flags- Flags that control the extractor's behavior.
-
Mp3Extractor
public Mp3Extractor(@com.google.android.exoplayer2.extractor.mp3.Mp3Extractor.Flags int flags, long forcedFirstSampleTimestampUs)Deprecated.- Parameters:
flags- Flags that control the extractor's behavior.forcedFirstSampleTimestampUs- A timestamp to force for the first sample, orC.TIME_UNSETif forcing is not required.
-
-
Method Detail
-
sniff
public boolean sniff(ExtractorInput input) throws IOException
Deprecated.Description copied from interface:ExtractorReturns whether this extractor can extract samples from theExtractorInput, which must provide data from the start of the stream.If
trueis returned, theinput's reading position may have been modified. Otherwise, only its peek position may have been modified.- Specified by:
sniffin interfaceExtractor- Parameters:
input- TheExtractorInputfrom 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:ExtractorInitializes the extractor with anExtractorOutput. Called at most once.- Specified by:
initin interfaceExtractor- Parameters:
output- AnExtractorOutputto receive extracted data.
-
seek
public void seek(long position, long timeUs)Deprecated.Description copied from interface:ExtractorNotifies the extractor that a seek has occurred.Following a call to this method, the
ExtractorInputpassed to the next invocation ofExtractor.read(ExtractorInput, PositionHolder)is required to provide data starting frompositionin the stream. Valid random access positions are the start of the stream and positions that can be obtained from anySeekMappassed to theExtractorOutput.
-
release
public void release()
Deprecated.Description copied from interface:ExtractorReleases all kept resources.
-
read
public int read(ExtractorInput input, PositionHolder seekPosition) throws IOException
Deprecated.Description copied from interface:ExtractorExtracts 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_CONTINUEis returned to indicate that theExtractorInputpassed 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 inseekPositionandExtractor.RESULT_SEEKis returned. If the extractor reached the end of the data provided by theExtractorInput, thenExtractor.RESULT_END_OF_INPUTis returned.When this method throws an
IOException, extraction may continue by providing anExtractorInputwith an unchangedread positionto a subsequent call to this method.- Specified by:
readin interfaceExtractor- Parameters:
input- TheExtractorInputfrom which data should be read.seekPosition- IfExtractor.RESULT_SEEKis 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.
-
disableSeeking
public void disableSeeking()
Deprecated.Disables the extractor from being able to seek through the media.Please note that this needs to be called before
read(com.google.android.exoplayer2.extractor.ExtractorInput, com.google.android.exoplayer2.extractor.PositionHolder).
-
-