Class TsExtractor
- java.lang.Object
-
- com.google.android.exoplayer2.extractor.ts.TsExtractor
-
- All Implemented Interfaces:
Extractor
@Deprecated public final class TsExtractor 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 MPEG-2 TS container format.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static interface
TsExtractor.Mode
Deprecated.Modes for 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 int
DEFAULT_TIMESTAMP_SEARCH_BYTES
Deprecated.static ExtractorsFactory
FACTORY
Deprecated.Factory forTsExtractor
instances.static int
MODE_HLS
Deprecated.Enable single PMT mode, mapTrackOutput
s by their type (instead of PID) and ignore continuity counters.static int
MODE_MULTI_PMT
Deprecated.Behave as defined in ISO/IEC 13818-1.static int
MODE_SINGLE_PMT
Deprecated.Assume only one PMT will be contained in the stream, even if more are declared by the PAT.static int
TS_PACKET_SIZE
Deprecated.static int
TS_STREAM_TYPE_AAC_ADTS
Deprecated.static int
TS_STREAM_TYPE_AAC_LATM
Deprecated.static int
TS_STREAM_TYPE_AC3
Deprecated.static int
TS_STREAM_TYPE_AC4
Deprecated.static int
TS_STREAM_TYPE_AIT
Deprecated.static int
TS_STREAM_TYPE_DC2_H262
Deprecated.static int
TS_STREAM_TYPE_DTS
Deprecated.static int
TS_STREAM_TYPE_DVBSUBS
Deprecated.static int
TS_STREAM_TYPE_E_AC3
Deprecated.static int
TS_STREAM_TYPE_H262
Deprecated.static int
TS_STREAM_TYPE_H263
Deprecated.static int
TS_STREAM_TYPE_H264
Deprecated.static int
TS_STREAM_TYPE_H265
Deprecated.static int
TS_STREAM_TYPE_HDMV_DTS
Deprecated.static int
TS_STREAM_TYPE_ID3
Deprecated.static int
TS_STREAM_TYPE_MPA
Deprecated.static int
TS_STREAM_TYPE_MPA_LSF
Deprecated.static int
TS_STREAM_TYPE_SPLICE_INFO
Deprecated.static int
TS_SYNC_BYTE
Deprecated.-
Fields inherited from interface com.google.android.exoplayer2.extractor.Extractor
RESULT_CONTINUE, RESULT_END_OF_INPUT, RESULT_SEEK
-
-
Constructor Summary
Constructors Constructor Description TsExtractor()
Deprecated.TsExtractor(@com.google.android.exoplayer2.extractor.ts.DefaultTsPayloadReaderFactory.Flags int defaultTsPayloadReaderFlags)
Deprecated.TsExtractor(@com.google.android.exoplayer2.extractor.ts.TsExtractor.Mode int mode, @com.google.android.exoplayer2.extractor.ts.DefaultTsPayloadReaderFactory.Flags int defaultTsPayloadReaderFlags, int timestampSearchBytes)
Deprecated.TsExtractor(@com.google.android.exoplayer2.extractor.ts.TsExtractor.Mode int mode, TimestampAdjuster timestampAdjuster, TsPayloadReader.Factory payloadReaderFactory)
Deprecated.TsExtractor(@com.google.android.exoplayer2.extractor.ts.TsExtractor.Mode int mode, TimestampAdjuster timestampAdjuster, TsPayloadReader.Factory payloadReaderFactory, int timestampSearchBytes)
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
.@com.google.android.exoplayer2.extractor.Extractor.ReadResult 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 forTsExtractor
instances.
-
MODE_MULTI_PMT
public static final int MODE_MULTI_PMT
Deprecated.Behave as defined in ISO/IEC 13818-1.- See Also:
- Constant Field Values
-
MODE_SINGLE_PMT
public static final int MODE_SINGLE_PMT
Deprecated.Assume only one PMT will be contained in the stream, even if more are declared by the PAT.- See Also:
- Constant Field Values
-
MODE_HLS
public static final int MODE_HLS
Deprecated.Enable single PMT mode, mapTrackOutput
s by their type (instead of PID) and ignore continuity counters.- See Also:
- Constant Field Values
-
TS_PACKET_SIZE
public static final int TS_PACKET_SIZE
Deprecated.- See Also:
- Constant Field Values
-
DEFAULT_TIMESTAMP_SEARCH_BYTES
public static final int DEFAULT_TIMESTAMP_SEARCH_BYTES
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_MPA
public static final int TS_STREAM_TYPE_MPA
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_MPA_LSF
public static final int TS_STREAM_TYPE_MPA_LSF
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_AAC_ADTS
public static final int TS_STREAM_TYPE_AAC_ADTS
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_AAC_LATM
public static final int TS_STREAM_TYPE_AAC_LATM
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_AC3
public static final int TS_STREAM_TYPE_AC3
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_DTS
public static final int TS_STREAM_TYPE_DTS
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_HDMV_DTS
public static final int TS_STREAM_TYPE_HDMV_DTS
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_E_AC3
public static final int TS_STREAM_TYPE_E_AC3
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_AC4
public static final int TS_STREAM_TYPE_AC4
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_H262
public static final int TS_STREAM_TYPE_H262
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_H263
public static final int TS_STREAM_TYPE_H263
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_H264
public static final int TS_STREAM_TYPE_H264
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_H265
public static final int TS_STREAM_TYPE_H265
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_ID3
public static final int TS_STREAM_TYPE_ID3
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_SPLICE_INFO
public static final int TS_STREAM_TYPE_SPLICE_INFO
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_DVBSUBS
public static final int TS_STREAM_TYPE_DVBSUBS
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_DC2_H262
public static final int TS_STREAM_TYPE_DC2_H262
Deprecated.- See Also:
- Constant Field Values
-
TS_STREAM_TYPE_AIT
public static final int TS_STREAM_TYPE_AIT
Deprecated.- See Also:
- Constant Field Values
-
TS_SYNC_BYTE
public static final int TS_SYNC_BYTE
Deprecated.- See Also:
- Constant Field Values
-
-
Constructor Detail
-
TsExtractor
public TsExtractor()
Deprecated.
-
TsExtractor
public TsExtractor(@com.google.android.exoplayer2.extractor.ts.DefaultTsPayloadReaderFactory.Flags int defaultTsPayloadReaderFlags)
Deprecated.- Parameters:
defaultTsPayloadReaderFlags
- A combination ofDefaultTsPayloadReaderFactory
FLAG_*
values that control the behavior of the payload readers.
-
TsExtractor
public TsExtractor(@com.google.android.exoplayer2.extractor.ts.TsExtractor.Mode int mode, @com.google.android.exoplayer2.extractor.ts.DefaultTsPayloadReaderFactory.Flags int defaultTsPayloadReaderFlags, int timestampSearchBytes)
Deprecated.- Parameters:
mode
- Mode for the extractor. One ofMODE_MULTI_PMT
,MODE_SINGLE_PMT
andMODE_HLS
.defaultTsPayloadReaderFlags
- A combination ofDefaultTsPayloadReaderFactory
FLAG_*
values that control the behavior of the payload readers.timestampSearchBytes
- The number of bytes searched from a given position in the stream to find a PCR timestamp. If this value is too small, the duration might be unknown and seeking might not be supported for high bitrate progressive streams. Setting a large value for this field might be inefficient though because the extractor stores a buffer oftimestampSearchBytes
bytes when determining the duration or when performing a seek operation. The default value isDEFAULT_TIMESTAMP_SEARCH_BYTES
. If the number of bytes left in the stream from the current position is less thantimestampSearchBytes
, the search is performed on the bytes left.
-
TsExtractor
public TsExtractor(@com.google.android.exoplayer2.extractor.ts.TsExtractor.Mode int mode, TimestampAdjuster timestampAdjuster, TsPayloadReader.Factory payloadReaderFactory)
Deprecated.- Parameters:
mode
- Mode for the extractor. One ofMODE_MULTI_PMT
,MODE_SINGLE_PMT
andMODE_HLS
.timestampAdjuster
- A timestamp adjuster for offsetting and scaling sample timestamps.payloadReaderFactory
- Factory for injecting a custom set of payload readers.
-
TsExtractor
public TsExtractor(@com.google.android.exoplayer2.extractor.ts.TsExtractor.Mode int mode, TimestampAdjuster timestampAdjuster, TsPayloadReader.Factory payloadReaderFactory, int timestampSearchBytes)
Deprecated.- Parameters:
mode
- Mode for the extractor. One ofMODE_MULTI_PMT
,MODE_SINGLE_PMT
andMODE_HLS
.timestampAdjuster
- A timestamp adjuster for offsetting and scaling sample timestamps.payloadReaderFactory
- Factory for injecting a custom set of payload readers.timestampSearchBytes
- The number of bytes searched from a given position in the stream to find a PCR timestamp. If this value is too small, the duration might be unknown and seeking might not be supported for high bitrate progressive streams. Setting a large value for this field might be inefficient though because the extractor stores a buffer oftimestampSearchBytes
bytes when determining the duration or when performing a seek operation. The default value isDEFAULT_TIMESTAMP_SEARCH_BYTES
. If the number of bytes left in the stream from the current position is less thantimestampSearchBytes
, the search is performed on the bytes left.
-
-
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 @com.google.android.exoplayer2.extractor.Extractor.ReadResult 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.
-
-