如要開始使用 Navigation 3,請將程式庫和所有支援程式庫新增至專案。請參考下表,決定要新增哪些程式庫。
成果
名稱 |
用途 |
構件 |
---|---|---|
Navigation 3 執行階段程式庫 |
Core Navigation 3 API。包括 |
androidx.navigation3:navigation3-runtime |
Navigation 3 UI 程式庫 |
提供用於顯示內容的類別,包括 |
androidx.navigation3:navigation3-ui |
Navigation 3 的 ViewModel 生命週期 |
允許將 ViewModel 範圍限定在返回堆疊中的項目。 |
androidx.lifecycle:lifecycle-viewmodel-navigation3 |
Navigation 3 的 Material 3 自動調整式版面配置 |
提供自動調整版面配置 (SceneStrategies、Scenes 和中繼資料定義),可搭配 NavDisplay 使用。 |
androidx.compose.material3.adaptive:adaptive-navigation3 適用於快照版本 |
允許序列化導覽鍵。 |
外掛程式:org.jetbrains.kotlin.plugin.serialization 程式庫: org.jetbrains.kotlinx:kotlinx-serialization-core |
專案設定
如要將 Navigation 3 程式庫新增至現有專案,請在 libs.versions.toml
中加入下列內容:
[versions]
nav3Core = "1.0.0-alpha11"
lifecycleViewmodelNav3 = "2.10.0-alpha05"
kotlinSerialization = "2.1.21"
kotlinxSerializationCore = "1.8.1"
material3AdaptiveNav3 = "1.3.0-alpha01"
[libraries]
# Core Navigation 3 libraries
androidx-navigation3-runtime = { module = "androidx.navigation3:navigation3-runtime", version.ref = "nav3Core" }
androidx-navigation3-ui = { module = "androidx.navigation3:navigation3-ui", version.ref = "nav3Core" }
# Optional add-on libraries
androidx-lifecycle-viewmodel-navigation3 = { module = "androidx.lifecycle:lifecycle-viewmodel-navigation3", version.ref = "lifecycleViewmodelNav3" }
kotlinx-serialization-core = { module = "org.jetbrains.kotlinx:kotlinx-serialization-core", version.ref = "kotlinxSerializationCore" }
androidx-material3-adaptive-navigation3 = { group = "androidx.compose.material3.adaptive", name = "adaptive-navigation3", version.ref = "material3AdaptiveNav3" }
[plugins]
# Optional plugins
jetbrains-kotlin-serialization = { id = "org.jetbrains.kotlin.plugin.serialization", version.ref = "kotlinSerialization"}
此外,請將編譯 SDK 更新至 36 以上版本:
[versions]
compileSdk = "36"
將以下內容新增到應用程式建構檔案 app/build.gradle.kts
:
plugins {
...
// Optional, provides the @Serialize annotation for autogeneration of Serializers.
alias(libs.plugins.jetbrains.kotlin.serialization)
}
dependencies {
...
implementation(libs.androidx.navigation3.ui)
implementation(libs.androidx.navigation3.runtime)
implementation(libs.androidx.lifecycle.viewmodel.navigation3)
implementation(libs.androidx.material3.adaptive.navigation3)
implementation(libs.kotlinx.serialization.core)
}