Package-level declarations

Contains building blocks for building a Frontend.

Types

Link copied to clipboard
typealias AnyIviFragment<P> = IviFragment<P, *>

Convenience type alias that defines an IviFragment for a panel type.

Link copied to clipboard

Convenience type alias that defines an IviFragment.Initializer for a panel type.

Link copied to clipboard
Link copied to clipboard
abstract class Frontend(val frontendContext: FrontendContext) : LifecycleOwner

The base class for Frontends in the IVI system.

Link copied to clipboard
abstract class FrontendBuilder

Builder class for Frontends.

Link copied to clipboard

The entry point for a single Frontend to communicate with the rest of the system.

Link copied to clipboard

Describes when the framework should create a Frontend.

Link copied to clipboard

Interface of all frontend extensions.

Link copied to clipboard
data class FrontendMetadata(val id: FrontendMetadataId, val creationPolicy: FrontendCreationPolicy = FrontendCreationPolicy.CREATE_FRONTEND_AFTER_STARTUP, val launchMenuItem: MenuItem? = null, val frontendExtensions: Collection<FrontendExtension> = emptyList(), val intentFilters: List<IntentFilter> = emptyList(), val availablePanelTypes: PanelTypeSet = PLATFORM_PANEL_TYPES, val frontendBuilderFactory: () -> FrontendBuilder)

Encapsulates metadata describing a Frontend.

Link copied to clipboard

An IviBuildConfigExtension containing the FrontendMetadata, generated at build-time.

Link copied to clipboard
data class FrontendMetadataId(val id: String)

A unique FrontendMetadata identifier per IviInstanceId.

Link copied to clipboard

A base class for fragments that contain the contents of frontend panels. Typical IVI fragments are responsible for creating a layout and linking it to a ViewModel. The viewModelClass is responsible for the business logic and the state of a fragment. This is because, unlike fragments, ViewModels are persistent across configuration changes.

Link copied to clipboard

An IviFragment identifier.

Link copied to clipboard

An interface for components that handle hardware back button presses.

Link copied to clipboard

An interface for components that have an IviOnBackPressedCallback, which can handle hardware back button presses.

Link copied to clipboard

An IviOnBackPressedCallback that can dispatch on back presses to other IviOnBackPressedCallbacks. It is disabled by default and enabled when any of added callbacks are enabled. The last added callback that is currently enabled is called to handle the back press.

Link copied to clipboard

Interface for views that need to be notified when the exit animation is started on the panels, which display them.