navigationevent
| העדכון האחרון | גרסה יציבה | גרסה מועמדת להפצה | גרסת בטא | גרסת אלפא |
|---|---|---|---|---|
| 10 בספטמבר 2025 | - | - | - | 1.0.0-alpha08 |
הצהרה על יחסי תלות
כדי להוסיף תלות ב-navigationevent, צריך להוסיף את מאגר Google Maven לפרויקט. מידע נוסף זמין במאמר בנושא מאגר Maven של Google.
מוסיפים את יחסי התלות של הארטיפקטים שאתם צריכים בקובץ build.gradle של האפליקציה או המודול:
גרוב
dependencies { implementation "androidx.navigationevent:navigationevent:1.0.0-alpha08" }
Kotlin
dependencies { implementation("androidx.navigationevent:navigationevent:1.0.0-alpha08") }
מידע נוסף על יחסי תלות זמין במאמר הוספת יחסי תלות של בנייה.
משוב
המשוב שלכם עוזר לנו לשפר את Jetpack. נשמח לשמוע מכם אם תגלו בעיות חדשות או אם יש לכם רעיונות לשיפור הספרייה הזו. לפני שיוצרים ספרייה חדשה, כדאי לעיין בבעיות הקיימות בספרייה הזו. כדי להוסיף את ההצבעה שלכם לבעיה קיימת, לוחצים על לחצן הכוכב.
מידע נוסף זמין במאמרי העזרה בנושא כלי המעקב אחר בעיות.
אין הערות לגבי הגרסה של הארטיפקט הזה.
גירסה 1.0
גרסה 1.0.0-alpha08
10 בספטמבר 2025
androidx.navigationevent:navigationevent-*:1.0.0-alpha08 משוחרר. גרסה 1.0.0-alpha08 מכילה את הקומטים האלה.
תכונות חדשות
- הוספנו API מבוסס-lambda
NavigationEventHandlerשמחליף את ה-handler מבוסס-הזרימה. אפשר לטפל בתנועות החלקה קדימה ואחורה באמצעות קריאות חוזרות פשוטות במקום לאסוף נתונים, וכך לצמצם את כמות הקוד הסטנדרטי ולמנוע בעיות שקשורות לביטולים. הוספנו אתNavigationBackHandlerו-NavigationForwardHandlerכממשקי API נוחים וממוקדים. מסירים אתNavigationEventHandlerמבוסס-הזרימה ועוברים לשיטות הקריאה החוזרות החדשות. (I23bac, b/436248277) - מאפשרת למאזינים פסיביים לגשת לכל היסטוריית הניווט באמצעות מידע משולב על חזרה. מאפשרת לממשקי משתמש לעבד תצוגות מקדימות והיסטוריית ניווט מוטמעת במקום להיות מוגבלים לקריאה החוזרת העליונה ביותר. (I7a510, b/436248277)
- הוספת מודל ברור של חזרה, נוכחי וקדימה כדי להבהיר את מצב הניווט ולתמוך בניווט קדימה באמצעות רכיבי handler מוטמעים. (Ib86da, b/420443609)
- הוספת שיטות
onForward*וisForwardEnabledל-NavigationEventCallback. (Ic100f, b/436248290) - הוספת תמיכה בניווט קדימה אל
NavigationEventInput. (I5734b)
שינויים ב-API
- הפעלת בדיקה של אירועי ניווט קדימה באמצעות
TestNavigationEventCallback. משתמשים ב-isForwardEnabledוב-onForward*. (I21fb5, b/420443609) - שינוי השם של
onEvent*ל-onBack*ב-NavEvent. (I228b3, b/436248290) - הפונקציה ממירה את
SwipeEdgeלמחלקה מוטבעת. (Id5e01) - הופכים את הספרייה
navigationeventלניתנת להפעלה הדדית עם Java. עכשיו יש גישה מלאה לכל ממשקי ה-API הציבוריים מקוד Java, כך שאפשר לשלב אותם בצורה חלקה בפרויקטים שכוללים שפות שונות או רק Java. (Ibc944,I5465f, I9fb1e, b/440532890b/443040294) - שינוי שם התפקיד
NavigationEventCallbackל-NavigationEventHandlerכדי להבהיר את התפקידים ב-API. השינוי הזה משקף טוב יותר את המטרה של המחלקה, שהיא טיפול במחוות ניווט מרובות שלבים. השיטה המתאימהaddCallbackהיא עכשיוaddHandler. (I2492a, b/443040331)
תיקוני באגים
- למנוע את ההפעלה של חזרה למצב הקודם בניווט קדימה. (I74814, b/436248290)
- הוספת תמיכה בניווט חיזוי קדימה.
NavigationEventממשקי ה-API מטפלים עכשיו בתנועות חזרה ובתנועות קדימה, ומאפשרים אנימציות עקביות לשני כיווני הניווט. (Idc98c, b/436248290) - למנוע קריסה של
IllegalStateExceptionבמהלך הרכבה מחדש כשמסירים רכיב צאצאNavigationEventDispatcherOwner. (Iff50c, b/412629020) - מאזינים פסיביים יכולים עכשיו לגשת לכל היסטוריית הניווט באמצעות מידע משולב על חזרה, וכך ממשקי משתמש יכולים להציג תצוגות מקדימות והיסטוריית ניווט מוטמעת במקום להיות מוגבלים לקריאה החוזרת העליונה ביותר. (I7a510, b/436248277)
גרסה 1.0.0-alpha07
27 באוגוסט 2025
androidx.navigationevent:navigationevent-*:1.0.0-alpha07 משוחרר. גרסה 1.0.0-alpha07 מכילה את הקומטים האלה.
שינויים ב-API
- הסרה של
NavigationEventDispatcher.onHasEnabledCallbacksChanged. (I50e97) - הפיכת
NavigationEventCallback.onEventCompleted()למופשט. (I36b38) - משנים את השיטות
NavigationEventCallback#on*לשיטותprotected. מעדכנים את קוד החיוג כדי לשנות את ההגדרות. (I6b691) - שינוי השם של פונקציות
DirectNavigationEventInput. (Iffb62) - שינוי השם של
NavigationEventInput.onAttachלonAdded. (I2d0b8) - שינוי השם של
NavigationEventInput.onDetachלonRemoved. (I2d0b8) - שינוי השם של
NavigationEventInputHandlerלNavigationEventInput. (I676a4) - הוספה של
@EmptySuperאלNavigationEventInput.onHasEnabledCallbacksChanged. (If9853) - הטמעה של
onAttachב-NavigationEventInputHandler. (I03648) - הטמעה של
onDetachב-NavigationEventInputHandler. (I03648) - ברירת המחדל היא
NavigationEventCallbackמופעלת בזמן היצירה. (Ic0188) - מחליפים את
NavigationEventInput.addOnHasEnabledCallbacksChangedCallbackב-NavigationEventInput.onHasEnabledCallbacksChanged. (I64e93) - נדרש ה-thread הראשי למשך
NavigationEventDispatcher.addInput. (Ic2930) - נדרש ה-thread הראשי למשך
NavigationEventDispatcher.removeInput. (Ic2930) - הסרה של
Dispatcher.addOnHasEnabledCallbacksChangedCallback. החלפה ב-Dispatcher.onHasEnabledCallbacksChanged. (Ida3e3, b/436530096)
תיקוני באגים
- תוקן באג שבו הוספה של handler שכבר צורף או הסרה של handler שלא צורף הפעילו לוגיקה שגויה של מחזור החיים. (I9e47b)
גרסה 1.0.0-alpha06
13 באוגוסט 2025
androidx.navigationevent:navigationevent-*:1.0.0-alpha06 משוחרר. גרסה 1.0.0-alpha06 מכילה את הקומטים האלה.
תכונות חדשות
Passive Listeners API
עכשיו אפשר להעביר מידע הקשרי מותאם אישית מכל מארח ניווט ולהאזין באופן פסיבי לשינויים במצב המחוות מכל מקום בממשק המשתמש. ההגדרה הזו מפעילה אנימציות מבוססות-הקשר לחיזוי של תנועת החזרה ולניווט אחר שמבוסס על תנועות.
התכונה הזו כוללת שני חלקים:
- העברת מידע – אפשר להשתמש ב-
NavigationEventInfoכדי להעביר נתונים בהתאמה אישית. - Consuming State – משתמשים ב-
dispatcher.state(NavigationEventState) כדי לראות את ההתקדמות וההקשר של תנועת היד.
-
NavigationEventCallbackעכשיו חושף את השיטהsetInfo(currentInfo, previousInfo)להגדרת הקשר של תנועות במחווה אחת (I1d5e7, b/424470518). -
NavigationEventHandlerמוסיף עומס יתר חדש שמקבל אתcurrentInfoואתpreviousInfo, מה שהופך אותו ל-API הראשי לאספקת הקשר באפליקציות Compose (I6ecd3, b/424470518).
דוגמה:
data class MyScreenInfo(val screenName: String) : NavigationEventInfo
NavigationEventHandler(
enabled = true,
currentInfo = MyScreenInfo("Details Screen"),
previousInfo = MyScreenInfo("Home Screen")
) { /* Handle back completion */ }
-
NavigationEventDispatcherחושף עכשיו אתdispatcher.stateואתdispatcher.getState<T>()(If7fae, Ia90ca, b/424470518). ממשקי ה-API האלה שמבוססים עלStateFlowמאפשרים לכל ממשק משתמש לעקוב אחרי התקדמות של תנועות ונתונים הקשריים בלי לטפל באירוע באופן ישיר.
דוגמה:
val gestureState by LocalNavigationEventDispatcherOwner.current!!
.navigationEventDispatcher
.state
.collectAsState()
val progress = gestureState.progress // Returns latestEvent.progress or 0F
when (val state = gestureState) {
is InProgress -> {
val toScreen = state.currentInfo as MyScreenInfo
val fromScreen = state.previousInfo as MyScreenInfo
println("Navigating from ${fromScreen.screenName} to ${toScreen.screenName}")
}
is Idle -> { /* Idle state */ }
}
הוספת נכס
progressאלNavigationEventState(I7b196) שמחזירlatestEvent.progressאם הוא בתהליך, או0Fאחרת:val progress = state.progressמוסיפים
NavigationEventDispatcherOwnercomposable כדי ליצור, לקשר ולסלק מופעים שלNavigationEventDispatcherבאופן היררכי. הפעלה של שליטה דינמית במצב המופעל של כלי השליחה וניקוי אוטומטי.@Composable fun Sample() { NavigationEventDispatcherOwner(enabled = true) { val localDispatcherOwner = LocalNavigationEventDispatcherOwner.current } }
שינויים ב-API
- הפרמטר
isPassthroughהוסר מה-NavigationEventCallback. (I99028, b/424470518) - הקונסטרוקטורים
NavigationEventStateהם עכשיו פנימיים. לצורך בדיקה, מעדכנים את הסטטוס (ברירת המחדל היאIdle) באמצעותDirectNavigationEventInputHandler. מתקשרים אלhandleOnStartedאו אלhandleOnProgressedכדי להגדיר את המצב ל-InProgress, ואלhandleOnCompletedאו אלhandleOnCancelledכדי להחזיר אותו ל-Idle. כדי לעדכן אתNavigationEventInfo, צריך להשתמש בNavigationEventCallback.setInfo. (I93dca, b/424470518) - נוספו פרמטרים שמוגדרים כברירת מחדל ל-
NavigationEventכדי להקל על יצירת מופעים ולפשט את הבדיקה. צריך להשתמש בהם במקום ב-TestNavigationEvent. (I5dc49, I232f4) - נוסף
TestNavigationEventCallbackלבדיקת אירועי ניווט עם מצבים ספציפיים נוכחיים או קודמים. (Idd22e, b/424470518) - הפכנו את
NavigationEventInputHandlerלמחלקה מופשטת כדי להחליף אתAbstractNavigationEventInputHandlerהקודמת בהטמעה ב-DirectNavigationEventInputHandler(Iadde5, Ifed40I3897c, b/432616296, b/435416924) - הקידומות של הפונקציות
send*ב-NavigationEventInputHandlerשונו ל-handle*. (Iffcaf) -
OnBackInvokedInputHandlerמרחיב עכשיו אתabstractהחדשNavigationInputHandler. (Ib45aa) - השתנה
NavigationEventDispatcherOwnerכך שנדרש מפיץ ראשי שבו צריך להעביר במפורש אתnullכדי ליצור מפיץ בסיסי. (Ia6f64, b/431534103)
תיקוני באגים
- שיפור היעילות על ידי מניעת העתקה של קולקציות ב-
NavigationEventDispatcher.dispose(). (I4ab09) - תוקנה בעיה שבה
NavigationEventHandlerלא הגיב בצורה נכונה לשינויים במצב המופעל שלו. (Ia5268,I19bec, I5be5c, b/431534103)
עדכונים ב-Docs
- המסמכים של KDocs עבור
NavigationEventהורחבו כדי להבהיר את התפקיד שלו כעטיפת אירועים מאוחדת ואת התנהגות מאפייני הפרטים בסוגי ניווט שונים (מחוות, קליקים). (I91e8d) - עדכנו את מאמרי העזרה של ממשקי ה-API של Compose לטיפול בחזרה למערכת (
BackHandler, PredictiveBackHandler, NavigationEventHandler) כדי להסביר את ההתנהגות באופן ספציפי לגבי סדר ההתקשרות חזרה. (I7ab94, )
עדכון תלות
-
NavigationEventתלוי עכשיו ב-Compose Runtime 1.9.0-beta03, שמאפשר לארטיפקטnavigationevent-composeלתמוך בכל יעדי KMP. (Ia1b87)
גרסה 1.0.0-alpha05
30 ביולי 2025
androidx.navigationevent:navigationevent-*:1.0.0-alpha05 משוחרר. גרסה 1.0.0-alpha05 מכילה את הקומטים האלה.
תמיכה בהיררכיה של הורה-צאצא:
ל-NavigationEventDispatcher יכולים להיות עכשיו משגרים של הורה וצאצא, שיוצרים מבנה עץ היררכי. האפשרות הזו מאפשרת לאירועי ניווט להתפשט ולנוהל בצורה גמישה יותר ברכיבי ממשק משתמש מורכבים של Compose, על ידי שיקוף ההיררכיה המבנית של ממשק המשתמש באמצעות משגרים משורשרים. (I194ac)
// Create a parent dispatcher that will manage navigation events at a higher level.
val parentDispatcher = NavigationEventDispatcher()
// Create a child dispatcher linked to the parent, forming a hierarchy.
val childDispatcher = NavigationEventDispatcher(parentDispatcher)
המאפיין ההיררכי isEnabled מאפשר שליטה במפיץ מלמעלה למטה. אם מגדירים את isEnabled לערך false במרכז בקרה, כל מרכזי הבקרה שנגזרים ממנו מושבתים אוטומטית. התכונה הזו מאפשרת להשבית ביעילות ענפים שלמים של מערכת אירועי הניווט. (I9e985)
// Disabling the child dispatcher disables all its callbacks and any of its children recursively.
childDispatcher.isEnabled = false
בנוסף, המאפיין isEnabled ב-NavigationEventCallback פועל עכשיו בהתאם למצב ההפעלה של רכיב השליחה המשויך. כלומר, קריאה חוזרת נחשבת למופעלת רק אם גם הקריאה החוזרת עצמה וגם המפיץ שלה (כולל הרכיבים הקודמים שלה) מופעלים. כך מובטח בקרה היררכית עקבית על הפעלת הקריאה החוזרת. (I1799a)
// Create a test callback and add it to the child dispatcher.
val callback1 = TestNavigationEventCallback(isEnabled = true)
childDispatcher.addCallback(callback1)
// Since the childDispatcher is disabled, the callback is effectively disabled as well.
assertThat(callback1.isEnabled).isFalse()
הוספנו שיטה חדשה dispose() לניקוי נכון של רכיבי Dispatcher ורכיבי הצאצא שלהם. הקריאה ל-dispose() מפסיקה את המאזינים כדי למנוע דליפות זיכרון, משחררת באופן רקורסיבי את כל רכיבי ה-dispatcher של הצאצא, מסירה את כל הקריאות החוזרות שרשומות ב-dispatcher ומבטלת את הקישור שלו לרכיב האב. כך תוכלו לוודא שהמשאבים ישוחררו בצורה נכונה כשאין יותר צורך בצוותי השטח. (I9e985)
// Dispose the child dispatcher to clean up resources.
childDispatcher.dispose()
אם קוראים לשיטה ציבורית כלשהי ב-dispatcher שהוצא משימוש, מתקבלת מיד שגיאת IllegalStateException. כך אפשר למנוע כשלים שקורים בלי שהמשתמשים יודעים עליהם, ולעזור למפתחים לזהות שימוש לא תקין במהלך הפיתוח. (Ic2dc3)
val callback2 = TestNavigationEventCallback()
// Attempting to use a disposed dispatcher will throw an exception.
assertThrows<IllegalStateException> {
childDispatcher.addCallback(callback2)
}
הערה: אנחנו נציג NavigationEventDispatcherOwnerרכיב חדש שאפשר להוסיף לאפליקציה (Composable) שמנהל באופן אוטומטי את ה-Dispatcher של הצאצא בממשק המשתמש של Compose ב-aosp/3692572. עם זאת, השינוי הזה לא נכלל בגרסה הנוכחית, והוא מתוכנן לגרסה הבאה.
Navigation Testing Library
- הוספת מודול
navigationevent-testingכדי לספק כלי בדיקה ייעודיים לספרייתnavigationevent. (0e50b6) - הוספת מחלקת כלי עזר פיקטיבית
TestNavigationEventCallbackלבדיקה. הוא מתעד קריאות לשיטת קריאה חוזרת ומאחסן פריטים שהתקבלוNavigationEventכדי לתמוך באימות. (4a0246) - הוספתי פונקציית כלי פיקטיבית
TestNavigationEventכדי ליצור מופעים שלNavigationEventעם ערכי ברירת מחדל, וכך לפשט את בדיקות היחידה לעיבוד אירועי ניווט. (3b63f5) - הוספת מחלקת כלי עזר פיקטיבית
TestNavigationEventDispatcherOwnerלבדיקה. הוא עוקב אחרי מספרים של אירועים של חזרה למצב הקודם ושל שינוי מצב ההפעלה, כדי לתמוך באימות אינטראקציות בבדיקות. (c8753e)
שינויים ב-API
- מעבירים את
NavigationEventInputHandlerמ-androidMainאלcommonMainכדי שיהיה זמין בקוד המשותף של KMP. הוספתpublic send*שיטות חדשות לשליחת אירועים. שינוי פונקציות השליחה ב-NavigationEventDispatcherמ-publicל-internal; המשתמשים צריכים עכשיו להשתמש ב-NavigationEventInputHandlerכדי לשלוח אירועים. (Ia7114) - שינוי השם של
NavigationInputHandlerלOnBackInvokedInputHandler. (I63405)
תיקוני באגים
- מבצעים רפקטורינג של
NavigationEventDispatcherכדי לצמצם את התקורה על ידי הימנעות מהקצאות של רשימות ביניים ושיפור הביצועים של שליחת קריאות חוזרות. (I82702, I1a9d9) - הוספת הערות
@FloatRangeלשדותtouchX,touchYו-progressב-NavigationEventכדי לאכוף טווחי ערכים תקינים בזמן הקומפילציה ולשפר את הבטיחות של ה-API. (Iac0ec)
גרסה 1.0.0-alpha04
2 ביולי 2025
androidx.navigationevent:navigationevent-*:1.0.0-alpha04 משוחרר. גרסה 1.0.0-alpha04 מכילה את הקומטים האלה.
תיקוני באגים
- השתמשתי ב-
implementedInJetBrainsForkכדיnavigationevent-composeוהוספתי יעדcommonStubsבהתאם למוסכמות של Compose. שינוי שבוקש על ידי JetBrains. (f60c79) - בוצע תיקון של היישום של התוסף Compose compiler ל-Kotlin/Native כדי להבטיח יצירה נכונה של stub. אין השפעה על ממשקי API ציבוריים או על אופן הפעולה שלהם. (1890c9)
גרסה 1.0.0-alpha03
18 ביוני 2025
androidx.navigationevent:navigationevent-*:1.0.0-alpha03 משוחרר. גרסה 1.0.0-alpha03 מכילה את הקומטים האלה.
תכונות חדשות
- הוספנו מודול
navigationevent-composeחדש לתמיכה בתכונות של Jetpack Compose בספרייתnavigationevent. (980d78) NavigationEventנוספה ל'יצירה'LocalNavigationEventDispatcherOwnerיצירה מקומית חדשה. היא מחזירה ערך שניתן להגדרה כ-null כדי לקבוע טוב יותר אם היא זמינה בהרכב הנוכחי. מעכשיו, אם הבעלים הבסיסי לא יימצא, תופיע שגיאה ב-NavigationEventHandler. (62ffda)NavigationEventנוסף ל-Compose רכיבNavigationEventHandlerComposable חדש לטיפול באירועים (תנועת חזרה עם חיזוי). היא מספקתFlowשלNavigationEventאובייקטים שצריך לאסוף בפונקציית ה-lambda להשעיה שסיפקתם c42ba6:
NavigationEventHandler { progress: Flow<NavigationEvent> ->
// This block is executed when the back gesture begins.
try {
progress.collect { backEvent ->
// Handle gesture progress updates here.
}
// This block is executed if the gesture completes successfully.
} catch (e: CancellationException) {
// This block is executed if the gesture is cancelled
throw e
} finally {
// This block is executed either the gesture is completed or cancelled
}
}
שינויים ב-API
- כל
NavigationEventCallbackיכול להיות רשום רק אצלNavigationEventDispatcherאחד בכל פעם. אם מוסיפים אותו לכמה מרכזי ניהול משלוחים, מוצגתIllegalStateException. שימו לב שההתנהגות הזו שונה מOnBackPressedDispatcher, שמאפשרת שימוש בכמה מעבירי בקשות. (e82c19) - הפכנו את
isPassThroughל-valכדי למנוע מוטציה במהלך הניווט, שיכולה לשבש את השליחה שלNavigationEvent. (I0b287)
גרסה 1.0.0-alpha02
4 ביוני 2025
androidx.navigationevent:navigationevent-*:1.0.0-alpha02 משוחרר. גרסה 1.0.0-alpha02 מכילה את ההתחייבויות האלה.
שינויים ב-API
- מחליפים את בנאי המשנה של
NavigationEventDispatcherבארגומנטים שמוגדרים כברירת מחדל. (I716a0) - הסרת מאפיין העדיפות מהמאפיין
NavigationEventCallback. במקום זאת, מעבירים את העדיפות אלNavigationEventDispatcher.addCallback(). (I13cae)
תיקוני באגים
- תוקנה בעיה
ConcurrentModificationExceptionשיכולה לקרות כשמתבצעת קריאה ל-NavigationEventCallback.remove()בגלל שינוי בו-זמני של הרשימה הפנימית של רכיבים שניתן לסגור. (b/420919815)
גרסה 1.0.0-alpha01
20 במאי 2025
androidx.navigationevent:navigationevent-*:1.0.0-alpha01 משוחרר. גרסה 1.0.0-alpha01 מכילה את הקומטים האלה.
תכונות חדשות
- ספריית
androidx.navigationeventמספקת API שמתמקד ב-KMP לטיפול בחזרה למערכת, וגם בחזרה עם חיזוי. NavigationEventDispatcherמשמש כממשקי API משותפים לרישום של מופע אחד או יותר שלNavigationEventCallbackלקבלת אירועים של חזרה למערכת. - השכבה הזו נמצאת מתחת לממשקי ה-API שפורסמו בעבר ב-
androidx.activity, והיא נועדה להיות תחליף פחות דעתני לשימוש בממשקי ה-API של Activity ברכיבים ברמה גבוהה יותר או לשימוש ישיר בממשקי ה-API של Android frameworkOnBackInvokedDispatcher. ממשקי ה-API שלandroidx.activityנכתבו מחדש על בסיס ממשקי ה-API של אירועי הניווט כחלק מ-Activity 1.12.0-alpha01.