class PlaceholderState


A state object that can be used to control placeholders. Placeholders are used when the content that needs to be displayed in a component is not yet available, e.g. it is loading asynchronously.

A PlaceholderState should be created for each component that has placeholder data. The state is used to coordinate all of the different placeholder effects and animations. The state should be created and remembered (maybe using rememberPlaceholderState), and as needed the isVisible property should be updated to show/hide the placeholder.

Placeholder has a number of different effects designed to work together. Modifier.placeholder draws a placeholder shape on top of content that is waiting to load. There can be multiple placeholders in a component. Modifier.placeholderShimmer does a shimmer animation over the whole component that includes the placeholders. There should only be one placeholderShimmer for each component.

NOTE: The order of modifiers is important. If you are adding both Modifier.placeholder and Modifier.placeholderShimmer to the same composable then the shimmer must be before in the modifier chain. Example of Text composable with both placeholderShimmer and placeholder modifiers.

import androidx.compose.foundation.layout.width
import androidx.compose.runtime.LaunchedEffect
import androidx.compose.runtime.mutableStateOf
import androidx.compose.runtime.remember
import androidx.compose.ui.Modifier
import androidx.compose.ui.text.style.TextAlign
import androidx.compose.ui.text.style.TextOverflow
import androidx.compose.ui.unit.dp
import androidx.wear.compose.material3.Text
import androidx.wear.compose.material3.placeholder
import androidx.wear.compose.material3.placeholderShimmer
import androidx.wear.compose.material3.rememberPlaceholderState

var labelText by remember { mutableStateOf("") }
val placeholderState = rememberPlaceholderState(isVisible = labelText.isEmpty())

Text(
    text = labelText,
    overflow = TextOverflow.Ellipsis,
    textAlign = TextAlign.Center,
    modifier =
        Modifier.width(90.dp).placeholderShimmer(placeholderState).placeholder(placeholderState)
)

// Simulate content loading
LaunchedEffect(Unit) {
    delay(3000)
    labelText = "A label"
}

Once all of the components content is loaded the shimmer will stop and a wipe off animation will remove the placeholders.

Summary

Public constructors

Public properties

Boolean

Whether the placeholder should be visible.

Public constructors

PlaceholderState

Added in 1.0.0-alpha37
PlaceholderState(isVisible: Boolean)
Parameters
isVisible: Boolean

whether the placeholder will be displayed. This should be modified later updating the state using PlaceholderState.isVisible

Public properties

isVisible

Added in 1.0.0-alpha37
var isVisibleBoolean

Whether the placeholder should be visible. Note that if there is an animation running, this is the target state for the animation.