ControlCenterPanel

abstract class ControlCenterPanel(frontendContext: FrontendContext, val type: ControlCenterPanel.Type) : GenericPanel<PanelContext>

A panel for an isolated area of the system UI that provides persistent indicators and controls that are accessible to the user at all times.

Parameters

frontendContext

An entry point for this Panel to communicate with the rest of the system.

type

Indicates what type of contents this control center panel instance is responsible for. This can be used by the system UI to determine where to show the panel.

Constructors

Link copied to clipboard
fun ControlCenterPanel(frontendContext: FrontendContext, type: ControlCenterPanel.Type)

Types

Link copied to clipboard
enum Type : Enum<ControlCenterPanel.Type>

Indicates what type of contents a control center panel is responsible for.

Properties

Link copied to clipboard
val type: ControlCenterPanel.Type

Inherited properties

Link copied to clipboard
val frontendContext: FrontendContext
Link copied to clipboard
val id: Long

Unique identifier of a GenericPanel. Each ID is an increment of the previously created panel's ID, allowing this value to be used for sorting purposes.

Link copied to clipboard
val isOccluded: LiveData<Boolean?>

Whether the panel is partially or fully occluded:

Link copied to clipboard
override val panelContext: LiveData<PanelContext?>

The PanelContext given when the panel is attached to the system UI.

Link copied to clipboard
val tag: String

The tag to recognise this panel with. Useful in combination with fragment tags to detect which fragment belongs to which panel.

Link copied to clipboard
var transitionDestination: PanelTransitionDestination?

A destination that the information contained by this panel transitions to when this panel closes. By default it is null, indicating the information does not transition anywhere.

Link copied to clipboard
var transitionSource: PanelTransitionSource?

The source of the information contained by this panel when the information transitions from another panel to this one. By default it is null, indicating the information does not transition from any other particular panel.

Inherited functions

Link copied to clipboard
fun createInitialFragment(): Fragment

The fragment used when initially showing the panel. The fragment may be recreated by the system UI upon configuration changes.

Link copied to clipboard
operator override fun equals(other: Any?): Boolean
Link copied to clipboard
open override fun getLifecycle(): Lifecycle
Link copied to clipboard
override fun hashCode(): Int
Link copied to clipboard
open fun onAddedToFrontend()

Called when this panel is added to Frontend.panels, allowing it to be shown in the system UI.

Link copied to clipboard
open fun onAttached(panelContext: PanelContext)

Called when the panel is attached to the system UI. The panel may be detached and attached multiple times, for example on configuration changes. However, a panel will never be attached multiple times at once.

Link copied to clipboard
open fun onDetached()

Called when the panel has been detached from the system UI. The panel may be attached again later, for example when the configuration changes.

Link copied to clipboard
open fun onRemovedFromFrontend()

Called when this panel is removed from Frontend.panels, preventing it from being shown in the system UI.

Link copied to clipboard
open override fun toString(): String