Jetpack中Navigation的简单使用

2024-06-04 03:12

本文主要是介绍Jetpack中Navigation的简单使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 效果图
  • 添加引用
  • 准备好fragment
  • 创建导航图 Navigation Graph
  • 在 xml 中引入NavHostFragment
  • 在代码中获取controller并写跳转逻辑
  • 带参数的页面跳转
  • demo下载地址
  • 参考文献

效果图

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

添加引用

  1. 在gradle文件夹下的libs.versions.toml中添加如下代码
[versions]
...
navigation = "2.7.7"[libraries]
...
androidx-navigation-ui-ktx = { module = "androidx.navigation:navigation-ui-ktx", version.ref = "navigation" }
androidx-navigation-fragment-ktx = { module = "androidx.navigation:navigation-fragment-ktx", version.ref = "navigation" }
  1. 在 app 下的build.gradle中添加如下代码
dependencies {...// Kotlinimplementation(libs.androidx.navigation.fragment.ktx)implementation(libs.androidx.navigation.ui.ktx)
}
  1. 如果需要用到传参,就需要一下步骤,否则跳过

    1. 在gradle文件夹下的libs.versions.toml中添加如下代码
    [versions]
    ...
    navigation = "2.7.7"[libraries]
    # 选如果需要传参,就添加
    androidx-navigation-safe-args-gradle-plugin = { module = "androidx.navigation:navigation-safe-args-gradle-plugin", version.ref = "navigation" }
    
    1. 在项目的build.gradle文件中添加如下代码
    // Top-level build file where you can add configuration options common to all sub-projects/modules.
    buildscript {dependencies {classpath(libs.androidx.navigation.safe.args.gradle.plugin)}
    }
    plugins {...
    }
    
    1. 在 app 的 build.gradle 文件中添加引用
    plugins {...id("androidx.navigation.safeargs.kotlin")
    }
    

准备好fragment

这个自己准备

创建导航图 Navigation Graph

  1. res目录下创建navigation文件夹
  2. navigation文件夹下新建 navigation_phone.xml
<?xml version="1.0" encoding="utf-8"?>
<navigation xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:id="@+id/navigation_phone"app:startDestination="@id/fragmentHome"><!--id: 给fragment起的名字,后续是用来跳转用的name:是具体fragment的路径layout:是用来预览用的--><fragmentandroid:id="@+id/fragmentHome"android:name="com.test.navigationdemo.fragment.HomeFragment"tools:layout="@layout/fragment_home" />...<fragmentandroid:id="@+id/fragmentMine"android:name="com.test.navigationdemo.fragment.MineFragment"tools:layout="@layout/fragment_mine"><!--id: 也是后续用来跳转用的destination:跳转的目的地,也是 fragment 标签的identerAnim ,exitAnim,popEnterAnim,popExitAnim 是用来设置进入和退出动画的--><actionandroid:id="@+id/action_fragmentMine_to_fragmentPrivacy"app:destination="@id/fragmentPrivacy"app:enterAnim="@anim/slide_in_right"app:exitAnim="@anim/slide_out_left"app:popEnterAnim="@anim/slide_in_left"app:popExitAnim="@anim/slide_out_right" /></fragment></navigation>

在 xml 中引入NavHostFragment

<!-- app:defaultNavHost="true"设置为true,代表回退栈由navController管理如果想自己管理,就不设置-->
<!-- 注意:这里我用的是FragmentContainerView,如果使用的是 fragment 标签,在 MainActivity代码中获取controller有区别
-->
<androidx.fragment.app.FragmentContainerViewandroid:id="@+id/fragmentStart"android:name="androidx.navigation.fragment.NavHostFragment"android:layout_width="0dp"android:layout_height="0dp"app:layout_constraintBottom_toTopOf="@id/rbGroup"app:layout_constraintLeft_toLeftOf="parent"app:layout_constraintRight_toRightOf="parent"app:layout_constraintTop_toTopOf="parent"app:navGraph="@navigation/navigation_phone" />

在代码中获取controller并写跳转逻辑

val hostFragment = supportFragmentManager.findFragmentById(R.id.fragmentStart) as NavHostFragment
val navController = hostFragment.navController
// 添加动画
val options = NavOptions.Builder().setEnterAnim(R.anim.fade_in).setExitAnim(R.anim.fade_out).build()
bind.rbGroup.setOnCheckedChangeListener { _, checkedId ->when (checkedId) {bind.rbHome.id -> navController.navigate(R.id.fragmentHome, null, options)bind.rbNews.id -> navController.navigate(R.id.fragmentNews, null, options)bind.rbHots.id -> navController.navigate(R.id.fragmentHots, null, options)bind.rbMine.id -> navController.navigate(R.id.fragmentMine, null, options)}
}

带参数的页面跳转

  1. 在 navigation graph中 需要接收参数的fragment下面添加argument标签
<?xml version="1.0" encoding="utf-8"?>
<navigation xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:id="@+id/navigation_phone"app:startDestination="@id/fragmentHome">...<fragmentandroid:id="@+id/fragmentParam"android:name="com.test.navigationdemo.fragment.ParamsFragment"tools:layout="@layout/fragment_parmas"><!--name:参数名argType:参数类型defaultValue:默认值--><argumentandroid:name="name"android:defaultValue="nobody"app:argType="string" /><argumentandroid:name="age"android:defaultValue="0"app:argType="integer" /></fragment></navigation>
  1. kotlin 代码如下
val navDirections =MineFragmentDirections.actionFragmentMineToFragmentParam(bind.edtName.text.toString().trim(),bind.edtAge.text.toString().toIntOrNull() ?: 0)
findNavController().navigate(navDirections)

demo下载地址

demo下载地址

参考文献

1. Navigation | Android Developers

这篇关于Jetpack中Navigation的简单使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1028904

相关文章

C语言中联合体union的使用

本文编辑整理自: http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=179471 一、前言 “联合体”(union)与“结构体”(struct)有一些相似之处。但两者有本质上的不同。在结构体中,各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和。而在“联合”中,各成员共享一段内存空间, 一个联合变量

Tolua使用笔记(上)

目录   1.准备工作 2.运行例子 01.HelloWorld:在C#中,创建和销毁Lua虚拟机 和 简单调用。 02.ScriptsFromFile:在C#中,对一个lua文件的执行调用 03.CallLuaFunction:在C#中,对lua函数的操作 04.AccessingLuaVariables:在C#中,对lua变量的操作 05.LuaCoroutine:在Lua中,

一份LLM资源清单围观技术大佬的日常;手把手教你在美国搭建「百万卡」AI数据中心;为啥大模型做不好简单的数学计算? | ShowMeAI日报

👀日报&周刊合集 | 🎡ShowMeAI官网 | 🧡 点赞关注评论拜托啦! 1. 为啥大模型做不好简单的数学计算?从大模型高考数学成绩不及格说起 司南评测体系 OpenCompass 选取 7 个大模型 (6 个开源模型+ GPT-4o),组织参与了 2024 年高考「新课标I卷」的语文、数学、英语考试,然后由经验丰富的判卷老师评判得分。 结果如上图所

Vim使用基础篇

本文内容大部分来自 vimtutor,自带的教程的总结。在终端输入vimtutor 即可进入教程。 先总结一下,然后再分别介绍正常模式,插入模式,和可视模式三种模式下的命令。 目录 看完以后的汇总 1.正常模式(Normal模式) 1.移动光标 2.删除 3.【:】输入符 4.撤销 5.替换 6.重复命令【. ; ,】 7.复制粘贴 8.缩进 2.插入模式 INSERT

Lipowerline5.0 雷达电力应用软件下载使用

1.配网数据处理分析 针对配网线路点云数据,优化了分类算法,支持杆塔、导线、交跨线、建筑物、地面点和其他线路的自动分类;一键生成危险点报告和交跨报告;还能生成点云数据采集航线和自主巡检航线。 获取软件安装包联系邮箱:2895356150@qq.com,资源源于网络,本介绍用于学习使用,如有侵权请您联系删除! 2.新增快速版,简洁易上手 支持快速版和专业版切换使用,快速版界面简洁,保留主

如何免费的去使用connectedpapers?

免费使用connectedpapers 1. 打开谷歌浏览器2. 按住ctrl+shift+N,进入无痕模式3. 不需要登录(也就是访客模式)4. 两次用完,关闭无痕模式(继续重复步骤 2 - 4) 1. 打开谷歌浏览器 2. 按住ctrl+shift+N,进入无痕模式 输入网址:https://www.connectedpapers.com/ 3. 不需要登录(也就是

Toolbar+DrawerLayout使用详情结合网络各大神

最近也想搞下toolbar+drawerlayout的使用。结合网络上各大神的杰作,我把大部分的内容效果都完成了遍。现在记录下各个功能效果的实现以及一些细节注意点。 这图弹出两个菜单内容都是仿QQ界面的选项。左边一个是drawerlayout的弹窗。右边是toolbar的popup弹窗。 开始实现步骤详情: 1.创建toolbar布局跟drawerlayout布局 <?xml vers

回调的简单理解

之前一直不太明白回调的用法,现在简单的理解下 就按这张slidingmenu来说,主界面为Activity界面,而旁边的菜单为fragment界面。1.现在通过主界面的slidingmenu按钮来点开旁边的菜单功能并且选中”区县“选项(到这里就可以理解为A类调用B类里面的c方法)。2.通过触发“区县”的选项使得主界面跳转到“区县”相关的新闻列表界面中(到这里就可以理解为B类调用A类中的d方法

自制的浏览器主页,可以是最简单的桌面应用,可以把它当成备忘录桌面应用

自制的浏览器主页,可以是最简单的桌面应用,可以把它当成备忘录桌面应用。如果你看不懂,请留言。 完整代码: <!DOCTYPE html><html lang="zh-CN"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><ti

C#中,decimal类型使用

在Microsoft SQL Server中numeric类型,在C#中使用的时候,需要用decimal类型与其对应,不能使用int等类型。 SQL:numeric C#:decimal