最近有点空余时间,来学点新东西,就开始学习之前一直想学的Jetpack组件
所以先从Navigation开始,废话不多说直接开始:
一.先添加相关依赖
// Java
implementation "androidx.navigation:navigation-fragment:$nav_version"
implementation "androidx.navigation:navigation-ui:$nav_version"
// Kotlin
implementation "androidx.navigation:navigation-fragment-ktx:$nav_version"
implementation "androidx.navigation:navigation-ui-ktx:$nav_version"
二.在res目录下新建navigation文件夹,并创建一个navigation类型的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"
app:startDestination="@id/page1Fragment">
<fragment
android:id="@+id/page1Fragment"
android:name="com.ypf.myjetpack.MainPage1Fragment"
android:label="fragment_page1"
tools:layout="@layout/fragment_main_page1">
<action
android:id="@+id/action_page2"
app:destination="@id/page2Fragment"/>
</fragment>
<fragment
android:id="@+id/page2Fragment"
android:name="com.ypf.myjetpack.MainPage2Fragment"
android:label="fragment_page2"
tools:layout="@layout/fragment_main_page2">
<action
android:id="@+id/action_page1"
app:popUpTo="@id/page1Fragment"/>
<action
android:id="@+id/action_page3"
app:destination="@id/nav_graph_page3"/>
</fragment>
<navigation
android:id="@+id/nav_graph_page3"
app:startDestination="@id/page3Fragment">
<fragment
android:id="@+id/page3Fragment"
android:name="com.ypf.myjetpack.MainPage3Fragment"
android:label="fragment_page3"
tools:layout="@layout/fragment_main_page3"/>
</navigation>
</navigation>
三.新建三个Fragment并设置跳转事件
class MainPage1Fragment : Fragment() {
override fun onCreateView(
inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?
): View {
return inflater.inflate(R.layout.fragment_main_page1, container, false)
}
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
btn_one.setOnClickListener{
Navigation.findNavController(it).navigate(R.id.action_page2)
}
}
}
class MainPage2Fragment : Fragment() {
override fun onCreateView(
inflater: LayoutInflater, container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
return inflater.inflate(R.layout.fragment_main_page2, container, false)
}
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
btn_two.setOnClickListener {
//点击返回page1
Navigation.findNavController(it).navigateUp()
}
btn_two_2.setOnClickListener {
Navigation.findNavController(it).navigate(R.id.action_page3)
}
}
}
class MainPage3Fragment : Fragment() {
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?,
savedInstanceState: Bundle?): View? {
return inflater.inflate(R.layout.fragment_main_page3, container, false)
}
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
btn_three.setOnClickListener {
Navigation.findNavController(it).navigateUp()
}
}
}
四.Mainactivity相关配置
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
}
override fun onSupportNavigateUp() =
findNavController(R.id.my_nav_host_fragment).navigateUp()
}
对应的xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools" xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/container"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<fragment
android:id="@+id/my_nav_host_fragment"
android:name="androidx.navigation.fragment.NavHostFragment"//设置navigation容器
android:layout_width="match_parent"
android:layout_height="match_parent"
app:defaultNavHost="true"//设置是否拦截返回键
app:navGraph="@navigation/nav_graph_main"/>//加载定义的nav_graph_main.xml文件
</LinearLayout>
最终大功告成
效果图如下:
图一 图二 图三
跳转逻辑如下:
点击图一的按钮切换到Page2,点击图二按钮分别跳转到page3和上一个页面
相关源码:https://download.youkuaiyun.com/download/u013075460/11847256