开发一个新项目,底部导航栏一般是首页的标配,在以前的xml布局中,我们可以很轻松的是用谷歌提供的BottomNavigationView
或者自定义来实现底部导航的功能,在Compose中也有也提供了一个类似的控件androidx.compose.material.BottomNavigation
。
1.声明导航栏数据源
主要声明导航栏label和图标数组,这里使用的是本地数据,也可以使用网络数据。
//导航label数组
private val labels = arrayOf("首页", "房讯", "消息", "我的")
//导航默认图标集合
private val defImages =
arrayOf(R.mipmap.img_index, R.mipmap.img_info, R.mipmap.img_message, R.mipmap.img_preson)
//导航选中图标集合
private var selectImages =
arrayOf(
R.mipmap.img_index_select,
R.mipmap.img_info_select,
R.mipmap.img_message_select,
R.mipmap.img_preson_select
)
//导航选中索引
private var selectIndex by mutableStateOf(0)
复制代码
2.使用Scaffold
搭建页面结构
Compose给我们提供了Scaffold
脚手架,实现了Material设计的页面基本结构。包括标题栏、底部栏、SnackBar(类似吐司功能)、浮动按钮、抽屉组件、剩余内容布局等,让我们可以快速定义一个基本的页面结构。
setContent {
val navController = rememberNavController()
Scaffold(
//设置底部导航栏
bottomBar = {
BuildBottomBar(labels = labels, navController)
},
) {
//设置页面主内容区域,这里通过NavHost,根据选中不同的导航栏Tab导航到不同的页面。
NavHost(navController = navController, startDestination = labels[selectIndex]) {
composable(labels[0]) {
//首页Compose
IndexPage()
}
composable(labels[1]) {
//咨询Compose
InfoPage()
}
composable(labels[2]) {
//消息Compose
MessagePage()
}
composable(labels[3]) {
//个人中心Compose
PersonPage()
}
}
}
}
复制代码
3.BottomNavigation
的用法
BottomNavigation
中的content可以添加多个BottomNavigationItem
,用来构建导航栏的样式,BottomNavigationItem
中可以设置icon
和label
,选中颜色和未选中颜色等等一些常用的属性。可以给item设置点击事件onClick
等。
BottomNavigation(backgroundColor = Color.White, elevation = 6.dp) {
for (i in labels.indices) {
BottomNavigationItem(selected = selectIndex == i, onClick = {
selectIndex = i
navController.navigate(labels[i])
}, icon = {
Image(
painter = painterResource(id = if (selectIndex == i) selectImages[i] else defImages[i]),
contentDescription = labels[i],
modifier = Modifier.size(25.dp)
)
}, label = {
Text(text = labels[i], color = if (selectIndex == i) Color.Red else Color.Gray)
})
}
}
复制代码
这里用了一个循环来添加BottomNavigationItem
,通过selectIndex
来判断tab是否选中。在点击事件中设置选中的索引。 这里要注意的是在Compose中导航主要是用NavHostController
来进行控制。 需要引入单独的依赖库
implementation "androidx.navigation:navigation-compose:2.4.0-alpha09"
复制代码
通常这个实例是用rememberNavController()
来获取。
val navController = rememberNavController()
复制代码
可以通过navigate
方法来进行导航到具体也面,naviget
传人的参数和NavHost
中的startDestination
参数一致,这样就可以跳转到指定页面中
navController.navigate(labels[i])
复制代码