Class DecoderVideoRenderer
- java.lang.Object
- 
- com.google.android.exoplayer2.BaseRenderer
- 
- com.google.android.exoplayer2.video.DecoderVideoRenderer
 
 
- 
- All Implemented Interfaces:
- PlayerMessage.Target,- Renderer,- RendererCapabilities
 - Direct Known Subclasses:
- Libgav1VideoRenderer,- LibvpxVideoRenderer
 
 @Deprecated public abstract class DecoderVideoRenderer extends BaseRenderer 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.Decodes and renders video using aDecoder.This renderer accepts the following messages sent via ExoPlayer.createMessage(PlayerMessage.Target)on the playback thread:- Message with type Renderer.MSG_SET_VIDEO_OUTPUTto set the output surface. The message payload should be the targetSurfaceorVideoDecoderOutputBufferRenderer, or null. Other non-null payloads have the effect of clearing the output.
- Message with type Renderer.MSG_SET_VIDEO_FRAME_METADATA_LISTENERto set a listener for metadata associated with frames being rendered. The message payload should be theVideoFrameMetadataListener, or null.
 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface com.google.android.exoplayer2.RendererRenderer.MessageType, Renderer.State, Renderer.WakeupListener
 - 
Nested classes/interfaces inherited from interface com.google.android.exoplayer2.RendererCapabilitiesRendererCapabilities.AdaptiveSupport, RendererCapabilities.Capabilities, RendererCapabilities.DecoderSupport, RendererCapabilities.FormatSupport, RendererCapabilities.HardwareAccelerationSupport, RendererCapabilities.Listener, RendererCapabilities.TunnelingSupport
 
- 
 - 
Field SummaryFields Modifier and Type Field Description protected DecoderCountersdecoderCountersDeprecated.Decoder event counters used for debugging purposes.- 
Fields inherited from interface com.google.android.exoplayer2.RendererMSG_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
 - 
Fields inherited from interface com.google.android.exoplayer2.RendererCapabilitiesADAPTIVE_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
 
- 
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedDecoderVideoRenderer(long allowedJoiningTimeMs, Handler eventHandler, VideoRendererEventListener eventListener, int maxDroppedFramesToNotify)Deprecated.
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Deprecated Methods Modifier and Type Method Description protected DecoderReuseEvaluationcanReuseDecoder(String decoderName, Format oldFormat, Format newFormat)Deprecated.Evaluates whether the existing decoder can be reused for a newFormat.protected abstract Decoder<DecoderInputBuffer,? extends VideoDecoderOutputBuffer,? extends DecoderException>createDecoder(Format format, CryptoConfig cryptoConfig)Deprecated.Creates a decoder for the given format.protected voiddropOutputBuffer(VideoDecoderOutputBuffer outputBuffer)Deprecated.Drops the specified output buffer and releases it.protected voidflushDecoder()Deprecated.Flushes the decoder.voidhandleMessage(@com.google.android.exoplayer2.Renderer.MessageType int messageType, Object message)Deprecated.Handles a message delivered to the target.booleanisEnded()Deprecated.Whether the renderer is ready for theExoPlayerinstance to transition toPlayer.STATE_ENDED.booleanisReady()Deprecated.Whether the renderer is able to immediately render media from the current position.protected booleanmaybeDropBuffersToKeyframe(long positionUs)Deprecated.Drops frames from the current output buffer to the next keyframe at or before the playback position.protected voidonDisabled()Deprecated.Called when the renderer is disabled.protected voidonEnabled(boolean joining, boolean mayRenderStartOfStream)Deprecated.Called when the renderer is enabled.protected voidonInputFormatChanged(FormatHolder formatHolder)Deprecated.Called when a new format is read from the upstream source.protected voidonPositionReset(long positionUs, boolean joining)Deprecated.Called when the position is reset.protected voidonProcessedOutputBuffer(long presentationTimeUs)Deprecated.Called when an output buffer is successfully processed.protected voidonQueueInputBuffer(DecoderInputBuffer buffer)Deprecated.Called immediately before an input buffer is queued into the decoder.protected voidonStarted()Deprecated.Called when the renderer is started.protected voidonStopped()Deprecated.Called when the renderer is stopped.protected voidonStreamChanged(Format[] formats, long startPositionUs, long offsetUs)Deprecated.Called when the renderer's stream has changed.protected voidreleaseDecoder()Deprecated.Releases the decoder.voidrender(long positionUs, long elapsedRealtimeUs)Deprecated.Incrementally renders theSampleStream.protected voidrenderOutputBuffer(VideoDecoderOutputBuffer outputBuffer, long presentationTimeUs, Format outputFormat)Deprecated.Renders the specified output buffer.protected abstract voidrenderOutputBufferToSurface(VideoDecoderOutputBuffer outputBuffer, Surface surface)Deprecated.Renders the specified output buffer to the passed surface.protected abstract voidsetDecoderOutputMode(@com.google.android.exoplayer2.C.VideoOutputMode int outputMode)Deprecated.Sets output mode of the decoder.protected voidsetOutput(Object output)Deprecated.Sets the video output.protected booleanshouldDropBuffersToKeyframe(long earlyUs, long elapsedRealtimeUs)Deprecated.Returns whether to drop all buffers from the buffer being processed to the keyframe at or after the current playback position, if possible.protected booleanshouldDropOutputBuffer(long earlyUs, long elapsedRealtimeUs)Deprecated.Returns whether the buffer being processed should be dropped.protected booleanshouldForceRenderOutputBuffer(long earlyUs, long elapsedSinceLastRenderUs)Deprecated.Returns whether to force rendering an output buffer.protected voidskipOutputBuffer(VideoDecoderOutputBuffer outputBuffer)Deprecated.Skips the specified output buffer and releases it.protected voidupdateDroppedBufferCounters(int droppedInputBufferCount, int droppedDecoderBufferCount)Deprecated.Updates local counters anddecoderCountersto reflect that buffers were dropped.- 
Methods inherited from class com.google.android.exoplayer2.BaseRendererclearListener, createRendererException, createRendererException, disable, enable, getCapabilities, getConfiguration, getFormatHolder, getIndex, getLastResetPositionUs, getMediaClock, getPlayerId, getReadingPositionUs, getState, getStream, getStreamFormats, getTrackType, hasReadStreamToEnd, init, isCurrentStreamFinal, isSourceReady, maybeThrowStreamError, onRelease, onRendererCapabilitiesChanged, onReset, readSource, release, replaceStream, reset, resetPosition, setCurrentStreamFinal, setListener, skipSource, start, stop, supportsMixedMimeTypeAdaptation
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface com.google.android.exoplayer2.RenderergetName, setPlaybackSpeed
 - 
Methods inherited from interface com.google.android.exoplayer2.RendererCapabilitiesgetName, supportsFormat
 
- 
 
- 
- 
- 
Field Detail- 
decoderCountersprotected DecoderCounters decoderCounters Deprecated.Decoder event counters used for debugging purposes.
 
- 
 - 
Constructor Detail- 
DecoderVideoRendererprotected DecoderVideoRenderer(long allowedJoiningTimeMs, @Nullable Handler eventHandler, @Nullable VideoRendererEventListener eventListener, int maxDroppedFramesToNotify)Deprecated.- Parameters:
- allowedJoiningTimeMs- The maximum duration in milliseconds for which this video renderer can attempt to seamlessly join an ongoing playback.
- eventHandler- A handler to use when delivering events to- eventListener. May be null if delivery of events is not required.
- eventListener- A listener of events. May be null if delivery of events is not required.
- maxDroppedFramesToNotify- The maximum number of frames that can be dropped between invocations of- VideoRendererEventListener.onDroppedFrames(int, long).
 
 
- 
 - 
Method Detail- 
renderpublic void render(long positionUs, long elapsedRealtimeUs) throws ExoPlaybackExceptionDeprecated.Description copied from interface:RendererIncrementally renders theSampleStream.If the renderer is in the Renderer.STATE_ENABLEDstate then each call to this method will do work toward being ready to render theSampleStreamwhen the renderer is started. If the renderer is in theRenderer.STATE_STARTEDstate then calls to this method will render theSampleStreamin 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_ENABLEDstate, unless it's the initial start of the media after callingRenderer.enable(RendererConfiguration, Format[], SampleStream, long, boolean, boolean, long, long)withmayRenderStartOfStreamset tofalse.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.
 
 - 
isEndedpublic boolean isEnded() Deprecated.Description copied from interface:RendererWhether the renderer is ready for theExoPlayerinstance to transition toPlayer.STATE_ENDED. The player will make this transition as soon astrueis 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.
 
 - 
isReadypublic boolean isReady() Deprecated.Description copied from interface:RendererWhether the renderer is able to immediately render media from the current position.If the renderer is in the Renderer.STATE_STARTEDstate 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_ENABLEDstate 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.
 
 - 
handleMessagepublic void handleMessage(@com.google.android.exoplayer2.Renderer.MessageType int messageType, @Nullable Object message) throws ExoPlaybackExceptionDeprecated.Description copied from interface:PlayerMessage.TargetHandles a message delivered to the target.- Specified by:
- handleMessagein interface- PlayerMessage.Target
- Overrides:
- handleMessagein class- BaseRenderer
- Parameters:
- messageType- The message type.
- message- The message payload.
- Throws:
- ExoPlaybackException- If an error occurred whilst handling the message. Should only be thrown by targets that handle messages on the playback thread.
 
 - 
onEnabledprotected void onEnabled(boolean joining, boolean mayRenderStartOfStream) throws ExoPlaybackExceptionDeprecated.Description copied from class:BaseRendererCalled when the renderer is enabled.The default implementation is a no-op. - Overrides:
- onEnabledin class- BaseRenderer
- Parameters:
- 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_STARTEDyet.
- Throws:
- ExoPlaybackException- If an error occurs.
 
 - 
onPositionResetprotected void onPositionReset(long positionUs, boolean joining) throws ExoPlaybackExceptionDeprecated.Description copied from class:BaseRendererCalled when the position is reset. This occurs when the renderer is enabled afterBaseRenderer.onStreamChanged(Format[], long, long)has been called, and also when a position discontinuity is encountered.After a position reset, the renderer's SampleStreamis guaranteed to provide samples starting from a key frame.The default implementation is a no-op. - Overrides:
- onPositionResetin class- BaseRenderer
- Parameters:
- 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.
 
 - 
onStartedprotected void onStarted() Deprecated.Description copied from class:BaseRendererCalled when the renderer is started.The default implementation is a no-op. - Overrides:
- onStartedin class- BaseRenderer
 
 - 
onStoppedprotected void onStopped() Deprecated.Description copied from class:BaseRendererCalled when the renderer is stopped.The default implementation is a no-op. - Overrides:
- onStoppedin class- BaseRenderer
 
 - 
onDisabledprotected void onDisabled() Deprecated.Description copied from class:BaseRendererCalled when the renderer is disabled.The default implementation is a no-op. - Overrides:
- onDisabledin class- BaseRenderer
 
 - 
onStreamChangedprotected void onStreamChanged(Format[] formats, long startPositionUs, long offsetUs) throws ExoPlaybackException Deprecated.Description copied from class:BaseRendererCalled when the renderer's stream has changed. This occurs when the renderer is enabled afterBaseRenderer.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:
- onStreamChangedin class- BaseRenderer
- Parameters:
- 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.
 
 - 
flushDecoder@CallSuper protected void flushDecoder() throws ExoPlaybackExceptionDeprecated.Flushes the decoder.- Throws:
- ExoPlaybackException- If an error occurs reinitializing a decoder.
 
 - 
releaseDecoder@CallSuper protected void releaseDecoder() Deprecated.Releases the decoder.
 - 
onInputFormatChanged@CallSuper protected void onInputFormatChanged(FormatHolder formatHolder) throws ExoPlaybackException Deprecated.Called when a new format is read from the upstream source.- Parameters:
- formatHolder- A- FormatHolderthat holds the new- Format.
- Throws:
- ExoPlaybackException- If an error occurs (re-)initializing the decoder.
 
 - 
onQueueInputBufferprotected void onQueueInputBuffer(DecoderInputBuffer buffer) Deprecated.Called immediately before an input buffer is queued into the decoder.The default implementation is a no-op. - Parameters:
- buffer- The buffer that will be queued.
 
 - 
onProcessedOutputBuffer@CallSuper protected void onProcessedOutputBuffer(long presentationTimeUs) Deprecated.Called when an output buffer is successfully processed.- Parameters:
- presentationTimeUs- The timestamp associated with the output buffer.
 
 - 
shouldDropOutputBufferprotected boolean shouldDropOutputBuffer(long earlyUs, long elapsedRealtimeUs)Deprecated.Returns whether the buffer being processed should be dropped.- Parameters:
- earlyUs- The time until the buffer should be presented in microseconds. A negative value indicates that the buffer is late.
- elapsedRealtimeUs-- SystemClock.elapsedRealtime()in microseconds, measured at the start of the current iteration of the rendering loop.
 
 - 
shouldDropBuffersToKeyframeprotected boolean shouldDropBuffersToKeyframe(long earlyUs, long elapsedRealtimeUs)Deprecated.Returns whether to drop all buffers from the buffer being processed to the keyframe at or after the current playback position, if possible.- Parameters:
- earlyUs- The time until the current buffer should be presented in microseconds. A negative value indicates that the buffer is late.
- elapsedRealtimeUs-- SystemClock.elapsedRealtime()in microseconds, measured at the start of the current iteration of the rendering loop.
 
 - 
shouldForceRenderOutputBufferprotected boolean shouldForceRenderOutputBuffer(long earlyUs, long elapsedSinceLastRenderUs)Deprecated.Returns whether to force rendering an output buffer.- Parameters:
- earlyUs- The time until the current buffer should be presented in microseconds. A negative value indicates that the buffer is late.
- elapsedSinceLastRenderUs- The elapsed time since the last output buffer was rendered, in microseconds.
- Returns:
- Returns whether to force rendering an output buffer.
 
 - 
skipOutputBufferprotected void skipOutputBuffer(VideoDecoderOutputBuffer outputBuffer) Deprecated.Skips the specified output buffer and releases it.- Parameters:
- outputBuffer- The output buffer to skip.
 
 - 
dropOutputBufferprotected void dropOutputBuffer(VideoDecoderOutputBuffer outputBuffer) Deprecated.Drops the specified output buffer and releases it.- Parameters:
- outputBuffer- The output buffer to drop.
 
 - 
maybeDropBuffersToKeyframeprotected boolean maybeDropBuffersToKeyframe(long positionUs) throws ExoPlaybackExceptionDeprecated.Drops frames from the current output buffer to the next keyframe at or before the playback position. If no such keyframe exists, as the playback position is inside the same group of pictures as the buffer being processed, returnsfalse. Returnstrueotherwise.- Parameters:
- positionUs- The current playback position, in microseconds.
- Returns:
- Whether any buffers were dropped.
- Throws:
- ExoPlaybackException- If an error occurs flushing the decoder.
 
 - 
updateDroppedBufferCountersprotected void updateDroppedBufferCounters(int droppedInputBufferCount, int droppedDecoderBufferCount)Deprecated.Updates local counters anddecoderCountersto reflect that buffers were dropped.- Parameters:
- droppedInputBufferCount- The number of buffers dropped from the source before being passed to the decoder.
- droppedDecoderBufferCount- The number of buffers dropped after being passed to the decoder.
 
 - 
createDecoderprotected abstract Decoder<DecoderInputBuffer,? extends VideoDecoderOutputBuffer,? extends DecoderException> createDecoder(Format format, @Nullable CryptoConfig cryptoConfig) throws DecoderException Deprecated.Creates a decoder for the given format.- Parameters:
- format- The format for which a decoder is required.
- cryptoConfig- The- CryptoConfigobject required for decoding encrypted content. May be null and can be ignored if decoder does not handle encrypted content.
- Returns:
- The decoder.
- Throws:
- DecoderException- If an error occurred creating a suitable decoder.
 
 - 
renderOutputBufferprotected void renderOutputBuffer(VideoDecoderOutputBuffer outputBuffer, long presentationTimeUs, Format outputFormat) throws DecoderException Deprecated.Renders the specified output buffer.The implementation of this method takes ownership of the output buffer and is responsible for calling VideoDecoderOutputBuffer.release()either immediately or in the future.- Parameters:
- outputBuffer-- VideoDecoderOutputBufferto render.
- presentationTimeUs- Presentation time in microseconds.
- outputFormat- Output- Format.
- Throws:
- DecoderException- If an error occurs when rendering the output buffer.
 
 - 
renderOutputBufferToSurfaceprotected abstract void renderOutputBufferToSurface(VideoDecoderOutputBuffer outputBuffer, Surface surface) throws DecoderException Deprecated.Renders the specified output buffer to the passed surface.The implementation of this method takes ownership of the output buffer and is responsible for calling VideoDecoderOutputBuffer.release()either immediately or in the future.- Parameters:
- outputBuffer-- VideoDecoderOutputBufferto render.
- surface- Output- Surface.
- Throws:
- DecoderException- If an error occurs when rendering the output buffer.
 
 - 
setOutputprotected final void setOutput(@Nullable Object output)Deprecated.Sets the video output.
 - 
setDecoderOutputModeprotected abstract void setDecoderOutputMode(@com.google.android.exoplayer2.C.VideoOutputMode int outputMode) Deprecated.Sets output mode of the decoder.- Parameters:
- outputMode- Output mode.
 
 - 
canReuseDecoderprotected DecoderReuseEvaluation canReuseDecoder(String decoderName, Format oldFormat, Format newFormat) Deprecated.Evaluates whether the existing decoder can be reused for a newFormat.The default implementation does not allow decoder reuse. - Parameters:
- decoderName- The name of the decoder.
- oldFormat- The previous format.
- newFormat- The new format.
- Returns:
- The result of the evaluation.
 
 
- 
 
-