| Modifier and Type | Class and Description |
|---|---|
static interface |
TsExtractor.Mode
Modes for the extractor.
|
| Modifier and Type | Field and Description |
|---|---|
static ExtractorsFactory |
FACTORY
Factory for
TsExtractor instances. |
static int |
MODE_HLS
Enable single PMT mode, map
TrackOutputs by their type (instead of PID) and ignore
continuity counters. |
static int |
MODE_MULTI_PMT
Behave as defined in ISO/IEC 13818-1.
|
static int |
MODE_SINGLE_PMT
Assume only one PMT will be contained in the stream, even if more are declared by the PAT.
|
static int |
TS_STREAM_TYPE_AAC_ADTS |
static int |
TS_STREAM_TYPE_AAC_LATM |
static int |
TS_STREAM_TYPE_AC3 |
static int |
TS_STREAM_TYPE_DTS |
static int |
TS_STREAM_TYPE_DVBSUBS |
static int |
TS_STREAM_TYPE_E_AC3 |
static int |
TS_STREAM_TYPE_H262 |
static int |
TS_STREAM_TYPE_H264 |
static int |
TS_STREAM_TYPE_H265 |
static int |
TS_STREAM_TYPE_HDMV_DTS |
static int |
TS_STREAM_TYPE_ID3 |
static int |
TS_STREAM_TYPE_MPA |
static int |
TS_STREAM_TYPE_MPA_LSF |
static int |
TS_STREAM_TYPE_SPLICE_INFO |
RESULT_CONTINUE, RESULT_END_OF_INPUT, RESULT_SEEK| Constructor and Description |
|---|
TsExtractor() |
TsExtractor(int defaultTsPayloadReaderFlags) |
TsExtractor(int mode,
int defaultTsPayloadReaderFlags) |
TsExtractor(int mode,
TimestampAdjuster timestampAdjuster,
TsPayloadReader.Factory payloadReaderFactory) |
| 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
TsExtractor instances.public static final int MODE_MULTI_PMT
public static final int MODE_SINGLE_PMT
public static final int MODE_HLS
TrackOutputs by their type (instead of PID) and ignore
continuity counters.public static final int TS_STREAM_TYPE_MPA
public static final int TS_STREAM_TYPE_MPA_LSF
public static final int TS_STREAM_TYPE_AAC_ADTS
public static final int TS_STREAM_TYPE_AAC_LATM
public static final int TS_STREAM_TYPE_AC3
public static final int TS_STREAM_TYPE_DTS
public static final int TS_STREAM_TYPE_HDMV_DTS
public static final int TS_STREAM_TYPE_E_AC3
public static final int TS_STREAM_TYPE_H262
public static final int TS_STREAM_TYPE_H264
public static final int TS_STREAM_TYPE_H265
public static final int TS_STREAM_TYPE_ID3
public static final int TS_STREAM_TYPE_SPLICE_INFO
public static final int TS_STREAM_TYPE_DVBSUBS
public TsExtractor()
public TsExtractor(int defaultTsPayloadReaderFlags)
defaultTsPayloadReaderFlags - A combination of DefaultTsPayloadReaderFactory
FLAG_* values that control the behavior of the payload readers.public TsExtractor(int mode,
int defaultTsPayloadReaderFlags)
mode - Mode for the extractor. One of MODE_MULTI_PMT, MODE_SINGLE_PMT
and MODE_HLS.defaultTsPayloadReaderFlags - A combination of DefaultTsPayloadReaderFactory
FLAG_* values that control the behavior of the payload readers.public TsExtractor(int mode,
TimestampAdjuster timestampAdjuster,
TsPayloadReader.Factory payloadReaderFactory)
mode - Mode for the extractor. One of MODE_MULTI_PMT, MODE_SINGLE_PMT
and MODE_HLS.timestampAdjuster - A timestamp adjuster for offsetting and scaling sample timestamps.payloadReaderFactory - Factory for injecting a custom set of payload readers.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.