在 Kotlin 中,使用 Navigation Component 可以轻松实现应用内的导航。以下是实现跳转的步骤:
在项目的 build.gradle 文件中添加 Navigation Component 的依赖项:
dependencies {
def nav_version = "2.3.5" // 使用最新版本
implementation "androidx.navigation:navigation-fragment:$nav_version"
implementation "androidx.navigation:navigation-ui:$nav_version"
}
在 res 文件夹下创建一个名为 navigation 的目录,并在其中创建一个名为 nav_graph.xml 的文件。这个文件定义了应用中的导航路由。
例如,创建一个简单的 nav_graph.xml 文件:
<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/nav_graph"
app:startDestination="@id/firstFragment">
<fragment
android:id="@+id/firstFragment"
android:name="com.example.app.FirstFragment"
tools:layout="@layout/fragment_first">
</fragment>
<fragment
android:id="@+id/secondFragment"
android:name="com.example.app.SecondFragment"
tools:layout="@layout/fragment_second">
</fragment>
</navigation>
在主 Activity(通常是 MainActivity)中,设置 Navigation Controller 并将其与导航图关联。
import androidx.appcompat.app.AppCompatActivity
import androidx.navigation.NavController
import androidx.navigation.fragment.NavHostFragment
import androidx.navigation.ui.setupActionBarWithNavController
import androidx.navigation.ui.setupWithNavController
class MainActivity : AppCompatActivity() {
private lateinit var navController: NavController
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val navHostFragment =
supportFragmentManager.findFragmentById(R.id.nav_host_fragment) as NavHostFragment
navController = navHostFragment.navController
setupActionBarWithNavController(navController)
}
override fun onSupportNavigateUp(): Boolean {
return navController.navigateUp() || super.onSupportNavigateUp()
}
}
在需要实现跳转的 Fragment 中,使用 Navigation UI 工具栏按钮或代码进行导航。
例如,在 FirstFragment 中添加一个按钮,点击时跳转到 SecondFragment:
import androidx.navigation.NavController
import androidx.navigation.fragment.NavHostFragment
import androidx.navigation.ui.NavigationUI
class FirstFragment : Fragment() {
private lateinit var navController: NavController
override fun onCreateView(
inflater: LayoutInflater, container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
val view = inflater.inflate(R.layout.fragment_first, container, false)
val navHostFragment =
parentFragmentManager.findFragmentById(R.id.nav_host_fragment) as NavHostFragment
navController = navHostFragment.navController
NavigationUI.setupWithNavController(view, navController)
view.findViewById<Button>(R.id.navigate_to_second_fragment)?.setOnClickListener {
navController.navigate(R.id.secondFragment)
}
return view
}
}
现在,当用户点击 FirstFragment 中的按钮时,应用将导航到 SecondFragment。