NavigationDrawer
Android
Component in Tv Material Compose
Navigation drawers provide ergonomic access to destinations in an app. They’re often next to app content and affect the screen’s layout grid. Standard navigation drawers are good for frequent switching to different destinations.
It displays content associated with the closed state when the drawer is not in focus and displays content associated with the open state when the drawer or its contents are focused on. The drawer is at the same level as the app's UI an reduces the screen size available to the remaining content.
Last updated:
Installation
dependencies {
implementation("androidx.tv:tv-material:1.0.0")
}
Overloads
@Composable
fun NavigationDrawer(
drawerContent: @Composable NavigationDrawerScope.(DrawerValue) -> Unit,
modifier: Modifier = Modifier,
drawerState: DrawerState = rememberDrawerState(DrawerValue.Closed),
content: @Composable () -> Unit
)
Parameters
name | description |
---|---|
drawerContent | Content that needs to be displayed on the drawer based on whether the drawer is [DrawerValue.Open] or [DrawerValue.Closed]. Drawer-entries can be animated when the drawer moves from Closed to Open state and vice-versa. For, e.g., the entry could show only an icon in the Closed state and slide in text to form (icon + text) when in the Open state.To limit the width of the drawer in the open or closed state, wrap the content in a box with therequired width. |
modifier | the [Modifier] to be applied to this drawer |
drawerState | state of the drawer |
content | content of the rest of the UI |
Code Example
SampleNavigationDrawer
@Composable
fun SampleNavigationDrawer() {
var selectedIndex by remember { mutableIntStateOf(0) }
val items =
listOf(
"Home" to Icons.Default.Home,
"Settings" to Icons.Default.Settings,
"Favourites" to Icons.Default.Favorite,
)
NavigationDrawer(
drawerContent = {
Column(
Modifier.background(Color.Gray).fillMaxHeight().padding(12.dp).selectableGroup(),
horizontalAlignment = Alignment.Start,
verticalArrangement = Arrangement.spacedBy(10.dp)
) {
items.forEachIndexed { index, item ->
val (text, icon) = item
NavigationDrawerItem(
selected = selectedIndex == index,
onClick = { selectedIndex = index },
leadingContent = {
Icon(
imageVector = icon,
contentDescription = null,
)
}
) {
Text(text)
}
}
}
}
) {
Button(modifier = Modifier.height(100.dp).fillMaxWidth(), onClick = {}) { Text("BUTTON") }
}
}