docs/doc/reference/com/google/android/exoplayer2/mediacodec/MediaCodecRenderer.html
Package com.google.android.exoplayer2.mediacodec
All Implemented Interfaces:PlayerMessage.Target, Renderer, RendererCapabilitiesDirect Known Subclasses:MediaCodecAudioRenderer, MediaCodecVideoRenderer
[@Deprecated](https://developer.android.com/reference/java/lang/Deprecated.html "class or interface in java.lang")public abstract classMediaCodecRendererextends[BaseRenderer](../BaseRenderer.html "class in com.google.android.exoplayer2")
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.
An abstract renderer that uses MediaCodec to decode samples for rendering.
Nested Classes | Modifier and Type | Class | Description |
| --- | --- | --- |
| static class | MediaCodecRenderer.DecoderInitializationException |
Deprecated.
Thrown when a failure occurs instantiating a decoder. |
-
Renderer.MessageType, Renderer.State, Renderer.WakeupListener
-
RendererCapabilities.AdaptiveSupport, RendererCapabilities.Capabilities, RendererCapabilities.DecoderSupport, RendererCapabilities.FormatSupport, RendererCapabilities.HardwareAccelerationSupport, RendererCapabilities.Listener, RendererCapabilities.TunnelingSupport
Fields | Modifier and Type | Field | Description |
| --- | --- | --- |
| protected static float | CODEC_OPERATING_RATE_UNSET |
Deprecated.
Indicates no codec operating rate should be set.
|
| protected DecoderCounters | decoderCounters |
Deprecated.
|
-
MSG_CUSTOM_BASE, MSG_SET_AUDIO_ATTRIBUTES, MSG_SET_AUDIO_SESSION_ID, MSG_SET_AUX_EFFECT_INFO, MSG_SET_CAMERA_MOTION_LISTENER, MSG_SET_CHANGE_FRAME_RATE_STRATEGY, MSG_SET_PREFERRED_AUDIO_DEVICE, MSG_SET_SCALING_MODE, MSG_SET_SKIP_SILENCE_ENABLED, MSG_SET_VIDEO_EFFECTS, MSG_SET_VIDEO_FRAME_METADATA_LISTENER, MSG_SET_VIDEO_OUTPUT, MSG_SET_VIDEO_OUTPUT_RESOLUTION, MSG_SET_VOLUME, MSG_SET_WAKEUP_LISTENER, STATE_DISABLED, STATE_ENABLED, STATE_STARTED
-
ADAPTIVE_NOT_SEAMLESS, ADAPTIVE_NOT_SUPPORTED, ADAPTIVE_SEAMLESS, ADAPTIVE_SUPPORT_MASK, DECODER_SUPPORT_FALLBACK, DECODER_SUPPORT_FALLBACK_MIMETYPE, DECODER_SUPPORT_PRIMARY, FORMAT_EXCEEDS_CAPABILITIES, FORMAT_HANDLED, FORMAT_SUPPORT_MASK, FORMAT_UNSUPPORTED_DRM, FORMAT_UNSUPPORTED_SUBTYPE, FORMAT_UNSUPPORTED_TYPE, HARDWARE_ACCELERATION_NOT_SUPPORTED, HARDWARE_ACCELERATION_SUPPORT_MASK, HARDWARE_ACCELERATION_SUPPORTED, MODE_SUPPORT_MASK, TUNNELING_NOT_SUPPORTED, TUNNELING_SUPPORT_MASK, TUNNELING_SUPPORTED
Constructors | Constructor | Description |
| --- | --- |
| MediaCodecRenderer(@com.google.android.exoplayer2.C.TrackType int trackType, MediaCodecAdapter.Factory codecAdapterFactory, MediaCodecSelector mediaCodecSelector, boolean enableDecoderFallback, float assumedMinimumCodecOperatingRate) |
Deprecated.
|
All Methods Static Methods Instance Methods Abstract Methods Concrete Methods Deprecated Methods | Modifier and Type | Method | Description |
| --- | --- | --- |
| protected DecoderReuseEvaluation | canReuseCodec(MediaCodecInfo codecInfo, Format oldFormat, Format newFormat) |
Deprecated.
Evaluates whether the existing MediaCodec can be kept for a new Format, and if it can whether it requires reconfiguration.
|
| protected MediaCodecDecoderException | createDecoderException(Throwable cause, MediaCodecInfo codecInfo) |
Deprecated.
|
| protected boolean | flushOrReinitializeCodec() |
Deprecated.
Flushes the codec.
|
| protected boolean | flushOrReleaseCodec() |
Deprecated.
Flushes the codec.
|
| protected MediaCodecAdapter | getCodec() |
Deprecated.
|
| protected MediaCodecInfo | getCodecInfo() |
Deprecated.
|
| protected boolean | getCodecNeedsEosPropagation() |
Deprecated.
Returns whether the codec needs the renderer to propagate the end-of-stream signal directly, rather than by using an end-of-stream buffer queued to the codec.
|
| protected float | getCodecOperatingRate() |
Deprecated.
Returns the operating rate used by the current codec
|
| protected float | getCodecOperatingRateV23(float targetPlaybackSpeed, Format format, Format[] streamFormats) |
Deprecated.
Returns the MediaFormat.KEY_OPERATING_RATE value for a given playback speed, current Format and set of possible stream formats.
|
| protected MediaFormat | getCodecOutputMediaFormat() |
Deprecated.
|
| protected abstract List<MediaCodecInfo> | getDecoderInfos(MediaCodecSelector mediaCodecSelector, Format format, boolean requiresSecureDecoder) |
Deprecated.
Returns a list of decoders that can decode media in the specified format, in priority order.
|
| protected abstract MediaCodecAdapter.Configuration | getMediaCodecConfiguration(MediaCodecInfo codecInfo, Format format, MediaCrypto crypto, float codecOperatingRate) |
Deprecated.
Returns the MediaCodecAdapter.Configuration that will be used to create and configure a MediaCodec to decode the given Format for a playback.
|
| protected long | getOutputStreamOffsetUs() |
Deprecated.
Returns the offset that should be subtracted from bufferPresentationTimeUs in processOutputBuffer(long, long, MediaCodecAdapter, ByteBuffer, int, int, int, long, boolean, boolean, Format) to get the playback position with respect to the media.
|
| protected float | getPlaybackSpeed() |
Deprecated.
Returns the current playback speed, as set by setPlaybackSpeed(float, float).
|
| protected void | handleInputBufferSupplementalData(DecoderInputBuffer buffer) |
Deprecated.
Handles supplemental data associated with an input buffer.
|
| protected boolean | isBypassPossible(Format format) |
Deprecated.
Returns whether buffers in the input format can be processed without a codec.
|
| boolean | isEnded() |
Deprecated.
Whether the renderer is ready for the ExoPlayer instance to transition to Player.STATE_ENDED.
|
| boolean | isReady() |
Deprecated.
Whether the renderer is able to immediately render media from the current position.
|
| protected void | maybeInitCodecOrBypass() |
Deprecated.
|
| protected void | onCodecError(Exception codecError) |
Deprecated.
Called when a codec error has occurred.
|
| protected void | onCodecInitialized(String name, MediaCodecAdapter.Configuration configuration, long initializedTimestampMs, long initializationDurationMs) |
Deprecated.
Called when a MediaCodec has been created and configured.
|
| protected void | onCodecReleased(String name) |
Deprecated.
Called when a MediaCodec has been released.
|
| protected void | onDisabled() |
Deprecated.
Called when the renderer is disabled.
|
| protected void | onEnabled(boolean joining, boolean mayRenderStartOfStream) |
Deprecated.
Called when the renderer is enabled.
|
| protected DecoderReuseEvaluation | onInputFormatChanged(FormatHolder formatHolder) |
Deprecated.
Called when a new Format is read from the upstream MediaPeriod.
|
| protected void | onOutputFormatChanged(Format format, MediaFormat mediaFormat) |
Deprecated.
Called when one of the output formats changes.
|
| protected void | onOutputStreamOffsetUsChanged(long outputStreamOffsetUs) |
Deprecated.
Called after the output stream offset changes.
|
| protected void | onPositionReset(long positionUs, boolean joining) |
Deprecated.
Called when the position is reset.
|
| protected void | onProcessedOutputBuffer(long presentationTimeUs) |
Deprecated.
Called when an output buffer is successfully processed.
|
| protected void | onProcessedStreamChange() |
Deprecated.
Called after the last output buffer before a stream change has been processed.
|
| protected void | onQueueInputBuffer(DecoderInputBuffer buffer) |
Deprecated.
Called immediately before an input buffer is queued into the codec.
|
| protected void | onReadyToInitializeCodec(Format format) |
Deprecated.
Called when ready to initialize the MediaCodecAdapter.
|
| protected void | onReset() |
Deprecated.
Called when the renderer is reset.
|
| protected void | onStarted() |
Deprecated.
Called when the renderer is started.
|
| protected void | onStopped() |
Deprecated.
Called when the renderer is stopped.
|
| protected void | onStreamChanged(Format[] formats, long startPositionUs, long offsetUs) |
Deprecated.
Called when the renderer's stream has changed.
|
| protected abstract boolean | processOutputBuffer(long positionUs, long elapsedRealtimeUs, MediaCodecAdapter codec, ByteBuffer buffer, int bufferIndex, int bufferFlags, int sampleCount, long bufferPresentationTimeUs, boolean isDecodeOnlyBuffer, boolean isLastBuffer, Format format) |
Deprecated.
Processes an output media buffer.
|
| protected void | releaseCodec() |
Deprecated.
|
| void | render(long positionUs, long elapsedRealtimeUs) |
Deprecated.
Incrementally renders the SampleStream.
|
| protected void | renderToEndOfStream() |
Deprecated.
Incrementally renders any remaining output.
|
| protected void | resetCodecStateForFlush() |
Deprecated.
Resets the renderer internal state after a codec flush.
|
| protected void | resetCodecStateForRelease() |
Deprecated.
Resets the renderer internal state after a codec release.
|
| protected void | setPendingOutputEndOfStream() |
Deprecated.
Notifies the renderer that output end of stream is pending and should be handled on the next render.
|
| protected void | setPendingPlaybackException(ExoPlaybackException exception) |
Deprecated.
Sets an exception to be re-thrown by render.
|
| void | setPlaybackSpeed(float currentPlaybackSpeed, float targetPlaybackSpeed) |
Deprecated.
Indicates the playback speed to this renderer.
|
| void | setRenderTimeLimitMs(long renderTimeLimitMs) |
Deprecated.
Sets a limit on the time a single render(long, long) call can spend draining and filling the decoder.
|
| protected boolean | shouldInitCodec(MediaCodecInfo codecInfo) |
Deprecated.
|
| protected boolean | shouldReinitCodec() |
Deprecated.
Returns whether the renderer needs to re-initialize the codec, possibly as a result of a change in device capabilities.
|
| protected boolean | shouldUseBypass(Format format) |
Deprecated.
Returns whether buffers in the input format can be processed without a codec.
|
| @com.google.android.exoplayer2.RendererCapabilities.Capabilities int | supportsFormat(Format format) |
Deprecated.
Returns the extent to which the Renderer supports a given format.
|
| protected abstract @com.google.android.exoplayer2.RendererCapabilities.Capabilities int | supportsFormat(MediaCodecSelector mediaCodecSelector, Format format) |
Deprecated.
Returns the RendererCapabilities.Capabilities for the given Format.
|
| protected static boolean | supportsFormatDrm(Format format) |
Deprecated.
Returns whether this renderer supports the given Format's DRM scheme.
|
| @com.google.android.exoplayer2.RendererCapabilities.AdaptiveSupport int | supportsMixedMimeTypeAdaptation() |
Deprecated.
Returns the extent to which the Renderer supports adapting between supported formats that have different MIME types.
|
| protected boolean | updateCodecOperatingRate() |
Deprecated.
Updates the codec operating rate, or triggers codec release and re-initialization if a previously set operating rate needs to be cleared.
|
| protected void | updateOutputFormatForTime(long presentationTimeUs) |
Deprecated.
Updates the output formats for the specified output buffer timestamp, calling onOutputFormatChanged(com.google.android.exoplayer2.Format, android.media.MediaFormat) if a change has occurred.
|
-
clearListener, createRendererException, createRendererException, disable, enable, getCapabilities, getConfiguration, getFormatHolder, getIndex, getLastResetPositionUs, getMediaClock, getPlayerId, getReadingPositionUs, getState, getStream, getStreamFormats, getTrackType, handleMessage, hasReadStreamToEnd, init, isCurrentStreamFinal, isSourceReady, maybeThrowStreamError, onRelease, onRendererCapabilitiesChanged, readSource, release, replaceStream, reset, resetPosition, setCurrentStreamFinal, setListener, skipSource, start, stop
-
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
getName
-
getName
-
protected static final float CODEC_OPERATING_RATE_UNSET
Deprecated.
Indicates no codec operating rate should be set. See Also:Constant Field Values
-
protected[DecoderCounters](../decoder/DecoderCounters.html "class in com.google.android.exoplayer2.decoder")decoderCounters
Deprecated.
-
public MediaCodecRenderer(@com.google.android.exoplayer2.C.TrackType int trackType,[MediaCodecAdapter.Factory](MediaCodecAdapter.Factory.html "interface in com.google.android.exoplayer2.mediacodec")codecAdapterFactory,[MediaCodecSelector](MediaCodecSelector.html "interface in com.google.android.exoplayer2.mediacodec")mediaCodecSelector,
boolean enableDecoderFallback,
float assumedMinimumCodecOperatingRate)
Deprecated.
Parameters:trackType - The track type that the renderer handles.codecAdapterFactory - A factory for MediaCodecAdapter instances.mediaCodecSelector - A decoder selector.enableDecoderFallback - Whether to enable fallback to lower-priority decoders if decoder initialization fails. This may result in using a decoder that is less efficient or slower than the primary decoder.assumedMinimumCodecOperatingRate - A codec operating rate that all codecs instantiated by this renderer are assumed to meet implicitly (i.e. without the operating rate being set explicitly using MediaFormat.KEY_OPERATING_RATE).
-
public void setRenderTimeLimitMs(long renderTimeLimitMs)
Deprecated.
Sets a limit on the time a single render(long, long) call can spend draining and filling the decoder.
This method should be called right after creating an instance of this class.
Parameters:renderTimeLimitMs - The render time limit in milliseconds, or C.TIME_UNSET for no limit.
-
public final @com.google.android.exoplayer2.RendererCapabilities.AdaptiveSupport int supportsMixedMimeTypeAdaptation()
Deprecated.
Description copied from interface: RendererCapabilities
Returns the extent to which the Renderer supports adapting between supported formats that have different MIME types.
Specified by:supportsMixedMimeTypeAdaptation in interface RendererCapabilitiesOverrides:supportsMixedMimeTypeAdaptation in class BaseRendererReturns:The RendererCapabilities.AdaptiveSupport for adapting between supported formats that have different MIME types.
-
public final @com.google.android.exoplayer2.RendererCapabilities.Capabilities int supportsFormat([Format](../Format.html "class in com.google.android.exoplayer2")format)
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Description copied from interface: RendererCapabilities
Returns the extent to which the Renderer supports a given format.
Parameters:format - The format.Returns:The RendererCapabilities.Capabilities for this format.Throws:ExoPlaybackException - If an error occurs.
-
protected abstract @com.google.android.exoplayer2.RendererCapabilities.Capabilities int supportsFormat([MediaCodecSelector](MediaCodecSelector.html "interface in com.google.android.exoplayer2.mediacodec")mediaCodecSelector,[Format](../Format.html "class in com.google.android.exoplayer2")format)
throws[MediaCodecUtil.DecoderQueryException](MediaCodecUtil.DecoderQueryException.html "class in com.google.android.exoplayer2.mediacodec")
Deprecated.
Returns the RendererCapabilities.Capabilities for the given Format.
Parameters:mediaCodecSelector - The decoder selector.format - The Format.Returns:The RendererCapabilities.Capabilities for this Format.Throws:MediaCodecUtil.DecoderQueryException - If there was an error querying decoders.
-
protected abstract[List](https://developer.android.com/reference/java/util/List.html "class or interface in java.util")<[MediaCodecInfo](MediaCodecInfo.html "class in com.google.android.exoplayer2.mediacodec")> getDecoderInfos([MediaCodecSelector](MediaCodecSelector.html "interface in com.google.android.exoplayer2.mediacodec")mediaCodecSelector,[Format](../Format.html "class in com.google.android.exoplayer2")format,
boolean requiresSecureDecoder)
throws[MediaCodecUtil.DecoderQueryException](MediaCodecUtil.DecoderQueryException.html "class in com.google.android.exoplayer2.mediacodec")
Deprecated.
Returns a list of decoders that can decode media in the specified format, in priority order.
Parameters:mediaCodecSelector - The decoder selector.format - The Format for which a decoder is required.requiresSecureDecoder - Whether a secure decoder is required.Returns:A list of MediaCodecInfos corresponding to decoders. May be empty.Throws:MediaCodecUtil.DecoderQueryException - Thrown if there was an error querying decoders.
-
protected abstract[MediaCodecAdapter.Configuration](MediaCodecAdapter.Configuration.html "class in com.google.android.exoplayer2.mediacodec")getMediaCodecConfiguration([MediaCodecInfo](MediaCodecInfo.html "class in com.google.android.exoplayer2.mediacodec")codecInfo,[Format](../Format.html "class in com.google.android.exoplayer2")format,
@Nullable[MediaCrypto](https://developer.android.com/reference/android/media/MediaCrypto.html "class or interface in android.media")crypto,
float codecOperatingRate)
Deprecated.
Returns the MediaCodecAdapter.Configuration that will be used to create and configure a MediaCodec to decode the given Format for a playback.
Parameters:codecInfo - Information about the MediaCodec being configured.format - The Format for which the codec is being configured.crypto - For drm protected playbacks, a MediaCrypto to use for decryption.codecOperatingRate - The codec operating rate, or CODEC_OPERATING_RATE_UNSET if no codec operating rate should be set.Returns:The parameters needed to call MediaCodec.configure(android.media.MediaFormat, android.view.Surface, android.media.MediaCrypto, int).
-
protected final void maybeInitCodecOrBypass()
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Throws:ExoPlaybackException
-
protected final boolean isBypassPossible([Format](../Format.html "class in com.google.android.exoplayer2")format)
Deprecated.
Returns whether buffers in the input format can be processed without a codec.
This method returns the possibility of bypass mode with checking both the renderer capabilities and DRM protection.
Parameters:format - The input Format.Returns:Whether playback bypassing MediaCodec is possible.
-
protected boolean shouldUseBypass([Format](../Format.html "class in com.google.android.exoplayer2")format)
Deprecated.
Returns whether buffers in the input format can be processed without a codec.
This method is only called if the content is not DRM protected, because if the content is DRM protected use of bypass is never possible.
Parameters:format - The input Format.Returns:Whether playback bypassing MediaCodec is supported.
-
protected boolean shouldInitCodec([MediaCodecInfo](MediaCodecInfo.html "class in com.google.android.exoplayer2.mediacodec")codecInfo)
Deprecated.
-
protected boolean shouldReinitCodec()
Deprecated.
Returns whether the renderer needs to re-initialize the codec, possibly as a result of a change in device capabilities.
-
protected boolean getCodecNeedsEosPropagation()
Deprecated.
Returns whether the codec needs the renderer to propagate the end-of-stream signal directly, rather than by using an end-of-stream buffer queued to the codec.
-
protected final void setPendingPlaybackException([ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")exception)
Deprecated.
Sets an exception to be re-thrown by render.
Parameters:exception - The exception.
-
protected final void updateOutputFormatForTime(long presentationTimeUs)
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Updates the output formats for the specified output buffer timestamp, calling onOutputFormatChanged(com.google.android.exoplayer2.Format, android.media.MediaFormat) if a change has occurred.
Subclasses should only call this method if operating in a mode where buffers are not dequeued from the decoder, for example when using video tunneling).
Throws:ExoPlaybackException - Thrown if an error occurs as a result of the output format change.
-
@Nullable
protected final[MediaCodecAdapter](MediaCodecAdapter.html "interface in com.google.android.exoplayer2.mediacodec")getCodec()
Deprecated.
-
@Nullable
protected final[MediaFormat](https://developer.android.com/reference/android/media/MediaFormat.html "class or interface in android.media")getCodecOutputMediaFormat()
Deprecated.
-
@Nullable
protected final[MediaCodecInfo](MediaCodecInfo.html "class in com.google.android.exoplayer2.mediacodec")getCodecInfo()
Deprecated.
-
protected void onEnabled(boolean joining,
boolean mayRenderStartOfStream)
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Description copied from class: BaseRenderer
Called when the renderer is enabled.
The default implementation is a no-op.
Overrides:onEnabled in class BaseRendererParameters:joining - Whether this renderer is being enabled to join an ongoing playback.mayRenderStartOfStream - Whether this renderer is allowed to render the start of the stream even if the state is not Renderer.STATE_STARTED yet.Throws:ExoPlaybackException - If an error occurs.
-
protected void onStreamChanged([Format](../Format.html "class in com.google.android.exoplayer2")[] formats,
long startPositionUs,
long offsetUs)
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Description copied from class: BaseRenderer
Called when the renderer's stream has changed. This occurs when the renderer is enabled after BaseRenderer.onEnabled(boolean, boolean) has been called, and also when the stream has been replaced whilst the renderer is enabled or started.
The default implementation is a no-op.
Overrides:onStreamChanged in class BaseRendererParameters:formats - The enabled formats.startPositionUs - The start position of the new stream in renderer time (microseconds).offsetUs - The offset that will be added to the timestamps of buffers read via BaseRenderer.readSource(com.google.android.exoplayer2.FormatHolder, com.google.android.exoplayer2.decoder.DecoderInputBuffer, @com.google.android.exoplayer2.source.SampleStream.ReadFlags int) so that decoder input buffers have monotonically increasing timestamps.Throws:ExoPlaybackException - If an error occurs.
-
protected void onPositionReset(long positionUs,
boolean joining)
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Description copied from class: BaseRenderer
Called when the position is reset. This occurs when the renderer is enabled after BaseRenderer.onStreamChanged(Format[], long, long) has been called, and also when a position discontinuity is encountered.
After a position reset, the renderer's SampleStream is guaranteed to provide samples starting from a key frame.
The default implementation is a no-op.
Overrides:onPositionReset in class BaseRendererParameters:positionUs - The new playback position in microseconds.joining - Whether this renderer is being enabled to join an ongoing playback.Throws:ExoPlaybackException - If an error occurs.
-
public void setPlaybackSpeed(float currentPlaybackSpeed,
float targetPlaybackSpeed)
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Description copied from interface: Renderer
Indicates the playback speed to this renderer.
The default implementation is a no-op.
Parameters:currentPlaybackSpeed - The factor by which playback is currently sped up.targetPlaybackSpeed - The target factor by which playback should be sped up. This may be different from currentPlaybackSpeed, for example, if the speed is temporarily adjusted for live playback.Throws:ExoPlaybackException - If an error occurs handling the playback speed.
-
protected void onDisabled()
Deprecated.
Description copied from class: BaseRenderer
Called when the renderer is disabled.
The default implementation is a no-op.
Overrides:onDisabled in class BaseRenderer
-
protected void onReset()
Deprecated.
Description copied from class: BaseRenderer
Called when the renderer is reset.
The default implementation is a no-op.
Overrides:onReset in class BaseRenderer
-
protected void releaseCodec()
Deprecated.
-
protected void onStarted()
Deprecated.
Description copied from class: BaseRenderer
Called when the renderer is started.
The default implementation is a no-op.
Overrides:onStarted in class BaseRenderer
-
protected void onStopped()
Deprecated.
Description copied from class: BaseRenderer
Called when the renderer is stopped.
The default implementation is a no-op.
Overrides:onStopped in class BaseRenderer
-
public void render(long positionUs,
long elapsedRealtimeUs)
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Description copied from interface: Renderer
Incrementally renders the SampleStream.
If the renderer is in the Renderer.STATE_ENABLED state then each call to this method will do work toward being ready to render the SampleStream when the renderer is started. If the renderer is in the Renderer.STATE_STARTED state then calls to this method will render the SampleStream in sync with the specified media positions.
The renderer may also render the very start of the media at the current position (e.g. the first frame of a video stream) while still in the Renderer.STATE_ENABLED state, unless it's the initial start of the media after calling Renderer.enable(RendererConfiguration, Format[], SampleStream, long, boolean, boolean, long, long) with mayRenderStartOfStream set to false.
This method should return quickly, and should not block if the renderer is unable to make useful progress.
This method may be called when the renderer is in the following states: Renderer.STATE_ENABLED, Renderer.STATE_STARTED.
Parameters:positionUs - The current media time in microseconds, measured at the start of the current iteration of the rendering loop.elapsedRealtimeUs - SystemClock.elapsedRealtime() in microseconds, measured at the start of the current iteration of the rendering loop.Throws:ExoPlaybackException - If an error occurs.
-
protected final boolean flushOrReinitializeCodec()
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Flushes the codec. If flushing is not possible, the codec will be released and re-instantiated. This method is a no-op if the codec is null.
The implementation of this method calls flushOrReleaseCodec(), and maybeInitCodecOrBypass() if the codec needs to be re-instantiated.
Returns:Whether the codec was released and reinitialized, rather than being flushed.Throws:ExoPlaybackException - If an error occurs re-instantiating the codec.
-
protected boolean flushOrReleaseCodec()
Deprecated.
Flushes the codec. If flushing is not possible, the codec will be released. This method is a no-op if the codec is null.
Returns:Whether the codec was released.
-
@CallSuper
protected void resetCodecStateForFlush()
Deprecated.
Resets the renderer internal state after a codec flush.
-
@CallSuper
protected void resetCodecStateForRelease()
Deprecated.
Resets the renderer internal state after a codec release.
Note that this only needs to reset state variables that are changed in addition to those already changed in resetCodecStateForFlush().
-
protected[MediaCodecDecoderException](MediaCodecDecoderException.html "class in com.google.android.exoplayer2.mediacodec")createDecoderException([Throwable](https://developer.android.com/reference/java/lang/Throwable.html "class or interface in java.lang")cause,
@Nullable[MediaCodecInfo](MediaCodecInfo.html "class in com.google.android.exoplayer2.mediacodec")codecInfo)
Deprecated.
-
protected void onReadyToInitializeCodec([Format](../Format.html "class in com.google.android.exoplayer2")format)
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Called when ready to initialize the MediaCodecAdapter.
This method is called just before the renderer obtains the configuration for the MediaCodecAdapter and creates the adapter via the passed in MediaCodecAdapter.Factory.
The default implementation is a no-op.
Parameters:format - The Format for which the codec is being configured.Throws:ExoPlaybackException - If an error occurs preparing for initializing the codec.
-
protected void onCodecInitialized([String](https://developer.android.com/reference/java/lang/String.html "class or interface in java.lang")name,[MediaCodecAdapter.Configuration](MediaCodecAdapter.Configuration.html "class in com.google.android.exoplayer2.mediacodec")configuration,
long initializedTimestampMs,
long initializationDurationMs)
Deprecated.
Called when a MediaCodec has been created and configured.
The default implementation is a no-op.
Parameters:name - The name of the codec that was initialized.configuration - The MediaCodecAdapter.Configuration used to configure the codec.initializedTimestampMs - SystemClock.elapsedRealtime() when initialization finished.initializationDurationMs - The time taken to initialize the codec in milliseconds.
-
protected void onCodecReleased([String](https://developer.android.com/reference/java/lang/String.html "class or interface in java.lang")name)
Deprecated.
Called when a MediaCodec has been released.
The default implementation is a no-op.
Parameters:name - The name of the codec that was released.
-
protected void onCodecError([Exception](https://developer.android.com/reference/java/lang/Exception.html "class or interface in java.lang")codecError)
Deprecated.
Called when a codec error has occurred.
The default implementation is a no-op.
Parameters:codecError - The error.
-
@CallSuper
@Nullable
protected[DecoderReuseEvaluation](../decoder/DecoderReuseEvaluation.html "class in com.google.android.exoplayer2.decoder")onInputFormatChanged([FormatHolder](../FormatHolder.html "class in com.google.android.exoplayer2")formatHolder)
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Called when a new Format is read from the upstream MediaPeriod.
Parameters:formatHolder - A FormatHolder that holds the new Format.Returns:The result of the evaluation to determine whether the existing decoder instance can be reused for the new format, or null if the renderer did not have a decoder.Throws:ExoPlaybackException - If an error occurs re-initializing the MediaCodec.
-
protected void onOutputFormatChanged([Format](../Format.html "class in com.google.android.exoplayer2")format,
@Nullable[MediaFormat](https://developer.android.com/reference/android/media/MediaFormat.html "class or interface in android.media")mediaFormat)
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Called when one of the output formats changes.
The default implementation is a no-op.
Parameters:format - The input Format to which future output now corresponds. If the renderer is in bypass mode, this is also the output format.mediaFormat - The codec output MediaFormat, or null if the renderer is in bypass mode.Throws:ExoPlaybackException - Thrown if an error occurs configuring the output.
-
protected void handleInputBufferSupplementalData([DecoderInputBuffer](../decoder/DecoderInputBuffer.html "class in com.google.android.exoplayer2.decoder")buffer)
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Handles supplemental data associated with an input buffer.
The default implementation is a no-op.
Parameters:buffer - The input buffer that is about to be queued.Throws:ExoPlaybackException - Thrown if an error occurs handling supplemental data.
-
protected void onQueueInputBuffer([DecoderInputBuffer](../decoder/DecoderInputBuffer.html "class in com.google.android.exoplayer2.decoder")buffer)
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Called immediately before an input buffer is queued into the codec.
The default implementation is a no-op.
Parameters:buffer - The buffer to be queued.Throws:ExoPlaybackException - Thrown if an error occurs handling the input buffer.
-
@CallSuper
protected void onProcessedOutputBuffer(long presentationTimeUs)
Deprecated.
Called when an output buffer is successfully processed.
Parameters:presentationTimeUs - The timestamp associated with the output buffer.
-
protected void onProcessedStreamChange()
Deprecated.
Called after the last output buffer before a stream change has been processed.
-
protected[DecoderReuseEvaluation](../decoder/DecoderReuseEvaluation.html "class in com.google.android.exoplayer2.decoder")canReuseCodec([MediaCodecInfo](MediaCodecInfo.html "class in com.google.android.exoplayer2.mediacodec")codecInfo,[Format](../Format.html "class in com.google.android.exoplayer2")oldFormat,[Format](../Format.html "class in com.google.android.exoplayer2")newFormat)
Deprecated.
Evaluates whether the existing MediaCodec can be kept for a new Format, and if it can whether it requires reconfiguration.
The default implementation does not allow decoder reuse.
Parameters:codecInfo - A MediaCodecInfo describing the decoder.oldFormat - The Format for which the existing instance is configured.newFormat - The new Format.Returns:The result of the evaluation.
-
protected void onOutputStreamOffsetUsChanged(long outputStreamOffsetUs)
Deprecated.
Called after the output stream offset changes.
The default implementation is a no-op.
Parameters:outputStreamOffsetUs - The output stream offset in microseconds.
-
public boolean isEnded()
Deprecated.
Description copied from interface: Renderer
Whether the renderer is ready for the ExoPlayer instance to transition to Player.STATE_ENDED. The player will make this transition as soon as true is returned by all of its renderers.
This method may be called when the renderer is in the following states: Renderer.STATE_ENABLED, Renderer.STATE_STARTED.
Returns:Whether the renderer is ready for the player to transition to the ended state.
-
public boolean isReady()
Deprecated.
Description copied from interface: Renderer
Whether the renderer is able to immediately render media from the current position.
If the renderer is in the Renderer.STATE_STARTED state then returning true indicates that the renderer has everything that it needs to continue playback. Returning false indicates that the player should pause until the renderer is ready.
If the renderer is in the Renderer.STATE_ENABLED state then returning true indicates that the renderer is ready for playback to be started. Returning false indicates that it is not.
This method may be called when the renderer is in the following states: Renderer.STATE_ENABLED, Renderer.STATE_STARTED.
Returns:Whether the renderer is ready to render media.
-
protected float getPlaybackSpeed()
Deprecated.
Returns the current playback speed, as set by setPlaybackSpeed(float, float).
-
protected float getCodecOperatingRate()
Deprecated.
Returns the operating rate used by the current codec
-
protected float getCodecOperatingRateV23(float targetPlaybackSpeed,[Format](../Format.html "class in com.google.android.exoplayer2")format,[Format](../Format.html "class in com.google.android.exoplayer2")[] streamFormats)
Deprecated.
Returns the MediaFormat.KEY_OPERATING_RATE value for a given playback speed, current Format and set of possible stream formats.
The default implementation returns CODEC_OPERATING_RATE_UNSET.
Parameters:targetPlaybackSpeed - The target factor by which playback should be sped up. This may be different from the current playback speed, for example, if the speed is temporarily adjusted for live playback.format - The Format for which the codec is being configured.streamFormats - The possible stream formats.Returns:The codec operating rate, or CODEC_OPERATING_RATE_UNSET if no codec operating rate should be set.
-
protected final boolean updateCodecOperatingRate()
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Updates the codec operating rate, or triggers codec release and re-initialization if a previously set operating rate needs to be cleared.
Returns:False if codec release and re-initialization was triggered. True in all other cases.Throws:ExoPlaybackException - If an error occurs releasing or initializing a codec.
-
protected abstract boolean processOutputBuffer(long positionUs,
long elapsedRealtimeUs,
@Nullable[MediaCodecAdapter](MediaCodecAdapter.html "interface in com.google.android.exoplayer2.mediacodec")codec,
@Nullable[ByteBuffer](https://developer.android.com/reference/java/nio/ByteBuffer.html "class or interface in java.nio")buffer,
int bufferIndex,
int bufferFlags,
int sampleCount,
long bufferPresentationTimeUs,
boolean isDecodeOnlyBuffer,
boolean isLastBuffer,[Format](../Format.html "class in com.google.android.exoplayer2")format)
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Processes an output media buffer.
When a new ByteBuffer is passed to this method its position and limit delineate the data to be processed. The return value indicates whether the buffer was processed in full. If true is returned then the next call to this method will receive a new buffer to be processed. If false is returned then the same buffer will be passed to the next call. An implementation of this method is free to modify the buffer and can assume that the buffer will not be externally modified between successive calls. Hence an implementation can, for example, modify the buffer's position to keep track of how much of the data it has processed.
Note that the first call to this method following a call to onPositionReset(long, boolean) will always receive a new ByteBuffer to be processed.
Parameters:positionUs - The current media time in microseconds, measured at the start of the current iteration of the rendering loop.elapsedRealtimeUs - SystemClock.elapsedRealtime() in microseconds, measured at the start of the current iteration of the rendering loop.codec - The MediaCodecAdapter instance, or null in bypass mode were no codec is used.buffer - The output buffer to process, or null if the buffer data is not made available to the application layer (see MediaCodec.getOutputBuffer(int)). This buffer can only be null for video data. Note that the buffer data can still be rendered in this case by using the bufferIndex.bufferIndex - The index of the output buffer.bufferFlags - The flags attached to the output buffer.sampleCount - The number of samples extracted from the sample queue in the buffer. This allows handling multiple samples as a batch for efficiency.bufferPresentationTimeUs - The presentation time of the output buffer in microseconds.isDecodeOnlyBuffer - Whether the buffer was marked with C.BUFFER_FLAG_DECODE_ONLY by the source.isLastBuffer - Whether the buffer is known to contain the last sample of the current stream. This flag is set on a best effort basis, and any logic relying on it should degrade gracefully to handle cases where it's not set.format - The Format associated with the buffer.Returns:Whether the output buffer was fully processed (for example, rendered or skipped).Throws:ExoPlaybackException - If an error occurs processing the output buffer.
-
protected void renderToEndOfStream()
throws[ExoPlaybackException](../ExoPlaybackException.html "class in com.google.android.exoplayer2")
Deprecated.
Incrementally renders any remaining output.
The default implementation is a no-op.
Throws:ExoPlaybackException - Thrown if an error occurs rendering remaining output.
-
protected final void setPendingOutputEndOfStream()
Deprecated.
Notifies the renderer that output end of stream is pending and should be handled on the next render.
-
protected final long getOutputStreamOffsetUs()
Deprecated.
Returns the offset that should be subtracted from bufferPresentationTimeUs in processOutputBuffer(long, long, MediaCodecAdapter, ByteBuffer, int, int, int, long, boolean, boolean, Format) to get the playback position with respect to the media.
-
protected static boolean supportsFormatDrm([Format](../Format.html "class in com.google.android.exoplayer2")format)
Deprecated.
Returns whether this renderer supports the given Format's DRM scheme.