public interface

LivePlaybackSpeedControl

 androidx.media3.exoplayer.LivePlaybackSpeedControl

Subclasses:

DefaultLivePlaybackSpeedControl

Gradle dependencies

compile group: 'androidx.media3', name: 'media3-exoplayer', version: '1.5.0-alpha01'

  • groupId: androidx.media3
  • artifactId: media3-exoplayer
  • version: 1.5.0-alpha01

Artifact androidx.media3:media3-exoplayer:1.5.0-alpha01 it located at Google repository (https://maven.google.com/)

Overview

Controls the playback speed while playing live content in order to maintain a steady target live offset.

Summary

Methods
public floatgetAdjustedPlaybackSpeed(long liveOffsetUs, long bufferedDurationUs)

Returns the adjusted playback speed in order get closer towards the target live offset.

public longgetTargetLiveOffsetUs()

Returns the current target live offset, in microseconds, or C.TIME_UNSET if no target live offset is defined for the current media.

public voidnotifyRebuffer()

Notifies the live playback speed control that a rebuffer occurred.

public voidsetLiveConfiguration(MediaItem.LiveConfiguration liveConfiguration)

Sets the live configuration defined by the media.

public voidsetTargetLiveOffsetOverrideUs(long liveOffsetUs)

Sets the target live offset in microseconds that overrides the live offset configured by the media.

Methods

public void setLiveConfiguration(MediaItem.LiveConfiguration liveConfiguration)

Sets the live configuration defined by the media.

Parameters:

liveConfiguration: The MediaItem.LiveConfiguration as defined by the media.

public void setTargetLiveOffsetOverrideUs(long liveOffsetUs)

Sets the target live offset in microseconds that overrides the live offset configured by the media. Passing C.TIME_UNSET deletes a previous override.

If no target live offset is configured by LivePlaybackSpeedControl.setLiveConfiguration(MediaItem.LiveConfiguration), this override has no effect.

public void notifyRebuffer()

Notifies the live playback speed control that a rebuffer occurred.

A rebuffer is defined to be caused by buffer depletion rather than a user action. Hence this method is not called during initial buffering or when buffering as a result of a seek operation.

public float getAdjustedPlaybackSpeed(long liveOffsetUs, long bufferedDurationUs)

Returns the adjusted playback speed in order get closer towards the target live offset.

Parameters:

liveOffsetUs: The current live offset, in microseconds.
bufferedDurationUs: The duration of media that's currently buffered, in microseconds.

Returns:

The adjusted factor by which playback should be sped up.

public long getTargetLiveOffsetUs()

Returns the current target live offset, in microseconds, or C.TIME_UNSET if no target live offset is defined for the current media.

Source

/*
 * Copyright (C) 2020 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package androidx.media3.exoplayer;

import androidx.media3.common.C;
import androidx.media3.common.MediaItem.LiveConfiguration;
import androidx.media3.common.util.UnstableApi;

/**
 * Controls the playback speed while playing live content in order to maintain a steady target live
 * offset.
 */
@UnstableApi
public interface LivePlaybackSpeedControl {

  /**
   * Sets the live configuration defined by the media.
   *
   * @param liveConfiguration The {@link LiveConfiguration} as defined by the media.
   */
  void setLiveConfiguration(LiveConfiguration liveConfiguration);

  /**
   * Sets the target live offset in microseconds that overrides the live offset {@link
   * #setLiveConfiguration configured} by the media. Passing {@code C.TIME_UNSET} deletes a previous
   * override.
   *
   * <p>If no target live offset is configured by {@link #setLiveConfiguration}, this override has
   * no effect.
   */
  void setTargetLiveOffsetOverrideUs(long liveOffsetUs);

  /**
   * Notifies the live playback speed control that a rebuffer occurred.
   *
   * <p>A rebuffer is defined to be caused by buffer depletion rather than a user action. Hence this
   * method is not called during initial buffering or when buffering as a result of a seek
   * operation.
   */
  void notifyRebuffer();

  /**
   * Returns the adjusted playback speed in order get closer towards the {@link
   * #getTargetLiveOffsetUs() target live offset}.
   *
   * @param liveOffsetUs The current live offset, in microseconds.
   * @param bufferedDurationUs The duration of media that's currently buffered, in microseconds.
   * @return The adjusted factor by which playback should be sped up.
   */
  float getAdjustedPlaybackSpeed(long liveOffsetUs, long bufferedDurationUs);

  /**
   * Returns the current target live offset, in microseconds, or {@link C#TIME_UNSET} if no target
   * live offset is defined for the current media.
   */
  long getTargetLiveOffsetUs();
}