Save the date! Android Dev Summit is coming to Mountain View, CA on November 7-8, 2018.
added in version 1.0.0
belongs to Maven artifact androidx.leanback:leanback:1.0.0-rc01
Deprecated since version 1.0.0

PlaybackFragment

public class PlaybackFragment
extends Fragment

java.lang.Object
   ↳ android.app.Fragment
     ↳ androidx.leanback.app.PlaybackFragment


This class was deprecated in API level 1.0.0.
use PlaybackSupportFragment

A fragment for displaying playback controls and related content.

A PlaybackFragment renders the elements of its ObjectAdapter as a set of rows in a vertical list. The Adapter's PresenterSelector must maintain subclasses of RowPresenter.

A playback row is a row rendered by PlaybackRowPresenter. App can call setPlaybackRow(Row) to set playback row for the first element of adapter. App can call setPlaybackRowPresenter(PlaybackRowPresenter) to set presenter for it. setPlaybackRow(Row) and setPlaybackRowPresenter(PlaybackRowPresenter) are optional, app can pass playback row and PlaybackRowPresenter in the adapter using setAdapter(ObjectAdapter).

Auto hide controls upon playing: best practice is calling setControlsOverlayAutoHideEnabled(boolean) upon play/pause. Theme attribute R.attr.playbackControlsAutoHideTimeout controls how long auto-hide will wait after media starts playing. The auto hiding timer will be cancelled upon tickle() triggered by input event. By default fragment does not auto hide controls after user interaction. To enable it: set theme attribute R.attr.playbackControlsAutoHideTickleTimeout, an auto hide timer will be created when tickle() is triggered by input event.

Summary

Constants

int BG_DARK

A dark translucent background.

int BG_LIGHT

A light translucent background.

int BG_NONE

No background.

Inherited constants

Public constructors

PlaybackFragment()

Public methods

void fadeOut()

This method was deprecated in API level 1.0.0. Call hideControlsOverlay(boolean)

ObjectAdapter getAdapter()
int getBackgroundType()

Returns the background type.

ProgressBarManager getProgressBarManager()

Returns the ProgressBarManager that will show or hide progress bar in onBufferingStateChanged(boolean).

void hideControlsOverlay(boolean runAnimation)

Hide controls overlay.

boolean isControlsOverlayAutoHideEnabled()

Returns true if controls will be auto hidden after a delay when fragment is resumed.

boolean isControlsOverlayVisible()

Returns true if controls overlay is visible, false otherwise.

boolean isFadingEnabled()

This method was deprecated in API level 1.0.0. Uses isControlsOverlayAutoHideEnabled()

void notifyPlaybackRowChanged()

Updates the ui when the row data changes.

void onCreate(Bundle savedInstanceState)
View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
void onDestroy()
void onDestroyView()
void onPause()
void onResume()
void onStart()
void onStop()
void onViewCreated(View view, Bundle savedInstanceState)
void setAdapter(ObjectAdapter adapter)

Sets the list of rows for the fragment.

void setBackgroundType(int type)

Sets the background type.

void setControlsOverlayAutoHideEnabled(boolean enabled)

Enables or disables auto hiding controls overlay after a short delay fragment is resumed.

void setFadingEnabled(boolean enabled)

This method was deprecated in API level 1.0.0. Uses setControlsOverlayAutoHideEnabled(boolean)

void setHostCallback(PlaybackGlueHost.HostCallback hostCallback)

Sets the PlaybackGlueHost.HostCallback.

void setOnItemViewClickedListener(BaseOnItemViewClickedListener listener)

This listener is called every time there is a click in RowsFragment.

void setOnItemViewSelectedListener(BaseOnItemViewSelectedListener listener)

This listener is called every time there is a selection in RowsFragment.

final void setOnKeyInterceptListener(View.OnKeyListener handler)

Sets the input event handler.

void setOnPlaybackItemViewClickedListener(BaseOnItemViewClickedListener listener)

Sets the BaseOnItemViewClickedListener that would be invoked for clicks only on PlaybackRowPresenter.ViewHolder.

void setPlaybackRow(Row row)

Sets the playback row for the playback controls.

void setPlaybackRowPresenter(PlaybackRowPresenter presenter)

Sets the presenter for rendering the playback row set by setPlaybackRow(Row).

void setPlaybackSeekUiClient(PlaybackSeekUi.Client client)

Interface to be implemented by UI widget to support PlaybackSeekUi.

void setSelectedPosition(int position)

Sets the selected row position with smooth animation.

void setSelectedPosition(int position, boolean smooth)

Sets the selected row position.

void showControlsOverlay(boolean runAnimation)

Show controls overlay.

void tickle()

Tickles the playback controls.

Protected methods

void onBufferingStateChanged(boolean start)

Called when media has start or stop buffering.

void onError(int errorCode, CharSequence errorMessage)

Called when media has error.

void onVideoSizeChanged(int videoWidth, int videoHeight)

Called when size of the video changes.

Inherited methods

Constants

BG_DARK

added in version 1.0.0
public static final int BG_DARK

A dark translucent background.

Constant Value: 1 (0x00000001)

BG_LIGHT

added in version 1.0.0
public static final int BG_LIGHT

A light translucent background.

Constant Value: 2 (0x00000002)

BG_NONE

added in version 1.0.0
public static final int BG_NONE

No background.

Constant Value: 0 (0x00000000)

Public constructors

PlaybackFragment

added in version 1.0.0
public PlaybackFragment ()

Public methods

fadeOut

added in version 1.0.0
public void fadeOut ()

This method was deprecated in API level 1.0.0.
Call hideControlsOverlay(boolean)

Fades out the playback overlay immediately.

getAdapter

added in version 1.0.0
public ObjectAdapter getAdapter ()

Returns
ObjectAdapter

getBackgroundType

added in version 1.0.0
public int getBackgroundType ()

Returns the background type.

Returns
int

getProgressBarManager

added in version 1.0.0
public ProgressBarManager getProgressBarManager ()

Returns the ProgressBarManager that will show or hide progress bar in onBufferingStateChanged(boolean).

Returns
ProgressBarManager The ProgressBarManager that will show or hide progress bar in onBufferingStateChanged(boolean).

hideControlsOverlay

added in version 1.0.0
public void hideControlsOverlay (boolean runAnimation)

Hide controls overlay.

Parameters
runAnimation boolean: True to run animation, false otherwise.

isControlsOverlayAutoHideEnabled

added in version 1.0.0
public boolean isControlsOverlayAutoHideEnabled ()

Returns true if controls will be auto hidden after a delay when fragment is resumed.

Returns
boolean

isControlsOverlayVisible

added in version 1.0.0
public boolean isControlsOverlayVisible ()

Returns true if controls overlay is visible, false otherwise.

Returns
boolean True if controls overlay is visible, false otherwise.

isFadingEnabled

added in version 1.0.0
public boolean isFadingEnabled ()

This method was deprecated in API level 1.0.0.
Uses isControlsOverlayAutoHideEnabled()

Returns
boolean

notifyPlaybackRowChanged

added in version 1.0.0
public void notifyPlaybackRowChanged ()

Updates the ui when the row data changes.

onCreate

public void onCreate (Bundle savedInstanceState)

Parameters
savedInstanceState Bundle

onCreateView

public View onCreateView (LayoutInflater inflater, 
                ViewGroup container, 
                Bundle savedInstanceState)

Parameters
inflater LayoutInflater

container ViewGroup

savedInstanceState Bundle

Returns
View

onDestroy

public void onDestroy ()

onDestroyView

public void onDestroyView ()

onPause

public void onPause ()

onResume

public void onResume ()

onStart

public void onStart ()

onStop

public void onStop ()

onViewCreated

public void onViewCreated (View view, 
                Bundle savedInstanceState)

Parameters
view View

savedInstanceState Bundle

setAdapter

added in version 1.0.0
public void setAdapter (ObjectAdapter adapter)

Sets the list of rows for the fragment. A default ClassPresenterSelector will be created if ObjectAdapter.getPresenterSelector() is null. if user provides setPlaybackRow(Row) and setPlaybackRowPresenter(PlaybackRowPresenter), the row and presenter will be set onto the adapter.

Parameters
adapter ObjectAdapter: The adapter that contains related rows and optional playback row.

setBackgroundType

added in version 1.0.0
public void setBackgroundType (int type)

Sets the background type.

Parameters
type int: One of BG_LIGHT, BG_DARK, or BG_NONE.

setControlsOverlayAutoHideEnabled

added in version 1.0.0
public void setControlsOverlayAutoHideEnabled (boolean enabled)

Enables or disables auto hiding controls overlay after a short delay fragment is resumed. If enabled and fragment is resumed, the view will fade out after a time period. tickle() will kill the timer, next time fragment is resumed, the timer will be started again if isControlsOverlayAutoHideEnabled() is true.

In most cases app does not need call tickle() as it's automatically called by PlaybackBaseControlGlue on user interactions.

Parameters
enabled boolean

setFadingEnabled

added in version 1.0.0
public void setFadingEnabled (boolean enabled)

This method was deprecated in API level 1.0.0.
Uses setControlsOverlayAutoHideEnabled(boolean)

Parameters
enabled boolean

setHostCallback

added in version 1.0.0
public void setHostCallback (PlaybackGlueHost.HostCallback hostCallback)

Sets the PlaybackGlueHost.HostCallback. Implementor of this interface will take appropriate actions to take action when the hosting fragment starts/stops processing.

Parameters
hostCallback PlaybackGlueHost.HostCallback

setOnItemViewClickedListener

added in version 1.0.0
public void setOnItemViewClickedListener (BaseOnItemViewClickedListener listener)

This listener is called every time there is a click in RowsFragment. This can be used by users to take additional actions such as animations.

Parameters
listener BaseOnItemViewClickedListener

setOnItemViewSelectedListener

added in version 1.0.0
public void setOnItemViewSelectedListener (BaseOnItemViewSelectedListener listener)

This listener is called every time there is a selection in RowsFragment. This can be used by users to take additional actions such as animations.

Parameters
listener BaseOnItemViewSelectedListener

setOnKeyInterceptListener

added in version 1.0.0
public final void setOnKeyInterceptListener (View.OnKeyListener handler)

Sets the input event handler.

Parameters
handler View.OnKeyListener

setOnPlaybackItemViewClickedListener

added in version 1.0.0
public void setOnPlaybackItemViewClickedListener (BaseOnItemViewClickedListener listener)

Sets the BaseOnItemViewClickedListener that would be invoked for clicks only on PlaybackRowPresenter.ViewHolder.

Parameters
listener BaseOnItemViewClickedListener

setPlaybackRow

added in version 1.0.0
public void setPlaybackRow (Row row)

Sets the playback row for the playback controls. The row will be set as first element of adapter if the adapter is ArrayObjectAdapter or SparseArrayObjectAdapter.

Parameters
row Row: The row that represents the playback.

setPlaybackRowPresenter

added in version 1.0.0
public void setPlaybackRowPresenter (PlaybackRowPresenter presenter)

Sets the presenter for rendering the playback row set by setPlaybackRow(Row). If adapter does not set a PresenterSelector, setAdapter(ObjectAdapter) will create a ClassPresenterSelector by default and map from the row object class to this PlaybackRowPresenter.

Parameters
presenter PlaybackRowPresenter: Presenter used to render setPlaybackRow(Row).

setPlaybackSeekUiClient

added in version 1.0.0
public void setPlaybackSeekUiClient (PlaybackSeekUi.Client client)

Interface to be implemented by UI widget to support PlaybackSeekUi.

Parameters
client PlaybackSeekUi.Client

setSelectedPosition

added in version 1.0.0
public void setSelectedPosition (int position)

Sets the selected row position with smooth animation.

Parameters
position int

setSelectedPosition

added in version 1.0.0
public void setSelectedPosition (int position, 
                boolean smooth)

Sets the selected row position.

Parameters
position int

smooth boolean

showControlsOverlay

added in version 1.0.0
public void showControlsOverlay (boolean runAnimation)

Show controls overlay.

Parameters
runAnimation boolean: True to run animation, false otherwise.

tickle

added in version 1.0.0
public void tickle ()

Tickles the playback controls. Fades in the view if it was faded out. tickle() will also kill the timer created by setControlsOverlayAutoHideEnabled(boolean). When next time fragment is resumed, the timer will be started again if isControlsOverlayAutoHideEnabled() is true. The timer will also be restarted if app sets a positive value on theme attribute R.attr.playbackControlsAutoHideTickleTimeout.

In most cases app does not need call tickle() as it's automatically called by PlaybackBaseControlGlue on user interactions.

Protected methods

onBufferingStateChanged

added in version 1.0.0
protected void onBufferingStateChanged (boolean start)

Called when media has start or stop buffering. App may override. The default initial state is not buffering.

Parameters
start boolean: True for buffering start, false otherwise.

onError

added in version 1.0.0
protected void onError (int errorCode, 
                CharSequence errorMessage)

Called when media has error. App may override.

Parameters
errorCode int: Optional error code for specific implementation.

errorMessage CharSequence: Optional error message for specific implementation.

onVideoSizeChanged

added in version 1.0.0
protected void onVideoSizeChanged (int videoWidth, 
                int videoHeight)

Called when size of the video changes. App may override.

Parameters
videoWidth int: Intrinsic width of video

videoHeight int: Intrinsic height of video