当前位置:   article > 正文

Android开发Jetpack从入门到精通教程_jiepack 教程

jiepack 教程

前言

即学即用Android Jetpack系列Blog的目的是通过学习Android Jetpack完成一个简单的Demo,本文是即学即用Android Jetpack系列Blog的第一篇。

记得去年第一次参加谷歌开发者大会的时候,就被Navigation的图形导航界面给迷住了,一句卧槽就代表了小王的全部心情~,我们可以看一下来自网络的一张图片:

Android Jetpack从入门到精通(深度好文,值得收藏)

 

所以,Android Jetpack学习之旅就开始了。

Android Jetpack从入门到精通(深度好文,值得收藏)

 

本人打算每周学习一个组件(上图的左上区域),最后将所学的组件组成一个简单的Demo。同时,刚刚过去的2019年谷歌开发者大会宣布亲儿子Kotlin成为开发Android的首选语言,所以本文的Demo也将都会采用Kotlin编写。

本章结束后登录部分完成效果:

Android Jetpack从入门到精通(深度好文,值得收藏)

 

语言:KotlinDemo地址:https://github.com/mCyp/Hoo

目录

一、简介

1. 定义

Navigation是什么呢?谷歌的介绍视频上说:

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

更确切的来说,Navigation是用来管理Fragment的切换,并且可以通过可视化的方式,看见App的交互流程。这完美的契合了Jake Wharton大神单Activity的建议。

2. 优点

  • 处理Fragment的切换(上文已说过)
  • 默认情况下正确处理Fragment的前进和后退
  • 为过渡和动画提供标准化的资源
  • 实现和处理深层连接
  • 可以绑定Toolbar、BottomNavigationView和ActionBar等
  • SafeArgs(Gradle插件) 数据传递时提供类型安全性
  • ViewModel支持

3. 准备

如果想要进行下面的学习,你需要 3.2 或者更高的Android studio。

4. 学习方式

最好的学习方式仍然是通过官方文档,下面是官方的学习地址:谷歌官方教程:Navigation Codelab谷歌官方文档:Navigation官方Demo:Demo地址

二、实战

在实战之前,我们先来了解一下Navigation中最关键的三要素,他们是:

名词解释Navigation Graph(New XML resource)如我们的第一张图所示,这是一个新的资源文件,用户在可视化界面可以看出他能够到达的Destination(用户能够到达的屏幕界面),以及流程关系。NavHostFragment(Layout XML view)当前Fragment的容器NavController(Kotlin/Java object)导航的控制者

可能我这么解释还是有点抽象,做一个不是那么恰当的比喻,我们可以将Navigation Graph看作一个地图,NavHostFragment看作一个车,以及把NavController看作车中的方向盘,Navigation Graph中可以看出各个地点(Destination)和通往各个地点的路径,NavHostFragment可以到达地图中的各个目的地,但是决定到什么目的地还是方向盘NavController,虽然它取决于开车人(用户)。

第一步 添加依赖

模块层的build.gradle文件需要添加:

  1. ext.navigationVersion = "2.0.0"
  2. dependencies {
  3. //...
  4. implementation "androidx.navigation:navigation-fragment-ktx:$rootProject.navigationVersion"
  5. implementation "androidx.navigation:navigation-ui-ktx:$rootProject.navigationVersion"
  6. }

如果你要使用SafeArgs插件,还要在项目目录下的build.gradle文件添加:

  1. buildscript {
  2. ext.navigationVersion = "2.0.0"
  3. dependencies {
  4. classpath "androidx.navigation:navigation-safe-args-gradle-plugin:$navigationVersion"
  5. }
  6. }

以及模块下面的build.gradle文件添加:

  1. apply plugin: 'kotlin-android-extensions'
  2. apply plugin: 'androidx.navigation.safeargs'

第二步 创建navigation导航

  1. 创建基础目录:资源文件res目录下创建navigation目录 -> 右击navigation目录New一个Navigation resource file
  2. 创建一个Destination,如果说navigation是我们的导航工具,Destination是我们的目的地,在此之前,我已经写好了一个WelcomeFragment、LoginFragment和RegisterFragment,添加Destination的操作完成后如下所示:

除了可视化界面之外,我们仍然有必要看一下里面的内容组成,login_navigation.xml:

  1. <navigation
  2. ...
  3. android:id="@+id/login_navigation"
  4. app:startDestination="@id/welcome">
  5. <fragment
  6. android:id="@+id/login"
  7. android:name="com.joe.jetpackdemo.ui.fragment.login.LoginFragment"
  8. android:label="LoginFragment"
  9. tools:layout="@layout/fragment_login"
  10. />
  11. <fragment
  12. android:id="@+id/welcome"
  13. android:name="com.joe.jetpackdemo.ui.fragment.login.WelcomeFragment"
  14. android:label="LoginFragment"
  15. tools:layout="@layout/fragment_welcome">
  16. <action
  17. .../>
  18. <action
  19. .../>
  20. </fragment>
  21. <fragment
  22. android:id="@+id/register"
  23. android:name="com.joe.jetpackdemo.ui.fragment.login.RegisterFragment"
  24. android:label="LoginFragment"
  25. tools:layout="@layout/fragment_register"
  26. >
  27. <argument
  28. .../>
  29. </fragment>
  30. </navigation>

我在这里省略了一些不必要的代码。让我们看一下navigation标签的属性:

属性解释app:startDestination默认的起始位置

第三步 建立NavHostFragment

我们创建一个新的LoginActivity,在activity_login.xml文件中:

  1. <androidx.constraintlayout.widget.ConstraintLayout
  2. ...>
  3. <fragment
  4. android:id="@+id/my_nav_host_fragment"
  5. android:name="androidx.navigation.fragment.NavHostFragment"
  6. app:navGraph="@navigation/login_navigation"
  7. app:defaultNavHost="true"
  8. android:layout_width="match_parent"
  9. android:layout_height="match_parent"/>
  10. </androidx.constraintlayout.widget.ConstraintLayout>

有几个属性需要解释一下:

属性解释android:name值必须是androidx.navigation.fragment.NavHostFragment,声明这是一个NavHostFragmentapp:navGraph存放的是第二步建好导航的资源文件,也就是确定了Navigation Graphapp:defaultNavHost="true"与系统的返回按钮相关联

第四步 界面跳转、参数传递和动画

在WelcomeFragment中,点击登录和注册按钮可以分别跳转到LoginFragment和RegisterFragment中。

Android Jetpack从入门到精通(深度好文,值得收藏)

 

image

这里我使用了两种方式实现:

方式一 利用ID导航

目标:WelcomeFragment携带key为name的数据跳转到LoginFragment,LoginFragment接收后显示。Have a account ? Login按钮的点击事件如下:

  1. btnLogin.setOnClickListener {
  2. // 设置动画参数
  3. val navOption = navOptions {
  4. anim {
  5. enter = R.anim.slide_in_right
  6. exit = R.anim.slide_out_left
  7. popEnter = R.anim.slide_in_left
  8. popExit = R.anim.slide_out_right
  9. }
  10. }
  11. // 参数设置
  12. val bundle = Bundle()
  13. bundle.putString("name","TeaOf")
  14. findNavController().navigate(R.id.login, bundle,navOption)
  15. }

后续LoginFragment的接收代码比较简单,直接获取Fragment中的Bundle即可,这里不再出示代码。最后的效果:

Android Jetpack从入门到精通(深度好文,值得收藏)

 

方式二 利用Safe Args

目标:WelcomeFragment通过Safe Args将数据传到RegisterFragment,RegisterFragment接收后显示。再看一下已经展示过的login_navigation.xml:

  1. <navigation
  2. ...>
  3. <fragment
  4. ...
  5. />
  6. <fragment
  7. android:id="@+id/welcome"
  8. >
  9. <action
  10. android:id="@+id/action_welcome_to_login"
  11. app:destination="@id/login"/>
  12. <action
  13. android:id="@+id/action_welcome_to_register"
  14. app:enterAnim="@anim/slide_in_right"
  15. app:exitAnim="@anim/slide_out_left"
  16. app:popEnterAnim="@anim/slide_in_left"
  17. app:popExitAnim="@anim/slide_out_right"
  18. app:destination="@id/register"/>
  19. </fragment>
  20. <fragment
  21. android:id="@+id/register"
  22. ...
  23. >
  24. <argument
  25. android:name="EMAIL"
  26. android:defaultValue="2005@qq.com"
  27. app:argType="string"/>
  28. </fragment>
  29. </navigation>

细心的同学可能已经观察到navigation目录下的login_navigation.xml资源文件中的action标签和argument标签,这里需要解释一下:action标签

属性作用app:destination跳转完成到达的fragment的Idapp:popUpTo将fragment从栈中弹出,直到某个Id的fragment

argument标签

属性作用android:name标签名字app:argType标签的类型android:defaultValue默认值

点击Android studio中的Make Project按钮,可以发现系统为我们生成了两个类:

Android Jetpack从入门到精通(深度好文,值得收藏)

 

WelcomeFragment中的JOIN US按钮点击事件:

  1. btnRegister.setOnClickListener {
  2. val action = WelcomeFragmentDirections
  3. .actionWelcomeToRegister()
  4. .setEMAIL("TeaOf1995@Gamil.com")
  5. findNavController().navigate(action)
  6. }

RegisterFragment中的接收:

  1. override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
  2. super.onViewCreated(view, savedInstanceState)
  3. // ...
  4. val safeArgs:RegisterFragmentArgs by navArgs()
  5. val email = safeArgs.email
  6. mEmailEt.setText(email)
  7. }

以及效果:

Android Jetpack从入门到精通(深度好文,值得收藏)

 

需要提及的是,如果不用Safe Args,action可以由Navigation.createNavigateOnClickListener(R.id.next_action, null)方式生成,感兴趣的同学可以自行编写。

三、更多

Navigation可以绑定menus、drawers和bottom navigation,这里我们以bottom navigation为例,我先在navigation目录下新创建了main_navigation.xml,接着新建了MainActivity,下面则是activity_main.xml:

  1. <LinearLayout
  2. ...>
  3. <fragment
  4. android:id="@+id/my_nav_host_fragment"
  5. android:name="androidx.navigation.fragment.NavHostFragment"
  6. android:layout_width="match_parent"
  7. app:navGraph="@navigation/main_navigation"
  8. app:defaultNavHost="true"
  9. android:layout_height="0dp"
  10. android:layout_weight="1"/>
  11. <com.google.android.material.bottomnavigation.BottomNavigationView
  12. android:id="@+id/navigation_view"
  13. android:layout_width="match_parent"
  14. android:layout_height="wrap_content"
  15. android:background="@android:color/white"
  16. app:itemIconTint="@color/colorAccent"
  17. app:itemTextColor="@color/colorPrimary"
  18. app:menu="@menu/menu_main"/>
  19. </LinearLayout>

MainActivity中的处理也十分简单:

  1. class MainActivity : AppCompatActivity() {
  2. lateinit var bottomNavigationView: BottomNavigationView
  3. override fun onCreate(savedInstanceState: Bundle?) {
  4. //...
  5. val host: NavHostFragment = supportFragmentManager.findFragmentById(R.id.my_nav_host_fragment) as NavHostFragment
  6. val navController = host.navController
  7. initWidget()
  8. initBottomNavigationView(bottomNavigationView,navController)
  9. }
  10. private fun initBottomNavigationView(bottomNavigationView: BottomNavigationView, navController: NavController) {
  11. bottomNavigationView.setupWithNavController(navController)
  12. }
  13. private fun initWidget() {
  14. bottomNavigationView = findViewById(R.id.navigation_view)
  15. }
  16. }

效果:

Android Jetpack从入门到精通(深度好文,值得收藏)

 

四、总结

Android Jetpack从入门到精通(深度好文,值得收藏)现在都说互联网寒冬,其实只要自身技术能力够强,咱们就不怕!我这边专门针对Android开发工程师整理了一套【Android进阶学习视频】、【全套Android面试秘籍】、【Android知识点PDF】。如有需要获取资料文档的朋友,可以[点击我的GitHub]免费获取

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/253921
推荐阅读
相关标签
  

闽ICP备14008679号