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") }
لمزيد من المعلومات حول الاعتماديات، يُرجى الاطّلاع على إضافة اعتماديات الإصدار.
الملاحظات
تساعدنا ملاحظاتك في تحسين Jetpack. يُرجى إعلامنا إذا اكتشفت مشاكل جديدة أو كانت لديك أفكار لتحسين هذه المكتبة. يُرجى الاطّلاع على المشاكل الحالية في هذه المكتبة قبل إنشاء مشكلة جديدة. يمكنك إضافة صوتك إلى مشكلة حالية من خلال النقر على زر النجمة.
يُرجى الاطّلاع على مستندات Issue Tracker للحصول على مزيد من المعلومات.
لا تتوفّر ملاحظات إصدار لهذا العنصر.
Navigation3 الإصدار 1.2
الإصدار 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 من Navigation الآن استخدام الروابط لصفحات معيّنة مع DeepLinkRequest وDeepLinkMatcher:
DeepLinkRequestرابط لصفحة في التطبيق يحتوي علىDeepLinkUriونوع MIME أو إجراء اختياري(على أجهزة 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)
تغييرات واجهة برمجة التطبيقات
- تمت الترقية إلى
compileSdk 37لتتوافق مع compileSdk في Compose
إصلاح الأخطاء
- تم إصلاح
IllegalArgumentExceptionفيAnimatedBottomSheetSampleعند عرض تراكبات متعددة. سيحسب المثالSceneStrategyالآن بشكلٍ صحيح آخر قيمة غيرOverlaySceneويعرضها تحت جميع المشاهد المتراكبة. (If2281، b/506733412) - تمت ترقية تبعية
NavigationEventإلى الإصدار 1.1.1 الذي يزيل NavigationEventHandler غير الفعّال عند تفعيل وضع الفحص لتفعيل ميزة "إيماءة إظهار شاشة الرجوع" في الإصدارات التجريبية من "استوديو Android". (I487fd)
الإصدار 1.2.0-alpha02
22 أبريل 2026
تم طرح androidx.navigation3:navigation3-*:1.2.0-alpha02. يتضمّن الإصدار 1.2.0-alpha02 هذه التعديلات.
تغييرات واجهة برمجة التطبيقات
- أعِد تسمية
onBackإلىonBackCompletedوأضِفonBackCancelledإلى NavigationBackHandler لتوفير إمكانية التعامل مع إيماءات الرجوع الملغاة. (I92741) - أضِف
NavigationBackHandlerلتبسيط التعامل مع إيماءات الرجوع وإيماءة الرجوع التوقّعية عند استخدامSceneState. يتيح ذلك للمطوّرين إنشاء مكوّنات واجهة مستخدم مخصّصة بسهولة أكبر تتوافق مع التنقّل للخلف العادي والإيماءات التوقّعية بدون احتساب الفروق في الأنشطة السابقة يدويًا. (I6a055) - أضِف
rememberNavigationEventStateلتسهيل عملية الربطSceneStateمن خلال معالجة إيماءة إظهار شاشة الرجوع. (Iae49c)
الميزات الجديدة
- تمت إضافة واجهة برمجة تطبيقات
ResultEventBusللسماح بتمرير النتائج بين NavEntries باستخدام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لا تنفّذ أي عملية. (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 الذي أزالNavigationEventHandlerغير الفعّال عند استخدام وضع الفحص لتفعيل ميزة "الرجوع التوقّعي" في الإصدارات التجريبية من "استوديو Android".
الإصدار 1.1.2
19 مايو 2026
تم طرح androidx.navigation3:navigation3-*:1.1.2. يتضمّن الإصدار 1.1.2 هذه التعديلات.
إصلاح الأخطاء
- تمت ترقية تبعية
NavigationEventإلى الإصدار 1.1.1 الذي أزالNavigationEventHandlerغير الفعّال عند استخدام وضع الفحص لتفعيل ميزة "الرجوع التوقّعي" في الإصدارات التجريبية من "استوديو Android".
الإصدار 1.1.1
22 أبريل 2026
تم طرح androidx.navigation3:navigation3-*:1.1.1. يتضمّن الإصدار 1.1.1 هذه التعديلات.
إصلاح الأخطاء
- لن يؤدي الوصول إلى
LocalNavAnimatedContentScopeمنOverlaySceneإلى حدوثIllegalStateException، لأنّOverlayScenesيتم الآن تزويدها بـLocalAnimatedContentScopeلا تنفّذ أي عملية. (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 المتحركة
- تحتوي واجهة OverlayScene على 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الآن أنّه يتم تحديد الحدّ الأقصى لعدد مرات ظهورLifecycleعندSTARTEDفي الإدخالات التي يتم عرضها أسفل التراكبات. يضمن ذلك استمرار عمل واجهات برمجة التطبيقات، مثلdropUnlessResumed، عند استخدام مربّعات الحوار. (If209f، b/483966071) - تم إصلاح مشكلة في
NavDisplayكان فيها التنقّل ذهابًا وإيابًا بين الشاشات نفسها وإيقاف الرسوم المتحركة بين الشاشتين قد يؤدي إلى عدم صحة ترتيب الشاشات حسب محور z. (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 هذه التعديلات.
تغييرات واجهة برمجة التطبيقات
- يستخدم نظاما التشغيل
NavDisplayوrememberSceneStateالآنList<SceneStrategy>بدلاً من المَعلمة الفردية السابقةSceneStrategyالتي تم ربطها باللاحقةthen. يتوافق ذلك بشكل أكبر معList<SceneDecoratorStrategy<T>>الذي تستخدمه كلتا واجهتَي برمجة التطبيقات حاليًا. تم إيقاف واجهات برمجة التطبيقات السابقة. (I78b2c، b/482108465) - تمت إضافة عامل التشغيل #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 واجهة
MetadataKeyجديدة تتيح تحديد أنواع المفاتيح والقيم التي يريدون تقديمها إلى خريطة البيانات الوصفية. أضفنا أيضًاNavMetadataKeyجديدة لعمليات الانتقالNavDisplayحتى يمكن استخدامها معmetadataDSL الجديدة لإضافة عمليات انتقال إلىNavDisplay. (Ic10ef وIc049c وb/476213928)
تغييرات واجهة برمجة التطبيقات
- تتضمّن واجهة
OverlaySceneدالة معاودة الاتصال الجديدةonRemovedالخاصة بالتعليق. يتم استدعاء دالة الرجوع هذه بعد إزالة مفتاح مرتبط بالمشهد من سجلّ التصفّح الخلفي، ولكن قبل أن يغادر التركيب. يسمح ذلك بإكمال الصور المتحركة للخروج التي يتم استدعاؤها ضِمنonRemovedقبل إزالة مشهد التراكب من التركيب. (I29a72، b/440558061) - تم فصل دالة الزخرفة في
SceneStrategyإلى دالة جديدةSceneDecoratorStrategy. هذه الواجهة الجديدة هي ما يجب استخدامه لتزيين المشاهد. تتوفّر واجهات برمجة تطبيقات جديدة لـNavDisplayوrememberSceneStateللسماح بإضافةSceneDecoratorStrategies. (If9385، b/477669607، b/477670333)
إصلاح الأخطاء
- تم إصلاح خطأ كان يحدث عند تمرير
SharedTransitionLayoutإلىNavDisplayأوrememberSceneStateواستخدام أيOverlayScene، ما كان يؤدي إلى حدوث عطل لأنّ استخدامSharedTransitionLayoutلا يعمل إلا معNavEntriesالتي يتم عرضها كجزء منAnimatedContent، ويتم عرضOverlaySceneفي نوافذ منفصلة. (I1bb76، b/478664101)
تحديث الاعتمادية
- من الإصدار 1.0.1 من
Navigation3: يعتمدNavigation3الآن على الإصدار 1.0.2 منNavigationEvent. يحلّ هذا التحديث مشكلة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 هذه التعديلات.
تغييرات واجهة برمجة التطبيقات
- تتيح
Navigation3الآن التعامل مع المشاهد كعناصر مشتركة. هذا يعني أنّه عند تغيير المشاهد، يمكن ضمان الانتقال السلس بينها. يمكنك تفعيل ذلك من خلال تمريرSharedTransitionScopeإلىNavDisplayأو إلىrememberSceneState. (I15868)
الإصدار 1.0
الإصدار 1.0.1
11 فبراير 2026
تم طرح androidx.navigation3:navigation3-*:1.0.1. يتضمّن الإصدار 1.0.1 هذه التعديلات.
تحديث الاعتمادية
- يعتمد
Navigation3الآن على الإصدار 1.0.2 منNavigationEvent. يحلّ هذا التحديث مشكلة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 للتنقل.
- لمزيد من المعلومات، يُرجى الاطّلاع على منشور المدوّنة الخاص بالإعلان، والانتقال إلى المراجع، وتجربة الوصفات.
الإصدار 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 هذه التعديلات.
تغييرات واجهة برمجة التطبيقات
- يحتوي
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 هذه التعديلات.
تغييرات واجهة برمجة التطبيقات
- لم يعُد بإمكانك
@Composableاستخدام طريقةcalculateSceneعلىSceneStrategy. بدلاً من ذلك، ننصحك بنقل هذا العمل إلى إنشاء طريقةSceneStrategy(أي في طريقةrememberMySceneStrategy()) التي تتيح لك بالكامل تحديد مدة صلاحية أي قيمrememberSaveableأو عباراتrememberالرئيسية من القيم الصحيحة. (If1733، b/448709506) - تم نقل المَعلمة
onBackالخاصة بـSceneStrategy.calculateSceneإلى نطاق المتلقّي الجديدSceneStrategyScopeلتوضيح أنّ هذه المَعلمة اختيارية وتوفير نقطة توسيع لميزات Navigation3 المستقبلية. (I3aea3، b/448460407) - لم يعُد
onBacklambda الذي تم تمريره إلىNavDisplayوإلىSceneStrategyيوفّر المَعلمةcount: Intللإشارة إلى الوقت الذي يجب فيه إزالة إدخالات متعددة. بدلاً من ذلك، سيتم الآن استدعاء دالة() -> Unitlambda عدة مرات على التوالي في الحالة النادرة التي تطلب فيها "مشاهد" عرض إدخالات متعددة. (Idedb5، b/446989346) - أزِل الفئة
NavEntryWrapperواستبدِل وظائفها بفئةNavEntryنهائية تتضمّن دالة إنشاء ثانوية جديدة تأخذNavEntryمع محتوى جديد. سيسمح ذلك بمواصلة إتاحة إمكانية تضمين إدخال بمحتوى جديد. (I7da2a، b/444447130) - تمت إزالة الدالة
navEntryDecoratorالتي تنشئ وتعرضNavEntryDecoratorواستبدالها بفئةNavEntryDecoratorالتي أصبحت متاحة الآن للجميع ويمكن إنشاء فئات فرعية منها. (If81f8، b/444447434، b/447381176) - تمت إعادة تسمية
SavedStateNavEntryDecoratorإلىSaveableStateHolderNavEntryDecoratorلأنّها تزين الإدخالات باستخدامSaveableStateHolder. تمت إعادة تصميم أداة التزيين أيضًا من دالة إلى فئة لأنّها تعمل وظيفيًا كمصنع لـNavEntryDecorator. (Ie6013، b/447381176) - لم يعُد من الضروري استخدام
LocalEntriesToRenderInCurrentScenecomposition local في العروض المخصّصة التي تستخدمSceneStateكبديل لاستخدامNavDisplay، لأنّها أصبحت الآن داخلية. (Ic40ef، b/414668196) - تمت إزالة
SceneSetupNavEntryDecoratorوrememberSceneSetupNavEntryDecorator()من مساحة واجهة برمجة التطبيقات العلنية. تتوفّر هذه الوظيفة الآن تلقائيًا بدون الحاجة إلى تضمينها يدويًا. (Ieae42، b/444479133) - تتضمّن الآن كل من
NavEntryوDialogSceneوSinglePaneSceneوSceneStateدالة equals. (I96121) - تتضمّن واجهة المشهد حقل بيانات وصفية جديدًا لإرفاق بيانات وصفية خاصة بالمشهد في NavDisplay. يسمح ذلك لـ "مشهد" بتجاوز البيانات الوصفية في
NavDisplay، على سبيل المثال باستخدام انتقالات. (I1fd96، b/443955625) - تبسيط توقيع
rememberNavBackStackمن خلال إزالة مَعلمة النوع العام المكرّرة تقبل الدالة الآن القيمةvararg elements: NavKey. (I03e45) - أصبحت الرسوم المتحركة التلقائية في
NavDisplayجزءًا من واجهة برمجة التطبيقات الشائعة التي تتيح استدعاءها من جميع المنصات. (I71af9، b/447147159) - أعِد تسمية
EntryProviderBuilderإلىEntryProviderScopeلتعكس بدقة أنّ الفئة هي لغة خاصة بالنطاق (DSL) في Kotlin توفّر نطاقًا لإنشاء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 هذه التعديلات.
تغييرات واجهة برمجة التطبيقات
- أضِف حمولة زائدة جديدة
NavDisplayتأخذ قائمةNavEntry<T>تم تزيينها بواسطةrememberDecoratedNavEntries. (I4025b، b/441940314) - تم نقل
DialogSceneإلى حزمة جديدة. (Ia5840) - أزِل واجهة برمجة التطبيقات العامة
DecorateNavEntry. بدلاً من ذلك، استخدِمrememberDecoratedNavEntriesلتضمين NavEntry مع قائمة من أدوات التزيين. (Id8c09) - توفّر واجهة مستخدم Navigation3 الآن خصائص
transitionSpecتلقائية جديدة. (Ibcabd) - تمت إضافة عنصر
SceneStateجديد للمساعدة في إدارة المشاهد. يوفّر ذلك أيضًا عملية تحميل زائدة جديدةNavDisplayتأخذSceneStateوNavigationEventState. (Idfb46، b/444479133) - تتيح لك
NavDisplayالآن تخصيص عمليات الانتقال استنادًا إلىSceneالتي ستنتقل إليها أو منها من خلال النظر إلىcurrentStateوtargetStateفيTransition. (I906cc، b/443872322) - أصبح
NavigationEventInfoالآنabstract classبدلاً منinterface. عدِّل جميع عمليات التنفيذ المخصّصة لتكون مشتقة من الفئة (مثلdata class MyInfo : NavigationEventInfo()). (I1e59c، b/444734264) - تم تعديل واجهات برمجة التطبيقات لمعالج
navigationevent-compose. يتوافق النوعانNavigationEventHandlerوNavigationBackHandler(والأنواع الفرعية) الآن مع تحميل زائد جديد يقبلNavigationEventStates تم نقلها إلى الأعلى. يتم الاحتفاظ بالتحميلات الزائدة البسيطة (التي تتضمّنcurrentInfo) وتستخدم الآن نموذج الحالة الجديد هذا داخليًا. (Ic3251، b/444734264) - تم نقل جميع واجهات برمجة التطبيقات الخاصة بالمشاهد من navigation3-ui إلى navigation3-runtime. وهذا يعني أنّها أصبحت متاحة الآن على جميع المنصات المتوافقة مع navigation3-runtime. (I431d0، b/444449993)
- تمت إضافة حمولة زائدة جديدة
rememberDecoratedNavEntriesتأخذ قائمةNavEntryلإضافة مَعلمات. يمكن أن تكون إدخالات الإدخال مزيّنة مسبقًا بمزيّنات إدخال أخرى. (I5a034، b/444230270) - إزالة مَعلمات نوع حرف البدل navigation3 (I02540)
- تم تحسين طريقة التعامل مع الأنواع العامة في لغة
entryProviderالخاصة بالمجال. إذا كنت تستوردandroidx.navigation3.runtime.entryفي السابق، لم يعُد ذلك مطلوبًا. (I299fc) - يجب حصر التحميل الزائد
NavBackStackSerializerالمستند إلى الانعكاس على Android. يمنع ذلك حدوث أخطاء ضمنية في التسلسل أثناء وقت التشغيل على الأنظمة الأساسية غير Android من خلال فرض استخدام التحميل الزائد الصريحSavedStateConfigurationفي الرمز البرمجي المتوافق مع عدة أنظمة أساسية. (I73313، b/420443609) - اجعل
swipeEdgeNavigationEvent@IntDef(Icee54، b/443950342) - حصر تسلسل
NavBackStackعلى Android يمنع ذلك حدوث أخطاء أثناء التشغيل على المنصات غير التابعة لنظام التشغيل Android. لحفظ الحالة على منصات متعددة، استخدِم الدالةrememberNavBackStackمع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 هذه التعديلات.
تغييرات واجهة برمجة التطبيقات
- تم استبدال
DecoratedNavEntryProviderبـrememberDecoratedNavEntriesالذي ينشئ NavEntries ويعرضها مع قائمة أدوات التزيين المتوفّرة (I0fe1c، b/441328236) - أصبحت
NavBackStackالآن عامة على النوعNavKey. يتيح ذلك للتطبيقات والمكتبات تحديد أنواع مفاتيح مخصّصة لحِزم البيانات السابقة، بدلاً من الاقتصار علىNavKey. (I4d190 وIad2f4 وb/420443609) - أصبحت السمة
NavBackStackالآن@kotlinx.serialization.Serializable، ما يتيح حفظ حالة التنقّل واستعادتها عند إيقاف العملية نهائيًا وتغيير الإعدادات بدون الحاجة إلى رمز نموذجي إضافي. (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 وDesktop)، وNative (Linux وiOS وwatchOS وmacOS وMinGW)، والويب (JavaScript وWasmJS). (I55078 وb/424410398 وb/419294028 وb/419046226) ملاحظة: لا يوفّر ذلك استهدافات KMP لعنصرNavigation3 UI. على المنصات الأخرى، عليك تنفيذNavDisplayمخصّص خاص بك. إذا أردت أن تصبح هذه الميزة متاحة، يُرجى التصويت على المشكلة في Jetbrains هنا ومتابعة حالة الطلب للحصول على دعم إضافي. - أصبح الكائن
NavDisplayInfoالآن متاحًا للجميع ويمكن استخدامه لاسترداد قائمة الإدخالات المرئية منNavDisplay. (Ibc91f)
تغييرات واجهة برمجة التطبيقات
- تمت إضافة
NavBackStackSerializerجديد لاستخدامه معrememberNavBackStackلتنفيذ عملية استعادة الحالة. يتلقّىrememberNavBackStack()الآن أيضًاSavedStateConfigurationيمكن استخدامه لتقديم الإعدادات الخاصة بك. (I2f4d2 وI4cd58 وb/420443609)
إصلاح الأخطاء
- تم إصلاح مشكلة كانت تتسبب في تشغيل أحداث Lifecycle غير صحيحة عند التنقّل. (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 من المستوى 21 لواجهة برمجة التطبيقات إلى المستوى 23 لواجهة برمجة التطبيقات (Ibdfca وb/380448311 وb/435705964 وb/435705223).
تغييرات واجهة برمجة التطبيقات
- تستخدم
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 يوليو 2022
تم طرح androidx.navigation3:navigation3-*:1.0.0-alpha05. يتضمّن الإصدار 1.0.0-alpha05 هذه التعديلات.
التغييرات في السلوك
- تستند حالة
NavEntryالآن بشكل صارم إلى قائمة أدوات التزيين الحالية التي تم تمريرها إلىNavDisplay. وهذا يعني أنّه يجب استبدال أدوات التزيين على طول الأنشطة السابقة في حال توفّر أنشطة سابقة متعددة من أجل الحفاظ على الحالة في الأنشطة السابقة. بخلاف ذلك، سيتم محو الحالات كما لو تم إزالة الإدخالات (بدلاً من التبديل). (I7a759، b/428033667)
الإصدار 1.0.0-alpha04
18 يونيو 2025
تم طرح androidx.navigation3:navigation3-*:1.0.0-alpha04. يتضمّن الإصدار 1.0.0-alpha04 هذه التعديلات.
تغييرات واجهة برمجة التطبيقات
NavEntry.contentخاصة الآن. لاستدعاء محتوىNavEntry، استخدِم واجهة برمجة التطبيقات الجديدةNavEntry.Content()التي لم تعُد تتطلّب المَعلمةkeyلاستدعائها. (Icd0fd، b/420991203)- أصبحت
NavEntry.keyالآن حقلًا خاصًا. يجب تحديدNavEntryوالحالات ذات الصلة من خلال الحقل الجديدcontentKeyالذي يتم إنشاؤه من تعبير lambda الجديدcontentKeyFactoryويتم ضبطه تلقائيًا على قيمة تجزئة قابلة للحفظ يتم إنشاؤها من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حالات عناصر التزيين الخاصة بعناصر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. يمكن للمطوّرين تقديم حالتهم مباشرةً إلى الدالة القابلة للإنشاء 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.