kotlin,Jetpack Compose使用Scaffold布局,包含底部导航栏

复制代码
package com.example.dibudaohang

import android.os.Bundle
import androidx.activity.ComponentActivity
import androidx.activity.compose.setContent
import androidx.activity.enableEdgeToEdge
import androidx.compose.foundation.layout.padding
import androidx.compose.material.icons.Icons
import androidx.compose.material.icons.filled.Home
import androidx.compose.material.icons.filled.Person
import androidx.compose.material.icons.filled.Search
import androidx.compose.material3.*
import androidx.compose.runtime.*
import androidx.compose.ui.Modifier
import com.example.dibudaohang.ui.theme.DibudaohangTheme

class MainActivity : ComponentActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        enableEdgeToEdge()
        setContent {
            DibudaohangTheme {
                BottomNavigationExample()
            }
        }
    }
}

@Composable
fun BottomNavigationExample() {
    // 使用remember保存选中的项,初始值为0
    var selectedItem by remember { mutableStateOf(0) }
    // 定义底部导航栏的项
    val items = listOf("Home", "Search", "Profile")

    // 使用Scaffold布局,包含底部导航栏
    Scaffold(
        bottomBar = {
            // 创建底部导航栏
            NavigationBar {
                // 遍历items列表,为每个项创建一个NavigationBarItem
                items.forEachIndexed { index, item ->
                    NavigationBarItem(
                        // 根据index选择不同的图标
                        icon = {
                            when (index) {
                                0 -> Icon(Icons.Default.Home, contentDescription = item)
                                1 -> Icon(Icons.Default.Search, contentDescription = item)
                                2 -> Icon(Icons.Default.Person, contentDescription = item)
                            }
                        },
                        // 显示项的标签
                        label = { Text(item) },
                        // 判断当前项是否被选中
                        selected = selectedItem == index,
                        // 点击事件,更新选中的项
                        onClick = { selectedItem = index }
                    )
                }
            }
        }
    ) { innerPadding ->
        // 根据选中的项显示不同的内容
        when (selectedItem) {
            0 -> Text("Home Screen", modifier = Modifier.padding(innerPadding))
            1 -> Text("Search Screen", modifier = Modifier.padding(innerPadding))
            2 -> Text("Profile Screen", modifier = Modifier.padding(innerPadding))
        }
    }
}

注意:在最新的 Jetpack Compose 中,BottomNavigation 已经被 NavigationBar 取代。NavigationBar 是 androidx.compose.material3 包中的新组件,用于实现底部导航栏。
相关推荐
石山岭30 分钟前
自己动手写了一个 Android 虚拟定位 App:GPSSimulate 技术实
android·前端
杉氧3 小时前
副作用 (Side Effects) 全攻略:如何像大师一样掌控 Composable 的生命周期?
android·架构·android jetpack
唐青枫6 小时前
别再把 inline 当性能开关:Kotlin 内联、noinline、crossinline 与 reified 实战详解
kotlin
Kapaseker7 小时前
Kotlin Toolchain 0.11 发布:主要是把 Amper 干没了
android·kotlin
黄林晴7 小时前
AndroidX 官宣信号:Compose版WebView要来了!
kotlin
三少爷的鞋8 小时前
Android 现代架构不需要事件总线进阶篇
android
杉氧1 天前
深入理解 Compose 重组机制:快照系统如何驱动 UI 精准刷新?
android·架构·android jetpack
召钱熏1 天前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
杉氧1 天前
深度解析:Jetpack Compose 核心架构与底层原理 —— 十年安卓老兵的“破茧重生”
android·架构·android jetpack
通玄1 天前
Jetpack Compose 入门系列(七):ViewModel 与界面状态管理
android