navigation3
| העדכון האחרון | גרסה יציבה | גרסה מועמדת להפצה | גרסת בטא | גרסת אלפא |
|---|---|---|---|---|
| 17 ביוני 2026 | 1.1.3 | - | - | 1.2.0-alpha04 |
הצהרה על יחסי תלות
כדי להוסיף תלות ב-navigation3, צריך להוסיף את מאגר Google Maven לפרויקט. מידע נוסף זמין במאמר בנושא מאגר Maven של Google.
אתם יכולים להוסיף את יחסי התלות של הארטיפקטים שאתם צריכים בקובץ build.gradle של האפליקציה או המודול:
Groovy
dependencies { implementation "androidx.navigation3:navigation3-runtime:1.2.0-alpha04" implementation "androidx.navigation3:navigation3-ui:1.2.0-alpha04" }
Kotlin
dependencies { implementation("androidx.navigation3:navigation3-runtime:1.2.0-alpha04") implementation("androidx.navigation3:navigation3-ui:1.2.0-alpha04") }
מידע נוסף זמין במאמר הוספת יחסי תלות ב-build.
משוב
המשוב שלכם עוזר לנו לשפר את Jetpack. נשמח לדעת אם גיליתם בעיות חדשות או אם יש לכם רעיונות איך לשפר את הספרייה הזו. כדאי לעיין בבעיות הידועות בספרייה הזו לפני שמדווחים על בעיה. כדי להוסיף הצבעה בדיווח על בעיה קיימת, לוחצים על כפתור הכוכב.
מידע נוסף זמין במאמרי העזרה בנושא Issue Tracker.
אין הערות לגבי הגרסה של הארטיפקט הזה.
גרסה 1.2 של Navigation3
גרסה 1.2.0-alpha04
3 ביוני 2026
androidx.navigation3:navigation3-*:1.2.0-alpha04 מופץ. גרסה 1.2.0-alpha04 מכילה את השמירות האלה.
תיקוני באגים
- תוקנה בעיה באנימציה של שכבת-על שבה שכבות-על מוטמעות כמו
ModalBottomSheetמונפשות מחדש באופן בלתי צפוי כשהשכבות שמעליהן מוקפצות. (Ia2b9e, b/502624496)
גרסה 1.2.0-alpha03
19 במאי 2026
androidx.navigation3:navigation3-*:1.2.0-alpha03 מופץ. גרסה 1.2.0-alpha03 מכילה את השמירות האלה.
תכונות חדשות
בניווט 3 יש עכשיו תמיכה בקישורי עומק עם DeepLinkRequest ו-DeepLinkMatcher:
DeepLinkRequestקישור עמוק שכוללDeepLinkUriו-mimeType או פעולה אופציונליים(ב-Android בלבד). בנוסף למחלקה החדשה, יש פונקציות נלוות ליצירת מופע עםuri, mimeTypeאוaction. בפלטפורמת Android יש גם כלי עזר ליצירת בקשה מ-Intent. (Iaaac9, b/470282247)val uriOnlyRequest = DeepLinkRequest.fromUriString("https://sampledeeplink.com/home") val uriAndMimeRequest = DeepLinkRequest.fromUriString( "https://sampledeeplink.com/user/profile?id=123", "image/png" )
DeepLinkMatcherמייצג קישור עומק שאפשר להתאים ל-DeepLinkRequest. כל מופע של התאמה משויך למקש הניווט שתומך בקישור העומק הזה. אפשר לשייך מקש ניווט לכמה התאמות. התקשרות אלDeepLinkMatcher.matchתחזירMatchResultשמכיל את מקש הניווט המשויך אם ההתאמה תצליח. יש שתי הטמעות ברירת מחדל שלDeepLinkMatcher: UriDeepLinkMatcherלהתאמת קישורי עומק על סמך URI, ו-StaticKeyDeepLinkMatcherלהתאמת קישורי עומק רק עםDeepLinkMatcher.Filterשתואמים לBoolean. (I3798e, b/470282247)
UriDeepLinkMatcherהטמעה מבוססת-הנחות שלDeepLinkMatcherשמטפלת בקישור עומק על ידי התאמה שלDeepLinkUriלמפתח ניווט ניתן לסריאליזציה. הוא תומך בארגומנטים של קישורי עומק מסוגים פרימיטיביים או באוסף של פרימיטיבים כמו רשימות, מערכים וקבוצות. (I1520b, b/470282247)@Serializable data class UserKey(val id: Int): NavKey // declare a deep link supported by UserKey val userMatcher = UriDeepLinkMatcher( uriPattern = "www.sampledeeplink.com/user?userId={id}", serializer = serializer<UserKey>() ) // handle a requested deep link with fallback key val key = userMatcher.match(deepLinkRequest)?.key ?: HomeKeyנוסף
DeepLinkUriשהיא גרסת kotlin-multiplatform שלandroid.net.Uri(Id4725, b/470282247)
שינויים ב-API
- הועלה לגרסה
compileSdk 37כדי להתאים ל-compileSdk של Compose
תיקוני באגים
- תוקנה הבעיה
AnimatedBottomSheetSample'sIllegalArgumentExceptionכשמוצגות כמה שכבות-על. הדוגמהSceneStrategyתחשב עכשיו בצורה נכונה את ה-OverlaySceneהאחרון ותציג אותו מתחת לכל הסצנות של שכבות העל. (If2281, b/506733412) - הועלתה התלות ב-
NavigationEventלגרסה 1.1.1, שמסירה את NavigationEventHandler שאין לו פעולה (no-op) כשנמצאים במצב בדיקה, כדי להפעיל את התכונה 'חזרה עם אנימציה' בתצוגות המקדימות של Android Studio. (I487fd)
גרסה 1.2.0-alpha02
22 באפריל 2026
androidx.navigation3:navigation3-*:1.2.0-alpha02 מופץ. גרסה 1.2.0-alpha02 מכילה את השמירות האלה.
שינויים ב-API
- משנים את השם של
onBackל-onBackCompletedומוסיפים אתonBackCancelledל-NavigationBackHandler כדי לתמוך בטיפול במחוות חזרה שבוטלו. (I92741) - הוספת
NavigationBackHandlerכדי לפשט את הטיפול במחוות חזרה ובחיזוי חזרה כשמשתמשים ב-SceneState. כך המפתחים יכולים ליצור בקלות רבה יותר רכיבי ממשק משתמש מותאמים אישית שתומכים בניווט לאחור רגיל ובמחוות ניווט אחורה חזויות, בלי לחשב ידנית את הדלתאות של מקבץ הפעילויות הקודמות (back stack). (I6a055) - מוסיפים
rememberNavigationEventStateכדי לפשט את החיבורSceneStateבאמצעות טיפול חיזוי בחזרה. (Iae49c)
תכונות חדשות
- הוספנו
ResultEventBusAPI כדי לאפשר העברת תוצאות בין NavEntry באמצעותLocalResultEventBusשסופק על ידיResultEventBusNavEntryDecoratorהחדש. אפשר להעריך את התוצאות שעברו כסטטוס עםResultEventBus#conflateAsStateאו כרצף של תוצאות עםResultEffect.
גרסה 1.2.0-alpha01
8 באפריל 2026
androidx.navigation3:navigation3-*:1.2.0-alpha01 מופץ. גרסה 1.2.0-alpha01 מכילה את השמירות האלה.
תיקוני באגים
- הגישה אל
LocalNavAnimatedContentScopeמ-OverlaySceneלא תגרום יותר ל-IllegalStateExceptionכיOverlayScenesמקבלים עכשיוLocalAnimatedContentScopeמסוג no-op. (I2f00c, b/486067688)
Navigation3 גרסה 1.1
גרסה 1.1.3
17 ביוני 2026
androidx.navigation3:navigation3-*:1.1.3 מופץ. גרסה 1.1.3 מכילה את השמירות האלה.
תיקוני באגים
תוקנה בעיה באנימציה של שכבת-על שבה שכבות-על מוטמעות כמו
ModalBottomSheetמונפשות מחדש באופן בלתי צפוי כשהשכבות שמעליהן מוקפצות. (Ia2b9e, b/502624496)הועלתה התלות ב-
NavigationEventלגרסה 1.1.2, שבה הוסר ה-no-opNavigationEventHandlerכשנמצאים במצב בדיקה, כדי להפעיל את התכונה 'חזרה עם אנימציה' בגרסאות טרום-השקה של Android Studio.
גרסה 1.1.2
19 במאי 2026
androidx.navigation3:navigation3-*:1.1.2 מופץ. גרסה 1.1.2 מכילה את השמירות האלה.
תיקוני באגים
- הועלתה התלות ב-
NavigationEventלגרסה 1.1.1, שבה הוסר ה-no-opNavigationEventHandlerכשנמצאים במצב בדיקה, כדי להפעיל את התכונה 'חזרה עם אנימציה' בתצוגות המקדימות של Android Studio.
גרסה 1.1.1
22 באפריל 2026
androidx.navigation3:navigation3-*:1.1.1 מופץ. גרסה 1.1.1 מכילה את השמירות האלה.
תיקוני באגים
- הגישה אל
LocalNavAnimatedContentScopeמ-OverlaySceneלא תגרום יותר ל-IllegalStateExceptionכיOverlayScenesמקבלים עכשיוLocalAnimatedContentScopeמסוג no-op. (I2f00c, b/486067688)
גרסה 1.1.0
8 באפריל 2026
androidx.navigation3:navigation3-*:1.1.0 מופץ. גרסה 1.1.0 מכילה את השמירות האלה.
גרסה 1.1.0 יציבה עכשיו!
שינויים חשובים מאז גרסה 1.0.0
אלמנטים משותפים בין סצנות
- רכיב Navigation3 תומך עכשיו בהתייחסות לסצנות כאובייקט של אלמנט משותף. המשמעות היא שכאשר הסצנות משתנות, אפשר לוודא שהמעבר ביניהן יהיה חלק. כדי להפעיל את ההגדרה הזו, מעבירים SharedTransitionScope ל-NavDisplay או ל-rememberSceneState.
SceneDecoratorStrategy
- הוספנו את SceneDecoratorStrategy כדי לתמוך בתרחישי שימוש כמו הוספת רכיבי ממשק משתמש נפוצים לסצנות או שיתוף מצב בין סצנות.
NavMetadata DSL
- בספרייה Navigation3 יש עכשיו DSL חדש של מטא-נתונים עם בטיחות סוגים. ה-DSL משתמש בממשק MetadataKey חדש שמאפשר להגדיר את סוגי המפתח והערך שרוצים לספק למפת המטא-נתונים. בנוסף, נוספו NavMetadataKeys חדשים למעברים של NavDisplay, כדי שאפשר יהיה להשתמש בהם עם ה-DSL החדש של המטא נתונים ולהוסיף מעברים ל-NavDisplay.
OverlayScene Animations
- לממשק OverlayScene יש עכשיו קריאה חוזרת (callback) חדשה להשהיה onRemoved. הקריאה החוזרת הזו מופעלת אחרי שמפתח שמשויך לסצנה מוסר מהמחסנית האחורית, אבל לפני שהוא יוצא מהקומפוזיציה. כך אנימציות היציאה שנקראות בתוך onRemovedיושלמו לפני שהסצנה של שכבת העל תוסר מהקומפוזיציה.
שינויים אחרים
- התגים NavDisplay ו-rememberSceneState מקבלים עכשיו List<SceneStrategy> במקום הפרמטר הקודם SceneStrategy שהיה משורשר באמצעות התו then.
– עכשיו אפשר להוסיף מטא-נתונים באופן דינמי תוך התחשבות במפתח הרשומה באמצעות EntryProvider DSL.
גרסה 1.1.0-rc01
25 במרץ 2026
androidx.navigation3:navigation3-*:1.1.0-rc01 מופץ. גרסה 1.1.0-rc01 מכילה את השמירות האלה.
תיקוני באגים
NavDisplayמוודא עכשיו שהערכים שמוצגים מתחת לשכבות-על מוגבלים ל-STARTED.Lifecycleכך תוכלו לוודא ש-API כמוdropUnlessResumedימשיך לפעול כשמשתמשים בתיבות דו-שיח. (If209f, b/483966071)- תוקנה בעיה ב-
NavDisplayשבה ניווט הלוך ושוב בין אותם מסכים והפרעה לאנימציות בין שני המסכים עלולים לגרום לסדר השכבות של המסכים להיות שגוי. (I4d491, b/459419800)
גרסה 1.1.0-beta01
11 במרץ 2026
androidx.navigation3:navigation3-*:1.1.0-beta01 מופץ. גרסה 1.1.0-beta01 מכילה את השמירות האלה.
גרסה 1.1.0-alpha05
25 בפברואר 2026
androidx.navigation3:navigation3-*:1.1.0-alpha05 מופץ. גרסה 1.1.0-alpha05 מכילה את השמירות האלה.
שינויים ב-API
- ב-
NavDisplayוב-rememberSceneStateיש עכשיוList<SceneStrategy>במקום הפרמטר הקודםSceneStrategyהיחיד ששורשר באמצעות התחיליתthen. השינוי הזה תואם יותר ל-List<SceneDecoratorStrategy<T>>ששני ממשקי ה-API האלה כבר מקבלים. הוצאנו משימוש את ממשקי ה-API הקודמים. (I78b2c, b/482108465) - נוסף אופרטור metadata #contains כדי לבדוק אם מפת המטא-נתונים מכילה את
NavMetadataKeyשצוין. (Ic30db, b/485311895) - נוספה האפשרות
NavMetadataKeyDialogKeyל-DialogSceneStrategyלשימוש עם Metadata DSL. (Ic7a26, b/483388817)
גרסה 1.1.0-alpha04
11 בפברואר 2026
androidx.navigation3:navigation3-*:1.1.0-alpha04 מופץ. גרסה 1.1.0-alpha04 מכילה את השמירות האלה.
תכונות חדשות
- Navigation3 מספקת עכשיו DSL חדש של מטא-נתונים שמאובטח מפני שגיאות הקלדה. ה-DSL משתמש בממשק
MetadataKeyחדש שמאפשר להגדיר את סוגי המפתח והערך שרוצים לספק למפת המטא-נתונים. בנוסף, נוספוNavMetadataKeyחדשים למעברים שלNavDisplay, כדי שאפשר יהיה להשתמש בהם עםmetadataDSL החדש כדי להוסיף מעברים ל-NavDisplay. (Ic10ef, Ic049c,b/476213928)
שינויים ב-API
- בממשק של
OverlaySceneיש עכשיוonRemovedcallback חדש להשעיה. הקריאה החוזרת הזו מופעלת אחרי שמפתח שמשויך לסצנה מוסר מהמחסנית האחורית, אבל לפני שהוא יוצא מהקומפוזיציה. כך אנימציות היציאה שנקראות בתוךonRemovedיושלמו לפני שהסצנה של שכבת העל תוסר מהקומפוזיציה. (I29a72, b/440558061) -
SceneStrategyפיצלה את פונקציית העיצוב לפונקציה חדשהSceneDecoratorStrategy. הממשק החדש הזה הוא הממשק שבו צריך להשתמש כדי לקשט סצנות. יש ממשקי API חדשים ל-NavDisplayול-rememberSceneStateשמאפשרים להוסיףSceneDecoratorStrategies. (If9385, b/477669607, b/477670333)
תיקוני באגים
- תוקנה שגיאה שבה העברה של
SharedTransitionLayoutאלNavDisplayאו אלrememberSceneStateושימוש ב-OverlaySceneכלשהו גרמו לקריסה, כי השימוש ב-SharedTransitionLayoutפועל רק עםNavEntriesשמוצגים כחלק מ-AnimatedContent, ו-OverlaySceneמוצגים בחלונות נפרדים משלהם. (I1bb76, b/478664101)
עדכון תלות
- מגרסה
Navigation31.0.1:Navigation3תלויה עכשיו בגרסהNavigationEvent1.0.2. העדכון הזה פותר בעיהIllegalStateExceptionשנגרמה כתוצאה משימוש ב-NavDisplayבמהלך תצוגות מקדימות שלAndroidStudio. (Id7212, b/477149762)
גרסה 1.1.0-alpha03
28 בינואר 2026
androidx.navigation3:navigation3-*:1.1.0-alpha03 מופץ. גרסה 1.1.0-alpha03 מכילה את השמירות האלה.
תכונות חדשות
- עכשיו אפשר להוסיף מטא-נתונים באופן דינמי באמצעות
EntryProviderDSL, תוך התחשבות במפתח הרשומה. (I942fb, b/474416976)
גרסה 1.1.0-alpha02
14 בינואר 2026
androidx.navigation3:navigation3-*:1.1.0-alpha02 מופץ. גרסה 1.1.0-alpha02 מכילה את השמירות האלה.
תכונות חדשות
-
SceneStrategyתומך עכשיו בהטמעה של סצנות באמצעות הפונקציה החדשהcalculatedScene(Scene). כלומר, אפשר להתאים אישית אתSceneStrategyכדי לספק פונקציונליות נוספת לסצנות אחרות. (I5df7c,b/440333896)
גרסה 1.1.0-alpha01
3 בדצמבר 2025
androidx.navigation3:navigation3-*:1.1.0-alpha01 מופץ. גרסה 1.1.0-alpha01 מכילה את השמירות האלה.
שינויים ב-API
- ב-
Navigation3יש עכשיו תמיכה בהתייחסות לסצנות כאובייקט של רכיב משותף. המשמעות היא שכאשר הסצנות משתנות, אפשר לוודא שהמעבר ביניהן יהיה חלק. כדי להפעיל את ההגדרה הזו, מעביריםSharedTransitionScopeל-NavDisplayאו ל-rememberSceneState. (I15868)
גירסה 1.0
גרסה 1.0.1
11 בפברואר 2026
androidx.navigation3:navigation3-*:1.0.1 מופץ. גרסה 1.0.1 מכילה את השמירות האלה.
עדכון תלות
-
Navigation3תלוי עכשיו ב-NavigationEvent1.0.2. העדכון הזה פותר בעיהIllegalStateExceptionשנגרמה כתוצאה משימוש ב-NavDisplayבמהלך תצוגות מקדימות שלAndroidStudio. (Id7212, b/477149762)
גרסה 1.0.0
19 בנובמבר 2025
androidx.navigation3:navigation3-*:1.0.0 מופץ. גרסה 1.0.0 מכילה את השמירות האלה.
חדש: Navigation3!
- הספרייה Navigation3 יציבה עכשיו. Navigation3 היא גישת AndroidX Compose first לניווט.
- מידע נוסף זמין בפוסט שלנו בבלוג. אפשר גם לעיין במשאבים ולנסות את המתכונים.
גרסה 1.0.0-rc01
5 בנובמבר 2025
androidx.navigation3:navigation3-*:1.0.0-rc01 מופץ. גרסה 1.0.0-rc01 מכילה את השמירות האלה.
תיקוני באגים
-
NavDisplayמגדיר עכשיוLocalLifecycleOwnerברמהSceneשמאפשרת לכותבי סצנות לקבוע אם כל המעברים הסתיימו על ידי בדיקה שהערך שלLifecycle.StateהואRESUMED. ההתנהגות שלLocalLifecycleOwnerברמהNavEntryלא משתנה: היא גם נשארת מוגבלת ל-STARTEDאם מתבצע מעבר, ומוגבלת בנוסף ל-CREATEDאםNavEntryהוצא מהמחסנית האחורית והוא בתהליך של אנימציה. (I03113, b/454045829)
גרסה 1.0.0-beta01
22 באוקטובר 2025
androidx.navigation3:navigation3-*:1.0.0-beta01 מופץ. גרסה 1.0.0-beta01 מכילה את השמירות האלה.
שינויים ב-API
-
SceneStrategyScopeכולל עכשיו רק בנאי ציבורי ללא ארגומנטים, שמתאים לבדיקה שלSceneStrategyושלSceneשמוחזר בבידוד. לתרחישי שימוש מורכבים יותר, מומלץ להשתמש ב-rememberSceneState(). (I8440c, b/451679047)
תיקוני באגים
- תוקנה לולאה אינסופית כשמשלבים
SceneStrategyעםthen. (Iba3f0, b/450323470) - תוקן מצב של הבהוב המסך כשמחליפים את
backStackשעבר אלNavDisplayומשתמשים באנימציות. (Ief7b5, b/450967248)
גרסה 1.0.0-alpha11
8 באוקטובר 2025
androidx.navigation3:navigation3-*:1.0.0-alpha11 מופץ. גרסה 1.0.0-alpha11 מכילה את השמירות האלה.
שינויים ב-API
- השיטה
calculateSceneב-SceneStrategyכבר לא@Composable. במקום זאת, כדאי להעביר את העבודה הזו לבנייה של שיטתSceneStrategy(כלומר, בשיטתrememberMySceneStrategy()) שמאפשרת לכם להגדיר באופן מלא את משך החיים של ערכיrememberSaveableאו של הצהרות מפתחrememberעל סמך הערכים הנכונים. (If1733, b/448709506) - הפרמטר
onBackשלSceneStrategy.calculateSceneהועבר להיקף החדש של מקבל הנתוניםSceneStrategyScopeכדי להבהיר שמדובר בפרמטר אופציונלי, וכדי לספק נקודת הרחבה לתכונות עתידיות של Navigation3. (I3aea3, b/448460407) - פונקציית ה-lambda
onBackשמועברת אלNavDisplayואלSceneStrategyלא מספקת יותר פרמטרcount: Intכדי לציין מתי צריך להסיר כמה רשומות. במקום זאת, קריאה ל-lambda() -> Unitתתבצע כמה פעמים ברצף במקרה הנדיר שבו בקשות ה-Scene שלכם יציגו כמה רשומות. (Idedb5, b/446989346) - תסיר את המחלקה
NavEntryWrapperותחליף את הפונקציונליות שלה במחלקה סופיתNavEntryעם בנאי משני חדש שמקבלNavEntryעם תוכן חדש. כך תהיה תמיכה בהוספת תוכן חדש לערך. (I7da2a, b/444447130) - הפונקציה
navEntryDecoratorשיוצרת ומחזירהNavEntryDecoratorהוסרה והוחלפה במחלקהNavEntryDecorator, שעכשיו היא ציבורית ופתוחה ליצירת מחלקות משנה. (If81f8, b/444447434, b/447381176) - השם של
SavedStateNavEntryDecoratorשונה ל-SaveableStateHolderNavEntryDecoratorכי הוא מוסיףSaveableStateHolderלרשומות. בנוסף, בוצע רפקטורינג של ה-decorator מפונקציה למחלקה, כי מבחינה פונקציונלית הוא מפעל שלNavEntryDecorator. (Ie6013, b/447381176) - כבר לא צריך להשתמש ב-
LocalEntriesToRenderInCurrentScenecomposition local כדי להציג תצוגות מותאמות אישית באמצעותSceneStateכחלופה לשימוש ב-NavDisplay. התכונה הזו היא עכשיו פנימית. (Ic40ef, b/414668196) - הסרנו את
SceneSetupNavEntryDecoratorואתrememberSceneSetupNavEntryDecorator()מ-API שגלוי לכולם. הפונקציונליות הזו כלולה עכשיו כברירת מחדל, ולא צריך להוסיף אותה באופן ידני. (Ieae42, b/444479133) - הפונקציות
NavEntry,DialogScene,SinglePaneSceneוגםSceneStateכוללות עכשיו את הפונקציה equals. (I96121) - בממשק של הסצנה יש שדה חדש של מטא-נתונים לצירוף מטא-נתונים ספציפיים לסצנה עבור NavDisplay. כך אפשר להגדיר שסצנה מסוימת תבטל את המטא-נתונים של
NavDisplay, למשל באמצעות מעברים. (I1fd96, b/443955625) - כדי לפשט את החתימה של
rememberNavBackStack, צריך להסיר את פרמטר הסוג הכללי המיותר. הפונקציה מקבלת עכשיו את הערךvararg elements: NavKey. (I03e45) - אנימציות ברירת המחדל של
NavDisplayהן עכשיו חלק מה-API המשותף, כך שאפשר לקרוא להן מכל הפלטפורמות. (I71af9, b/447147159) - משנים את השם של
EntryProviderBuilderל-EntryProviderScopeכדי לשקף בצורה מדויקת שהכיתה היא Kotlin DSL שמספקת היקף לבנייתNavEntries. (Ia7465)
תיקוני באגים
rememberNavBackStack()אוכף עכשיו סריאליזציה פולימורפית עבור NavKey ודורשSavedStateConfigurationמותאם אישית שמוגדר כדי להבטיח שחזור נכון של המצב. עדכנו את KDoc כדי לשקף את הדרישה שכל סוגי המשנה של NavKey צריכים להיות רשומים ב-SerializersModule שסופק. (I6de37,I782f2, b/446664383)
גרסה 1.0.0-alpha10
24 בספטמבר 2025
androidx.navigation3:navigation3-*:1.0.0-alpha10 מופץ. גרסה 1.0.0-alpha10 מכילה את השמירות האלה.
שינויים ב-API
- הוספת עומס יתר חדש של
NavDisplayשמקבל רשימה שלNavEntry<T>שעברה קישוט על ידיrememberDecoratedNavEntries. (I4025b, b/441940314) - העברנו את
DialogSceneלחבילה חדשה. (Ia5840) - הסרת ה-API הציבורי
DecorateNavEntry. במקום זאת, משתמשים ב-rememberDecoratedNavEntriesכדי להקיף את NavEntry ברשימה של רכיבי Decorator. (Id8c09) - בממשק המשתמש של Navigation3 יש עכשיו מאפייני ברירת מחדל חדשים של
transitionSpec. (Ibcabd) - הוספנו אובייקט
SceneStateחדש שיעזור לכם לנהל סצנות. הפעולה הזו מספקת גם עומס יתר חדש שלNavDisplayשמקבל אתSceneStateואתNavigationEventState. (Idfb46, b/444479133) NavDisplayמאפשרת עכשיו להתאים אישית את המעברים על סמך המיקוםSceneשממנו יוצאים והמיקום שאליו נכנסים, על ידי עיון בTransitioncurrentStateובtargetState. (I906cc, b/443872322)- התפקיד של
NavigationEventInfoהוא עכשיוabstract classבמקוםinterface. מעדכנים את כל ההטמעות בהתאמה אישית כך שיורשות מהמחלקה (לדוגמה,data class MyInfo : NavigationEventInfo()). (I1e59c, b/444734264) - ממשקי ה-API של
navigationevent-composehandler עודכנו. הפונקציותNavigationEventHandlerו-NavigationBackHandler(והווריאציות שלהן) תומכות עכשיו בעומס יתר חדש שמקבלNavigationEventStates שהועברו למעלה. העומסים הפשוטים (שמקבליםcurrentInfo) נשמרים ועכשיו משתמשים במודל המצב החדש הזה באופן פנימי. (Ic3251, b/444734264) - כל ממשקי ה-API של Scene הועברו מ-navigation3-ui אל navigation3-runtime. כלומר, הם זמינים עכשיו בכל הפלטפורמות שנתמכות על ידי navigation3-runtime. (I431d0, b/444449993)
- נוספה
rememberDecoratedNavEntriesחדשה של overload שמקבלת רשימה שלNavEntryלעיצוב. אפשר להוסיף לערכי הקלט קישוטי ערכים אחרים. (I5a034, b/444230270) - הסרת פרמטרים של סוג wildcard של navigation3 (I02540)
- שיפרנו את הטיפול בגנריות ב-
entryProviderDSL. אם בעבר ייבאתם אתandroidx.navigation3.runtime.entry, אין יותר צורך בכך. (I299fc) - הגבלת העומס העודף של
NavBackStackSerializerשמבוסס על השתקפות ל-Android. ההגדרה הזו מונעת כשלים מרומזים בסריאליזציה בזמן ריצה בפלטפורמות שאינן Android, על ידי אכיפת השימוש בעומס היתר המפורשSavedStateConfigurationבקוד מרובה פלטפורמות. (I73313, b/420443609) - תכין את
NavigationEvent'sswipeEdgeבתור@IntDef(Icee54, b/443950342) - הגבלת סריאליזציה
NavBackStackל-Android. כך נמנעים כשלים בזמן ריצה בפלטפורמות שאינן Android. כדי לשמור את המצב בכמה פלטפורמות, משתמשים ב-rememberNavBackStackoverload עםSavedStateConfigurationמפורש. (I1e418, b/420443609)
תיקוני באגים
- תוקנה קריסה במהלך ניווט חזוי אחורה כש-
NavDisplayמקונן מכיל רשומה אחת של צאצא. (I2cdc0, b/441933162)
גרסה 1.0.0-alpha09
10 בספטמבר 2025
androidx.navigation3:navigation3-*:1.0.0-alpha09 מופץ. גרסה 1.0.0-alpha09 מכילה את השמירות האלה.
שינויים ב-API
- הפונקציה
DecoratedNavEntryProviderהוחלפה בפונקציהrememberDecoratedNavEntriesשיוצרת ומחזירה NavEntry עם קישוטים של רשימת הקישוטים שסופקו (I0fe1c, b/441328236) - הפונקציה
NavBackStackהיא עכשיו גנרית לגבי הסוגNavKey. כך אפליקציות וספריות יכולות להגדיר סוגים מותאמים אישית של מקשים עבור ערימות החזרה שלהן, במקום להיות מוגבלות ל-NavKey. (I4d190,Iad2f4, b/420443609) -
NavBackStackהוא עכשיו@kotlinx.serialization.Serializable, ולכן אפשר לשמור ולשחזר את מצב הניווט אחרי סיום התהליך ושינויים בהגדרות בלי להשתמש בקוד boilerplate נוסף. (I2c3cf, b/420443609) - העברנו את
RememberNavBackStackאלcommonMainכדי לוודא שהוא מסופק בכל פלטפורמות היעד. (Id69e7, b/420443609)
תיקוני באגים
-
NavDisplayעכשיו כלNavEntryמועבר בצורה נכונה לLifecycle.Stateהנכון. (I30aac, b/440145700) - תוקנה בעיה שבה
NavDisplayהתעלם מכלNavigationEventDispatcherOwnerשמוגדר באמצעותLocalNavigationEventDispatcherOwnerשל ספרייתNavigationEvent. (I6224a)
שינויים בתלות
- Navigation3 תלוי עכשיו ב-NavigationEvent Alpha08.
גרסה 1.0.0-alpha08
27 באוגוסט 2025
androidx.navigation3:navigation3-*:1.0.0-alpha08 מופץ. גרסה 1.0.0-alpha08 מכילה את השמירות האלה.
תכונות חדשות
- נוספו יעדים חדשים של Kotlin MultiPlatform (KMP) לארטיפקטים של
Navigation3 Runtime. Navigation3 Runtimeתומך עכשיו בפלטפורמות הבאות: JVM (Android ומחשב), Native (Linux, iOS, watchOS, macOS, MinGW) ו-Web (JavaScript, WasmJS). (I55078, b/424410398, b/419294028, b/419046226). הערה: הפקודה הזו לא מספקת יעדי KMP עבור ארטיפקטNavigation3 UI. בפלטפורמות אחרות, תצטרכו להטמיעNavDisplayמשלכם בהתאמה אישית. אם אתם רוצים שהתמיכה תתווסף, אתם יכולים להצביע על הבעיה ב-Jetbrains כאן ולעקוב אחרי ההתקדמות כדי לקבל תמיכה נוספת. - האובייקט
NavDisplayInfoעכשיו ציבורי ואפשר להשתמש בו כדי לאחזר את רשימת הרשומות שגלויות מתוךNavDisplay. (Ibc91f)
שינויים ב-API
- נוסף
NavBackStackSerializerחדש לשימוש בשילוב עםrememberNavBackStackכדי לבצע שחזור של מצב. התגrememberNavBackStack()מקבל עכשיו גם את הערךSavedStateConfigurationשאפשר להשתמש בו כדי לספק הגדרה משלכם. (I2f4d2, I4cd58, b/420443609)
תיקוני באגים
- תוקנה בעיה שבה ניווט גרם להפעלת אירועים שגויים של מחזור החיים. (I8bf6d, b/425901162, b/434109022)
בעיות מוכרות
- באג שנוצר על ידי I8bf6d גרם לכך שמחזורי החיים התבססו על סצנות במקום על רשומות נפרדות. כתוצאה מכך, מחזור החיים לא פעל בכל המקרים שבהם הערך
keyשסופק ל-NavEntryלא היהString, או ש-NavEntryלא ביטל אתcontentKeyוהגדיר אותו כשוויון ל-key(שימו לב שפעולה כזו מחייבת שהמפתח יישמר ב-Bundle). הבאג הזה תוקן בגרסה הבאה. (b/440145700)
גרסה 1.0.0-alpha07
13 באוגוסט 2025
androidx.navigation3:navigation3-*:1.0.0-alpha07 מופץ. גרסה 1.0.0-alpha07 מכילה את השמירות האלה.
עדכון MinSdk
- הערך שמוגדר כברירת מחדל ל-minSdk ב-AndroidX הועבר מ-API 21 ל-API 23 (Ibdfca, b/380448311, b/435705964, b/435705223)
שינויים ב-API
-
SavedStateNavEntryDecoratorמשתמש עכשיו ב-SaveableStateRegistryשמוטמע ב-SaveableStateProviderכדי לשמור ולשחזר מצבים. (If8d9a) - הפרמטר
predictivePopTransitionSpecמועבר עכשיו כפרמטר של החלקה מהקצה, וכך אפשר להתאים אישית את המעבר בהתאם לקצה שממנו המשתמש התחיל את תנועת החיזוי של החזרה. (I753a8)
תיקוני באגים
- תוקנה בעיה שגרמה לחישוב אינסופי של סצנות בהתאמה אישית, כי המערכת לא זכרה את הסצנה האחרונה. (I7ba84, b/418153031)
עדכון תלות
- Navigation3 מסתמך עכשיו על אירוע הניווט
1.0.0-alpha06.
גרסה 1.0.0-alpha06
30 ביולי 2025
androidx.navigation3:navigation3-*:1.0.0-alpha06 מופץ. גרסה 1.0.0-alpha06 מכילה את השמירות האלה.
עדכון תלות
- Navigation3 מסתמך עכשיו על אירוע הניווט
1.0.0-alpha05.
גרסה 1.0.0-alpha05
2 ביולי 2025
androidx.navigation3:navigation3-*:1.0.0-alpha05 מופץ. גרסה 1.0.0-alpha05 מכילה את השמירות האלה.
שינויים בהתנהגות
- הסטטוס של
NavEntryמבוסס עכשיו באופן בלעדי על הרשימה הנוכחית של פונקציות העיטור שמועברות אלNavDisplay. המשמעות היא שאם יש כמה מחסניות של היסטוריית ניווט, צריך להחליף את ה-decorators לאורך מחסניות היסטוריית הניווט כדי לשמור על המצב של NavEntry במחסנית היסטוריית הניווט. אחרת, המצבים ינוקו כאילו הרשומות הוצאו מהמחסנית (במקום החלפה). (I7a759, b/428033667)
גרסה 1.0.0-alpha04
18 ביוני 2025
androidx.navigation3:navigation3-*:1.0.0-alpha04 מופץ. גרסה 1.0.0-alpha04 מכילה את השמירות האלה.
שינויים ב-API
- הסרטון
NavEntry.contentמוגדר עכשיו כפרטי. כדי להפעיל תוכןNavEntry, צריך לקרוא ל-API החדשNavEntry.Content(), שכבר לא דורש פרמטרkeyלהפעלה. (Icd0fd, b/420991203) - השדה
NavEntry.keyהוא עכשיו שדה פרטי. השדה החדשcontentKey, שנוצר מ-lambda חדשהcontentKeyFactory, צריך לזהות אתNavEntryואת המצבים הרלוונטיים שלו. ערך ברירת המחדל של השדה הוא גיבוב שניתן לשמירה שנוצר מ-NavEntry.key(I81a6c, b/422001357, b/420991203 I2d7d4, b/420991203, b/422841812)
שינויים בתלות
- Navigation3 תלוי עכשיו בארטיפקט
androidx.navigationevent.composeהחדש.
גרסה 1.0.0-alpha03
4 ביוני 2025
androidx.navigation3:navigation3-*:1.0.0-alpha03 מופץ. גרסה 1.0.0-alpha03 מכילה את השמירות האלה.
תיקוני באגים
-
Navigation3כבר לא ינקה את מצבי ה-decorator שלbackStacksשהוחלפו והוחלפו במופע אחר שלbackStack. (I28a42, b/415076044)
גרסה 1.0.0-alpha02
23 במאי 2025
androidx.navigation3:navigation3-*:1.0.0-alpha02 מופץ. גרסה 1.0.0-alpha02 מכילה את השמירות האלה.
תיקוני באגים
- נפתרה בעיה ב-
SavedStateNavEntryDecoratorשגרמה להתנגשויות בין סוגים שונים של נתונים עם אותם ערכי מאפיינים. (b/418070648, Iff4775) - תוקנה בעיה של מחלקה חסרה שגרמה לקריסות כשמריצים בלי להצהיר על תלות מפורשת. (b/419049149, I4b4ed)
גרסה 1.0.0-alpha01
20 במאי 2025
androidx.navigation3:navigation3-*:1.0.0-alpha01 מופץ. גרסה 1.0.0-alpha01 מכילה את השמירות האלה.
תכונות חדשות
Navigation3 היא ספריית ניווט חדשה שנוצרה במיוחד כדי לטפל בניווט בתוך האפליקציה ב-Jetpack Compose. ארטיפקט androidx.navigation3.runtime מספק את אבני הבניין, וארטיפקט androidx.navigation3.ui מספק את שכבת ממשק המשתמש באמצעות NavDisplay API. מפתחים יכולים לספק את המצב שלהם ישירות לפונקציה הניתנת להרכבה NavDisplay, שמשנה את התוכן בהתאם לשינויים במצב המפתח.
@Serialiable object Home : NavKey
@Serialiable object Chat : NavKey
val backStack = rememberNavBackStack(Home)
NavDisplay(backStack, entryProvider = entryProvider {
entry<Home> {
Column {
Text(“Home”)
Button(onClick = { backStack.add(Chat) } ) {
Text(“Go to Chat”)
}
}
}
entry<Chat> { /* My Composable Content */ }
})
מידע נוסף זמין במדריך Navigation3.