当前位置: 首页 > news >正文

kotlin,jetpack compose 最简导航(navigation)案例学习

// 添加导航组件依赖,用于支持Compose中的导航功能
implementation ("androidx.navigation:navigation-compose:2.8.9")
// 定义包名
package com.example.mynavigation

// 导入所需的Android和Compose库
import android.os.Bundle
import androidx.activity.ComponentActivity
import androidx.activity.compose.setContent
import androidx.activity.enableEdgeToEdge
import androidx.compose.foundation.layout.Arrangement
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.foundation.layout.padding
import androidx.compose.material3.Button
import androidx.compose.material3.Scaffold
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.tooling.preview.Preview
import androidx.navigation.NavController
import androidx.navigation.compose.NavHost
import androidx.navigation.compose.composable
import androidx.navigation.compose.rememberNavController
import com.example.mynavigation.ui.theme.MyNavigationTheme

// 定义MainActivity类,继承自ComponentActivity
class MainActivity : ComponentActivity() {
    // 重写onCreate方法,用于初始化Activity
    override fun onCreate(savedInstanceState: Bundle?) {
        // 调用父类的onCreate方法
        super.onCreate(savedInstanceState)
        // 启用边缘到边缘的显示模式
        enableEdgeToEdge()
        // 设置Activity的内容视图
        setContent {
            // 使用自定义的主题
            MyNavigationTheme {
                // 创建一个导航控制器
                val navController = rememberNavController()
                // 定义导航图
                NavHost(navController = navController, startDestination = "home") {
                    // 定义home目的地的界面
                    composable("home") { HomeScreen(navController) }
                    // 定义detail456目的地的界面,并传递id参数
                    composable("detail/{id}") { backStackEntry ->
                        // 从导航参数中获取id
                        val id = backStackEntry.arguments?.getString("id")
                        // 显示DetailScreen界面
                        DetailScreen(navController, id)
                    }
                }
            }
        }
    }
}

// 定义HomeScreen可组合函数,用于显示主界面
@Composable
fun HomeScreen(navController: NavController) {
    // 使用Column布局,填充整个屏幕,内容垂直和水平居中
    Column(
        modifier = Modifier.fillMaxSize(), // 填充整个屏幕
        verticalArrangement = Arrangement.Center, // 垂直居中
        horizontalAlignment = Alignment.CenterHorizontally // 水平居中
    ) {
        // 定义一个按钮,点击后导航到detail456界面,并传递id参数
        Button(onClick = { navController.navigate("detail/123") }) {
            // 按钮上显示文本
            Text("Navigate with ID 123")
        }
    }
}

// 定义DetailScreen可组合函数,用于显示详情界面
@Composable
fun DetailScreen(navController: NavController, id: String?) {
    // 使用Column布局,填充整个屏幕,内容垂直和水平居中
    Column(
        modifier = Modifier.fillMaxSize(), // 填充整个屏幕
        verticalArrangement = Arrangement.Center, // 垂直居中
        horizontalAlignment = Alignment.CenterHorizontally // 水平居中
    ) {
        // 显示详情界面的标题
        Text("Detail Screen")
        // 显示传递过来的id,如果id为空则显示"Unknown"
        Text("ID:  ${id ?: "Unknown"}")
        // 定义一个按钮,点击后返回上一个界面
        Button(onClick = { navController.navigateUp() }) {
            // 按钮上显示文本
            Text("Back")
        }
    }
}

相关文章:

  • 1.2-WAF\CDN\OSS\反向代理\负载均衡
  • AI数据分析:一键生成数据分析维度
  • boost.asio
  • 在 i.MX8MP 上用 C++ 调用豆包 AI 大模型实现图像问答
  • 东方通TongHttpServer报错403
  • RFID技术在机器人中的核心应用场景及技术实现
  • Reactive编程:什么是Reactive编程?Reactive编程思想
  • git中feature跟hotfix是什么意思
  • VSCode:Linux下安装使用
  • 区块链知识点知识点3
  • MybatisPlus(SpringBoot版)学习第六讲:插件(分页插件乐观锁)
  • dom0-kernel: /thermal-zones/soc_max/cooling-maps/map0: could not find phandle 2
  • (C语言)指针运算 习题练习1.2(压轴难题)
  • kali利用msf渗透Windows电脑测试
  • 《Keras 3 :AI 使用图神经网络和 LSTM 进行交通流量预测》
  • 数据结构之多项式相加的链表实现
  • PHP文件的导出和导入
  • 蓝桥杯省模拟赛 01串个数
  • 攻破tensorflow,勇创最佳agent(1)---学习率learning_rate问题
  • 【云服务器】在 Linux(Ubuntu / CentOS 7)上快速搭建我的世界 Minecraft 服务器,并实现远程联机,详细教程
  • 市场监管总局召开平台企业支持个体工商户发展座谈会
  • 京东CEO许冉:外卖日单量接近2000万单,看到外卖对平台拉动和转化效应
  • 人民日报评外卖平台被约谈:摒弃恶性竞争,实现行业健康发展
  • 李强会见巴西总统卢拉
  • 中国巴西民间推动建立经第三方验证的“森林友好型”牛肉供应链
  • 时隔4年多,这一次普京和泽连斯基能见面吗?