TsExtractor
@UnstableApi
public final class TsExtractor implements Extractor
Extracts data from the MPEG-2 TS container format.
Summary
Nested types |
|---|
@DocumentedFlags controlling the behavior of the extractor. |
@DocumentedModes for the extractor. |
Constants |
|
|---|---|
static final int |
DEFAULT_TIMESTAMP_SEARCH_BYTES = 112800 |
static final ExtractorsFactory |
This field is deprecated. Use |
static final int |
Flag to use the source subtitle formats without modification. |
static final int |
MODE_HLS = 2Enable single PMT mode, map |
static final int |
MODE_MULTI_PMT = 0Behave as defined in ISO/IEC 13818-1. |
static final int |
MODE_SINGLE_PMT = 1Assume only one PMT will be contained in the stream, even if more are declared by the PAT. |
static final int |
TS_PACKET_SIZE = 188 |
static final int |
|
static final int |
|
static final int |
TS_STREAM_TYPE_AC3 = 129 |
static final int |
TS_STREAM_TYPE_AC4 = 172 |
static final int |
TS_STREAM_TYPE_AIT = 257 |
static final int |
TS_STREAM_TYPE_DC2_H262 = 128 |
static final int |
TS_STREAM_TYPE_DTS = 138 |
static final int |
TS_STREAM_TYPE_DTS_HD = 136 |
static final int |
TS_STREAM_TYPE_DTS_UHD = 139 |
static final int |
|
static final int |
TS_STREAM_TYPE_E_AC3 = 135 |
static final int |
|
static final int |
TS_STREAM_TYPE_H263 = 16 |
static final int |
TS_STREAM_TYPE_H264 = 27 |
static final int |
TS_STREAM_TYPE_H265 = 36 |
static final int |
TS_STREAM_TYPE_HDMV_DTS = 130 |
static final int |
TS_STREAM_TYPE_ID3 = 21 |
static final int |
TS_STREAM_TYPE_MHAS = 45 |
static final int |
|
static final int |
|
static final int |
|
static final int |
TS_SYNC_BYTE = 71 |
Public constructors |
|---|
|
This method is deprecated. Use |
This method is deprecated. Use |
TsExtractor(SubtitleParser.Factory subtitleParserFactory)Constructs an instance. |
TsExtractor(Constructs an instance. |
This method is deprecated. Use |
This method is deprecated. Use |
This method is deprecated. Use |
TsExtractor(Constructs an instance. |
Public methods |
|
|---|---|
void |
init(ExtractorOutput output)Initializes the extractor with an |
static ExtractorsFactory |
newFactory(SubtitleParser.Factory subtitleParserFactory)Creates a factory for |
int |
@Extractor.ReadResultExtracts data read from a provided |
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 |
Inherited Constants |
||||||
|---|---|---|---|---|---|---|
|
Inherited methods |
||||
|---|---|---|---|---|
|
Constants
FLAG_EMIT_RAW_SUBTITLE_DATA
public static final int FLAG_EMIT_RAW_SUBTITLE_DATA = 1
Flag to use the source subtitle formats without modification. If unset, subtitles will be transcoded to APPLICATION_MEDIA3_CUES during extraction.
MODE_HLS
public static final int MODE_HLS = 2
Enable single PMT mode, map TrackOutputs by their type (instead of PID) and ignore continuity counters.
MODE_SINGLE_PMT
public static final int MODE_SINGLE_PMT = 1
Assume only one PMT will be contained in the stream, even if more are declared by the PAT.
Public constructors
TsExtractor
publicTsExtractor(
@DefaultTsPayloadReaderFactory.Flags int defaultTsPayloadReaderFlags
)
TsExtractor
public TsExtractor(SubtitleParser.Factory subtitleParserFactory)
Constructs an instance.
| Parameters | |
|---|---|
SubtitleParser.Factory subtitleParserFactory |
The |
TsExtractor
public TsExtractor(
@TsExtractor.Flags int extractorFlags,
SubtitleParser.Factory subtitleParserFactory
)
Constructs an instance.
| Parameters | |
|---|---|
@TsExtractor.Flags int extractorFlags |
Flags that control the extractor's behavior. |
SubtitleParser.Factory subtitleParserFactory |
The |
TsExtractor
publicTsExtractor(
@TsExtractor.Mode int mode,
@DefaultTsPayloadReaderFactory.Flags int defaultTsPayloadReaderFlags,
int timestampSearchBytes
)
TsExtractor
publicTsExtractor(
@TsExtractor.Mode int mode,
TimestampAdjuster timestampAdjuster,
TsPayloadReader.Factory payloadReaderFactory
)
TsExtractor
publicTsExtractor(
@TsExtractor.Mode int mode,
TimestampAdjuster timestampAdjuster,
TsPayloadReader.Factory payloadReaderFactory,
int timestampSearchBytes
)
TsExtractor
public TsExtractor(
@TsExtractor.Mode int mode,
@TsExtractor.Flags int extractorFlags,
SubtitleParser.Factory subtitleParserFactory,
TimestampAdjuster timestampAdjuster,
TsPayloadReader.Factory payloadReaderFactory,
int timestampSearchBytes
)
Constructs an instance.
| Parameters | |
|---|---|
@TsExtractor.Mode int mode |
Mode for the extractor. One of |
@TsExtractor.Flags int extractorFlags |
Flags that control the extractor's behavior. |
SubtitleParser.Factory subtitleParserFactory |
The |
TimestampAdjuster timestampAdjuster |
A timestamp adjuster for offsetting and scaling sample timestamps. |
TsPayloadReader.Factory payloadReaderFactory |
Factory for injecting a custom set of payload readers. |
int 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 of |
Public methods
init
public void init(ExtractorOutput output)
Initializes the extractor with an ExtractorOutput. Called at most once.
| Parameters | |
|---|---|
ExtractorOutput output |
An |
newFactory
public static ExtractorsFactory newFactory(SubtitleParser.Factory subtitleParserFactory)
Creates a factory for TsExtractor instances with the provided SubtitleParser.Factory.
read
@Extractor.ReadResult
public int read(ExtractorInput input, PositionHolder seekPosition)
Extracts data read from a provided ExtractorInput. Must not be called before init.
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, 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 RESULT_SEEK is returned. If the extractor reached the end of the data provided by the ExtractorInput, then RESULT_END_OF_INPUT is returned.
When this method throws an IOException, extraction may continue by providing an ExtractorInput with an unchanged read position to a subsequent call to this method.
| Parameters | |
|---|---|
ExtractorInput input |
The |
PositionHolder seekPosition |
If |
| Returns | |
|---|---|
int |
One of the |
| Throws | |
|---|---|
java.io.IOException |
If an error occurred reading from or parsing the input. |
seek
public void seek(long position, long timeUs)
Notifies the extractor that a seek has occurred.
Following a call to this method, the ExtractorInput passed to the next invocation of read 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.
| Parameters | |
|---|---|
long position |
The byte offset in the stream from which data will be provided. |
long timeUs |
The seek time in microseconds. |
sniff
public boolean sniff(ExtractorInput input)
Returns whether this extractor can extract samples from the ExtractorInput, 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.
| Parameters | |
|---|---|
ExtractorInput input |
The |
| Returns | |
|---|---|
boolean |
Whether this extractor can read the provided input. |
| Throws | |
|---|---|
java.io.IOException |
If an error occurred reading from the input. |