시작하기

Navigation 3을 시작하려면 지원 라이브러리와 함께 라이브러리를 프로젝트에 추가합니다. 아래 표를 사용하여 추가할 라이브러리를 결정합니다.

아티팩트

이름

기능

아티팩트

Navigation 3 런타임 라이브러리

Core Navigation 3 API NavEntry, EntryProvider 및 관련 DSL을 포함합니다.

androidx.navigation3:navigation3-runtime

Navigation 3 UI 라이브러리

NavDisplayScene를 비롯하여 콘텐츠를 표시하는 클래스를 제공합니다.

androidx.navigation3:navigation3-ui

탐색 3의 ViewModel 수명 주기

ViewModel의 범위를 백 스택의 항목으로 지정할 수 있습니다.

androidx.lifecycle:lifecycle-viewmodel-navigation3

스냅샷 빌드에서 사용 가능

Navigation 3용 Material 3 적응형 레이아웃

NavDisplay와 함께 사용할 수 있는 적응형 레이아웃 (SceneStrategies, Scenes, 메타데이터 정의)을 제공합니다.

androidx.compose.material3.adaptive:adaptive-navigation3

스냅샷 빌드에서 사용 가능

KotlinX 직렬화

탐색 키를 직렬화할 수 있습니다.

플러그인: org.jetbrains.kotlin.plugin.serialization

라이브러리:

org.jetbrains.kotlinx:kotlinx-serialization-core

org.jetbrains.kotlinx:kotlinx-serialization-json

프로젝트 설정

기존 프로젝트에 Navigation 3 라이브러리를 추가하려면 libs.versions.toml에 다음을 추가합니다.

[versions]
nav3Core = "1.0.0-alpha01"
nav3Material = "1.0.0-SNAPSHOT"
nav3Lifecycle = "1.0.0-alpha01"
kotlinSerialization = "2.1.21"
kotlinxSerializationCore = "1.8.1"

[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-material3-navigation3 = { group = "androidx.compose.material3.adaptive", name = "adaptive-navigation3", version.ref = "nav3Material" }
androidx-lifecycle-viewmodel-navigation3 = { module = "androidx.lifecycle:lifecycle-viewmodel-navigation3", version.ref = "nav3Lifecycle" }
kotlinx-serialization-core = { module = "org.jetbrains.kotlinx:kotlinx-serialization-core", version.ref = "kotlinxSerializationCore" }
kotlinx-serialization-json = { module = "org.jetbrains.kotlinx:kotlinx-serialization-json", version.ref = "kotlinxSerializationCore" }

[plugins]
# Optional plugins
jetbrains-kotlin-serialization = { id = "org.jetbrains.kotlin.plugin.serialization", version.ref = "kotlinSerialization"}

빌드 파일 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)
    implementation(libs.androidx.lifecycle.viewmodel.navigation3)
    implementation(libs.androidx.material3.navigation3)
    implementation(libs.kotlinx.serialization.core)
    implementation(libs.kotlinx.serialization.json)
}