前端开发技术

Android JetPack之Navigation

2022-02-14  本文已影响0人  Aron1001

前言

有一段时间没有系统的学习一种android技术了,最近查了一下android的最新技术,感觉都是在讲jetpack,于是就打算学习一下。
花了两天时间学习了一下JetPack - Navagation,在这记录一下。

概念

Navigation是一个可简化Android导航的库和插件。

更确切的来说,Navigation是用来管理Fragment的切换,并且可以通过可视化的方式,看见App的交互流程

优点

添加依赖

implementation "androidx.navigation:navigation-fragment-ktx:$rootProject.navigationVersion"
implementation "androidx.navigation:navigation-ui-ktx:$rootProject.navigationVersion"

创建导航图

点击可添加destination,这里我们准备好三个fragment,分别是LoginFragment,RegisterFragment,WelcomeFragment。

添加destination后的导航图如下所示:


2.png

指定起始destination:
您可以右键点击该目的地,然后点击 Set as Start Destination
代码如下:

<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/login_navigation"
    app:startDestination="@id/welcomeFragment">
   ...
</navigation>

下面我们可以连接destination:
1,在 Design 标签页中,将鼠标悬停在目的地的右侧,该目的地为您希望用户从中导航出来的目的地。该目的地右侧上方会显示一个圆圈。
2,点击您希望用户导航到的目的地,并将光标拖动到该目的地的上方,然后松开。

操作之后,xml文件会自动生成相应的代码:

<fragment
        android:id="@+id/welcomeFragment"
        android:name="com.aron.learning.fragment.WelcomeFragment"
        android:label="WelcomeFragment"
        tools:layout="@layout/fragment_welcome">
        <action
            android:id="@+id/action_welcomeFragment_to_loginFragment"
            app:destination="@id/loginFragment" />
        <action
            android:id="@+id/action_welcomeFragment_to_registerFragment"
            app:destination="@id/registerFragment" />
</fragment>
上一篇 下一篇

猜你喜欢

热点阅读