Package com.google.android.exoplayer2
Interface LoadControl
-
- All Known Implementing Classes:
DefaultLoadControl
@Deprecated public interface LoadControl
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.Controls buffering of media.
-
-
Field Summary
Fields Modifier and Type Field Description static MediaPeriodId
EMPTY_MEDIA_PERIOD_ID
Deprecated.Used as a placeholder when MediaPeriodId is unknown.
-
Method Summary
All Methods Instance Methods Abstract Methods Default Methods Deprecated Methods Modifier and Type Method Description Allocator
getAllocator()
Deprecated.Returns theAllocator
that should be used to obtain media buffer allocations.long
getBackBufferDurationUs()
Deprecated.Returns the duration of media to retain in the buffer prior to the current playback position, for fast backward seeking.void
onPrepared()
Deprecated.Called by the player when prepared with a new source.void
onReleased()
Deprecated.Called by the player when released.void
onStopped()
Deprecated.Called by the player when stopped.default void
onTracksSelected(Renderer[] renderers, TrackGroupArray trackGroups, ExoTrackSelection[] trackSelections)
Deprecated.default void
onTracksSelected(Timeline timeline, MediaPeriodId mediaPeriodId, Renderer[] renderers, TrackGroupArray trackGroups, ExoTrackSelection[] trackSelections)
Deprecated.Called by the player when a track selection occurs.boolean
retainBackBufferFromKeyframe()
Deprecated.Returns whether media should be retained from the keyframe before the current playback position minusgetBackBufferDurationUs()
, rather than any sample before or at that position.boolean
shouldContinueLoading(long playbackPositionUs, long bufferedDurationUs, float playbackSpeed)
Deprecated.Called by the player to determine whether it should continue to load the source.default boolean
shouldStartPlayback(long bufferedDurationUs, float playbackSpeed, boolean rebuffering, long targetLiveOffsetUs)
Deprecated.ImplementshouldStartPlayback(Timeline, MediaPeriodId, long, float, boolean, long)
instead.default boolean
shouldStartPlayback(Timeline timeline, MediaPeriodId mediaPeriodId, long bufferedDurationUs, float playbackSpeed, boolean rebuffering, long targetLiveOffsetUs)
Deprecated.Called repeatedly by the player when it's loading the source, has yet to start playback, and has the minimum amount of data necessary for playback to be started.
-
-
-
Field Detail
-
EMPTY_MEDIA_PERIOD_ID
@Deprecated static final MediaPeriodId EMPTY_MEDIA_PERIOD_ID
Deprecated.Used as a placeholder when MediaPeriodId is unknown. Only used when the deprecated methodsonTracksSelected(Renderer[], TrackGroupArray, ExoTrackSelection[])
orshouldStartPlayback(long, float, boolean, long)
are called.
-
-
Method Detail
-
onPrepared
void onPrepared()
Deprecated.Called by the player when prepared with a new source.
-
onTracksSelected
default void onTracksSelected(Timeline timeline, MediaPeriodId mediaPeriodId, Renderer[] renderers, TrackGroupArray trackGroups, ExoTrackSelection[] trackSelections)
Deprecated.Called by the player when a track selection occurs.- Parameters:
timeline
- The currentTimeline
in ExoPlayer. Can beTimeline.EMPTY
only when the deprecatedonTracksSelected(Renderer[], TrackGroupArray, ExoTrackSelection[])
was called.mediaPeriodId
- Identifies (in the current timeline) theMediaPeriod
for which the selection was made. Will beEMPTY_MEDIA_PERIOD_ID
whentimeline
is empty.renderers
- The renderers.trackGroups
- TheTrackGroup
s from which the selection was made.trackSelections
- The track selections that were made.
-
onTracksSelected
@Deprecated default void onTracksSelected(Renderer[] renderers, TrackGroupArray trackGroups, ExoTrackSelection[] trackSelections)
Deprecated.
-
onStopped
void onStopped()
Deprecated.Called by the player when stopped.
-
onReleased
void onReleased()
Deprecated.Called by the player when released.
-
getAllocator
Allocator getAllocator()
Deprecated.Returns theAllocator
that should be used to obtain media buffer allocations.
-
getBackBufferDurationUs
long getBackBufferDurationUs()
Deprecated.Returns the duration of media to retain in the buffer prior to the current playback position, for fast backward seeking.Note: If
retainBackBufferFromKeyframe()
is false then seeking in the back-buffer will only be fast if the back-buffer contains a keyframe prior to the seek position.Note: Implementations should return a single value. Dynamic changes to the back-buffer are not currently supported.
- Returns:
- The duration of media to retain in the buffer prior to the current playback position, in microseconds.
-
retainBackBufferFromKeyframe
boolean retainBackBufferFromKeyframe()
Deprecated.Returns whether media should be retained from the keyframe before the current playback position minusgetBackBufferDurationUs()
, rather than any sample before or at that position.Warning: Returning true will cause the back-buffer size to depend on the spacing of keyframes in the media being played. Returning true is not recommended unless you control the media and are comfortable with the back-buffer size exceeding
getBackBufferDurationUs()
by as much as the maximum duration between adjacent keyframes in the media.Note: Implementations should return a single value. Dynamic changes to the back-buffer are not currently supported.
- Returns:
- Whether media should be retained from the keyframe before the current playback position
minus
getBackBufferDurationUs()
, rather than any sample before or at that position.
-
shouldContinueLoading
boolean shouldContinueLoading(long playbackPositionUs, long bufferedDurationUs, float playbackSpeed)
Deprecated.Called by the player to determine whether it should continue to load the source. If this method returns true, theMediaPeriod
identified in the most recentonTracksSelected(com.google.android.exoplayer2.Timeline, com.google.android.exoplayer2.source.MediaPeriodId, com.google.android.exoplayer2.Renderer[], com.google.android.exoplayer2.source.TrackGroupArray, com.google.android.exoplayer2.trackselection.ExoTrackSelection[])
call will continue being loaded.- Parameters:
playbackPositionUs
- The current playback position in microseconds, relative to the start of theperiod
that will continue to be loaded if this method returnstrue
. If playback of this period has not yet started, the value will be negative and equal in magnitude to the duration of any media in previous periods still to be played.bufferedDurationUs
- The duration of media that's currently buffered.playbackSpeed
- The current factor by which playback is sped up.- Returns:
- Whether the loading should continue.
-
shouldStartPlayback
default boolean shouldStartPlayback(Timeline timeline, MediaPeriodId mediaPeriodId, long bufferedDurationUs, float playbackSpeed, boolean rebuffering, long targetLiveOffsetUs)
Deprecated.Called repeatedly by the player when it's loading the source, has yet to start playback, and has the minimum amount of data necessary for playback to be started. The value returned determines whether playback is actually started. The load control may opt to returnfalse
until some condition has been met (e.g. a certain amount of media is buffered).- Parameters:
timeline
- The currentTimeline
in ExoPlayer. Can beTimeline.EMPTY
only when the deprecatedshouldStartPlayback(long, float, boolean, long)
was called.mediaPeriodId
- Identifies (in the current timeline) theMediaPeriod
for which playback will start. Will beEMPTY_MEDIA_PERIOD_ID
whentimeline
is empty.bufferedDurationUs
- The duration of media that's currently buffered.playbackSpeed
- The current factor by which playback is sped up.rebuffering
- Whether the player is rebuffering. A rebuffer is defined to be caused by buffer depletion rather than a user action. Hence this parameter is false during initial buffering and when buffering as a result of a seek operation.targetLiveOffsetUs
- The desired playback position offset to the live edge in microseconds, orC.TIME_UNSET
if the media is not a live stream or no offset is configured.- Returns:
- Whether playback should be allowed to start or resume.
-
shouldStartPlayback
@Deprecated default boolean shouldStartPlayback(long bufferedDurationUs, float playbackSpeed, boolean rebuffering, long targetLiveOffsetUs)
Deprecated.ImplementshouldStartPlayback(Timeline, MediaPeriodId, long, float, boolean, long)
instead.
-
-