SeekMap.Unseekable
Modifier and Type | Field and Description |
---|---|
static ExtractorsFactory |
FACTORY
Factory for
FlvExtractor instances. |
int |
tagDataSize |
long |
tagTimestampUs |
int |
tagType |
RESULT_CONTINUE, RESULT_END_OF_INPUT, RESULT_SEEK
Constructor and Description |
---|
FlvExtractor() |
Modifier and Type | Method and Description |
---|---|
long |
getDurationUs()
Returns the duration of the stream in microseconds.
|
long |
getPosition(long timeUs)
Maps a seek position in microseconds to a corresponding position (byte offset) in the stream
from which data can be provided to the extractor.
|
void |
init(ExtractorOutput output)
Initializes the extractor with an
ExtractorOutput . |
boolean |
isSeekable()
Returns whether seeking is supported.
|
int |
read(ExtractorInput input,
PositionHolder seekPosition)
Extracts data read from a provided
ExtractorInput . |
void |
release()
Releases all kept resources.
|
void |
seek(long position)
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
FlvExtractor
instances.public int tagType
public int tagDataSize
public long tagTimestampUs
public boolean sniff(ExtractorInput input) throws IOException, InterruptedException
Extractor
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.
sniff
in interface Extractor
input
- The ExtractorInput
from which data should be peeked/read.IOException
- If an error occurred reading from the input.InterruptedException
- If the thread was interrupted.public void init(ExtractorOutput output)
Extractor
ExtractorOutput
. Called at most once.init
in interface Extractor
output
- An ExtractorOutput
to receive extracted data.public void seek(long position)
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()
Extractor
public int read(ExtractorInput input, PositionHolder seekPosition) throws IOException, InterruptedException
Extractor
ExtractorInput
.
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 Extractor
input
- 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.IOException
- If an error occurred reading from the input.InterruptedException
- If the thread was interrupted.public boolean isSeekable()
SeekMap
If seeking is not supported then the only valid seek position is the start of the file, and so
SeekMap.getPosition(long)
will return 0 for all input values.
isSeekable
in interface SeekMap
public long getDurationUs()
SeekMap
getDurationUs
in interface SeekMap
C.TIME_UNSET
if the
duration is unknown.public long getPosition(long timeUs)
SeekMap
getPosition
in interface SeekMap
timeUs
- A seek position in microseconds.#isSeekable()
returns false.