‫ARCore for Jetpack XR

يمكنك دمج المحتوى الرقمي في العالم الحقيقي باستخدام إمكانات الإدراك.
آخر الأخبار الإصدار الثابت إصدار محتمل الإصدار التجريبي الإصدار الأولي
‫19 مايو 2026 - - - 1.0.0-alpha14

تحديد الاعتماديات

لإضافة اعتمادية على ARCore for Jetpack XR، يجب تضمين مستودع Maven من Google في مشروعك. اطّلِع على مستودع Maven من Google لمزيد من المعلومات.

أضِف الاعتماديات الخاصة بالعناصر التي تحتاج إليها في ملف build.gradle لتطبيقك أو وحدتك:

Groovy

dependencies {
    implementation "androidx.xr.arcore:arcore:1.0.0-alpha14"
}

Kotlin

dependencies {
    implementation("androidx.xr.arcore:arcore:1.0.0-alpha14")
}

لمزيد من المعلومات حول الاعتماديات، يُرجى الاطّلاع على إضافة اعتماديات الإصدار.

الملاحظات

تساعدنا ملاحظاتك في تحسين Jetpack. يُرجى إعلامنا إذا اكتشفت مشاكل جديدة أو كانت لديك أفكار لتحسين هذه المكتبة. يُرجى الاطّلاع على المشاكل الحالية في هذه المكتبة قبل إنشاء مشكلة جديدة. يمكنك إضافة صوتك إلى مشكلة حالية من خلال النقر على زر النجمة.

إنشاء مشكلة جديدة

يُرجى الاطّلاع على مستندات Issue Tracker للحصول على مزيد من المعلومات.

الإصدار 1.0

الإصدار ‎1.0.0-alpha14

‫19 مايو 2026

تم طرح androidx.xr.arcore:arcore-*:1.0.0-alpha14. يتضمّن الإصدار ‎1.0.0-alpha14 هذه التعديلات.

تغييرات واجهة برمجة التطبيقات

  • إيقاف GeospatialMode.VPS_AND_GPS نهائيًا واستبداله بـ GeospatialMode.SPATIAL، وإطلاق وضع تتبُّع جديد منخفض الطاقة، GeospatialMode.INERTIAL، لا يستخدم سوى وحدة القياس بالقصور الذاتي ونظام GPS (I1e6cd)
  • فئات استثناءات نقاط الارتكاز المخصّصة: AnchorInvalidUuidException وAnchorNotAuthorizedException وAnchorUnsupportedLocationException وAnchorRuntimeFailureException وAnchorUnsupportedObjectException هي الآن مثيلات RuntimeException، ولا يُفترض التحقّق منها. (I9356e)
  • تمت إضافة واجهة برمجة التطبيقات ArCoreTestRule، بما في ذلك TestArDevice وTestAugmentableObject وTestDepthMap وTestEye وTestFace وTestGeospatial وTestHand وTestPlane وTestRenderViewpoint وTestTrackable (I0ad3c)
  • يزيل AnchorLoadInvalidUuid وAnchorCreateUnsupportedObject وAnchorCreateUnsupportedLocation وAnchorCreateNotAuthorized. أصبحت كل هذه الأخطاء الآن استثناءات في وقت التشغيل. تتم إزالة AnchorCreateIllegalState. تم استبدالها بـ AnchorCreateTrackingUnavailable في معظم الحالات. تضيف هذه السمة AnchorException والفئات الفرعية AnchorInvalidUuidException وAnchorNotAuthorizedException وAnchorUnsupportedLocationException وAnchorRuntimeFailureException وAnchorUnsupportedObjectException. (I4c4dd)

المشاكل المعروفة

  • قد يتم فقدان بيانات التتبُّع الجغرافي المكاني أثناء سيناريوهات الاتصال الصعبة عند استخدام تنفيذ وقت التشغيل arcore-projected. يجب أن يؤدي إزالة عملية التنفيذ هذه في وقت التشغيل من تطبيقك واستخدام arcore-play-services بدلاً منها إلى حلّ المشكلة. سيكون هذا هو الإعداد التلقائي في الإصدار التالي.

المساهمة الخارجية

  • تمت إضافة واجهة برمجة التطبيقات AugmentedImage لتتبُّع محدّدات المواقع المخصّصة (I0cf09)

الإصدار ‎1.0.0-alpha13

‫6 مايو 2026

تم طرح androidx.xr.arcore:arcore-*:1.0.0-alpha13. يتضمّن الإصدار ‎1.0.0-alpha13 هذه التعديلات.

تغييرات واجهة برمجة التطبيقات

  • تم نقل TrackingState وVpsAvailabilityResult إلى androidx.xr.arcore package، وأصبحت الأنواع في androidx.xr.runtime متوقّفة نهائيًا. (Ic7930، b/480462213)
  • تمت إعادة تسمية "Plane.Type" إلى "PlaneType". (I8c90c، b/482675376)
  • تمت إعادة تسمية "Hand.HandSide" إلى "HandSide". (Ica562، b/482675376)
  • تمت إعادة تسمية "Plane.Label" إلى "PlaneLabel". (Ic6b67، b/482675376)
  • تمت إعادة تسمية "Geospatial.Surface" إلى "GeospatialSurface". (I1a8be، b/482675376)
  • تمت إعادة تسمية Geospatial.State إلى GeospatialState. (I203fa، b/482675376)
  • تم نقل واجهة برمجة التطبيقات NativeData إلى المكتبة xr:runtime:runtime. (I87954، b/494251500)
  • أصبحت Session.create وSession.configure غير شاملة الآن وتتطلّب عبارات else في عبارات when. (I9885e، b/495805998، b/495805998)
  • تم إيقاف androidx.xr.runtime.FieldOfView نهائيًا. استخدِم androidx.xr.runtime.math.FieldOfView بدلاً من ذلك. (Ia01a0، b/480233045)
  • تم تغيير Orbiter لاستخدام OrbiterAnchorPoint + VolumeOffset أو OrbiterPoseProvider بدلاً من الموضع والإزاحة ونوع الإزاحة والمحاذاة والارتفاع. تمّت أيضًا إزالة المَعلمة shouldRenderInNonSpatial. إذا كان المطوّر لا يريد عرض Orbiter في وضع غير مكاني، عليه تضمين Orbiter في عبارة if والتحقّق من SpatialCapabilities. (I9fbb3، b/462428503)
  • تمت إضافة أدوات تعديل قابلة للنقل. تعمل أدوات التعديل هذه بشكل جيد في الوقت الحالي مع SpatialPanels وSpatialExternalSurface. وستتوفّر قريبًا أيضًا في SpatialGltfModels. ومع ذلك، فإنّ الهدف هو أن تكون هذه الميزات متوافقة بشكل جيد مع جميع SubspaceComposables. (I9a3cd، b/479530787، b/478935063، b/478935063)
  • على المطوّرين اتّباع ArDevice.state مسار العمل لمراقبة State.trackingState وتعديل عرض التطبيق أو التحذيرات وفقًا لذلك استنادًا إلى دقة التتبُّع. (Ic00f0، b/445466590)
  • تمت إعادة تسمية قيم التعداد HandJointType. (Ifbc83، b/482670596)
  • تمت إعادة تسمية الثوابت FaceConfidenceRegion. (Ia62d5، b/482670596)
  • تمت إعادة تسمية الثوابت FaceBlendShapeType. (I33b8b، b/482670596)
  • تمّت إضافة CreatePoseFromGeospatialPoseErrorInternal وCreateGeospatialPoseFromPoseErrorInternal. (I4bcf1، b/482666615)
  • تمت إعادة تسمية DeviceTrackingMode.LAST_KNOWN إلى SPATIAL_LAST_KNOWN (مع توفير خيار احتياطي قديم)، وتمت إضافة INERTIAL_LAST_KNOWN لتتبُّع 3DoF، كما تمت إضافة TRACKING_DEGRADED إلى TrackingState. (Ie661c، b/445466590)
  • تم إيقاف GroupEntity نهائيًا. للحصول على عنصر Entity يتضمّن وظائف العنصر الأساسي فقط، استدعِ Entity.create الذي سيعرض واجهة العنصر. (I4c450، b/473867483)
  • تمت إضافة واجهة برمجة التطبيقات XrLog. اضبط XrLog.isEnabled على true لتفعيل التسجيل في JetpackXR، واستخدِم XrLog.Level لضبط مستوى التسجيل. (I76a1f، b/463460895، b/487378441)

إصلاح الأخطاء

  • أضِف دعم حالة تتبُّع الجهاز إلى أجهزة OpenXR. (I91485، b/445466590)

الإصدار ‎1.0.0-alpha12

‫25 مارس 2026

تم طرح androidx.xr.arcore:arcore-*:1.0.0-alpha12. يتضمّن الإصدار ‎1.0.0-alpha12 هذه التعديلات.

تغييرات واجهة برمجة التطبيقات

  • تم تغيير Config.augmentedObjectCategories من قائمة إلى مجموعة. (I25a64، b/487376359)
  • النوعان androidx.xr.arcore.Eye وandroidx.xr.arcore.Hand (I42438، b/449032900)
  • تمت إضافة حمولة زائدة Session.create للسماح بتمرير "سياق Android" لتحديد نطاق الموارد. (I7d3fe، b/415805990، b/477386334)
  • تغيير FakeRuntimeAnchor.ANCHOR_RESOURCE_LIMIT إلى FakeRuntimeAnchor.anchorResourceLimit (I90841، b/431992235)
  • جعل واجهة برمجة التطبيقات TiltGesture تجريبية لأنّه قد يتم تغييرها أو إزالتها في المستقبل لاستخدام واجهة برمجة التطبيقات هذه، يجب الموافقة على @ExperimentalGesturesApi (Ic9858).
  • تمت إضافة إمكانية ضبط الفئات لتتبُّع AugmentedObject في ملف الإعداد (I1f6e4، b/480220930)

إصلاح الأخطاء

  • تم إصلاح إصدار Chrome من خلال تعديل ملف META-INF/services/ باستخدام الموقع الجغرافي الفعلي لـ PerceptionRuntimeFactory. (I7a801، b/481288291)

الإصدار ‎1.0.0-alpha11

‫25 فبراير 2026

تم طرح androidx.xr.arcore:arcore-*:1.0.0-alpha11. يتضمّن الإصدار ‎1.0.0-alpha11 هذه التعديلات.

الإصدار ‎1.0.0-alpha10

‫28 يناير 2026

تم طرح androidx.xr.arcore:arcore-*:1.0.0-alpha10. يتضمّن الإصدار ‎1.0.0-alpha10 هذه التعديلات.

الميزات الجديدة

  • تضيف واجهة برمجة التطبيقات TiltGesture، ما يوفّر Flow تفاعليًا لرصد حالة ميل الجهاز (للأعلى/للأسفل) بشكل ثابت مع عرض مستوى التقدّم في الانتقال. (Ic269f، b/448152779)
  • تستخدم حزمة ARCore for Jetpack XR الآن آلية تسجيل بيانات وقت التشغيل في XR. يُرجى الاطّلاع على androidx.xr.runtime.Log لمزيد من المعلومات. (l52735، b/448697662)

تغييرات واجهة برمجة التطبيقات

  • تعمل ميزة Geospatial.createPoseFromGeospatialPose الآن على الأجهزة المتوافقة مع OpenXR. (l362c6)

الإصدار ‎1.0.0-alpha09

‫3 ديسمبر 2025

تم طرح androidx.xr.arcore:arcore-*:1.0.0-alpha09. يتضمّن الإصدار ‎1.0.0-alpha09 هذه التعديلات.

الإصدار ‎1.0.0-alpha08

‫19 نوفمبر 2025

تم طرح androidx.xr.arcore:arcore-*:1.0.0-alpha08. يتضمّن الإصدار ‎1.0.0-alpha08 هذه التعديلات.

الميزات الجديدة

  • يتوافق الإصدار ARCore من Jetpack XR الآن مع الأجهزة التي تتوفّر عليها "خدمات Google Play للواقع المعزّز".
  • تمّت إضافة واجهات Geospatial API للتحقّق من توفّر خدمة تحديد المواقع المرئية (VPS) وتحويل الوضع (I144dc)

الإصدار ‎1.0.0-alpha07

‫22 أكتوبر 2025

تم طرح androidx.xr.arcore:arcore-*:1.0.0-alpha07. يتضمّن الإصدار ‎1.0.0-alpha07 هذه التعديلات.

إصلاح الأخطاء

  • تمت إضافة :xr:arcore:arcore-openxr كعنصر تابع للتنفيذ إلى :xr:arcore:arcore (I47315، b/446999229)

الإصدار ‎1.0.0-alpha06

‫24 سبتمبر 2025

تم طرح androidx.xr.arcore:arcore-*:1.0.0-alpha06. يتضمّن الإصدار ‎1.0.0-alpha06 هذه التعديلات.

تغييرات واجهة برمجة التطبيقات

  • تم نقل إمكانية اختبار بيانات ARCore المنظَّمة إلى الوحدة xr:arcore:arcore-testing. (I25469)
  • إضافة ArDevice وRenderViewpoint للسماح للتطبيقات باسترداد وضع الجهاز وإعدادات العرض لأغراض العرض (Ib7e3f)
  • إعادة تسمية تعدادات HandJointType باستخدام البادئة HAND_JOINT_TYPE_ (I3f7cd)
  • تم نقل HandJointType إلى xr:arcore:arcore من xr:runtime:runtime. (Iadb9c، b/409058039)
  • تعرض Hand.State الآن java.nio.FloatBuffer مع الوضعيات المشتركة بتنسيق يتيح الوصول بسهولة إلى التطبيقات التي تركّز على الأداء. (I55e27)

الإصدار ‎1.0.0-alpha05

‫30 يوليو 2025

تم طرح ميزات androidx.xr.arcore:arcore:1.0.0-alpha05 وandroidx.xr.arcore:arcore-guava:1.0.0-alpha05 وandroidx.xr.arcore:arcore-rxjava3:1.0.0-alpha05. يتضمّن الإصدار ‎1.0.0-alpha05 هذه التعديلات.

الميزات الجديدة

  • أضِف getPrimaryHandSide ليتمكّن المطوّر من الحصول على معلومات الجانب الأيسر (I270bd).
  • إضافة واجهة برمجة تطبيقات للتحقّق من توفّر خدمة تحديد الموقع المرئي (VPS) المستندة إلى الموقع الجغرافي (I58573)
  • إضافة ARCore API لحزمة checkVpsAvailability (Idbded)
  • تمت إضافة دوال الإضافة stateFlowable إلى :xr:arcore:arcore-rxjava3 ليستخدمها مطوّرو Java. (I083aa، b/427247794)

تغييرات واجهة برمجة التطبيقات

  • تمت إعادة تسمية قيم Config *Mode لتعكس سلوكها. (I6d247، b/414648065)
  • لن يحتوي العنصر الرئيسي في ARCore (xr:arcore:arcore) إلا على واجهات برمجة تطبيقات غير متزامنة بنمط Kotlin. يمكن لمطوّري Java الاعتماد على مكتبة xr:arcore:arcore-rxjava3 للوصول إلى واجهات برمجة التطبيقات المتوافقة. (Ia525e، b/422794329)
  • سيحتوي العنصر الرئيسي في ARCore (xr:scenecore:scenecore) على واجهات برمجة تطبيقات غير متزامنة بنمط Kotlin فقط. يمكن لمطوّري Java الاعتماد على مكتبة xr:arcore:arcore-guava للوصول إلى واجهات برمجة التطبيقات المتوافقة. (Iffcb4، b/422773524)
  • تمت إضافة Anchor.persistAsync() إلى AnchorGuava ليستخدمها مطوّرو Java. (I4af1c، b/425984631)
  • تمت إضافة Earth.createAnchorOnSurfaceAsync(Session, Double, Double, Double, Quaternion, Surface) إلى EarthGuava ليستخدمها مطوّرو Java. (I66357، b/425992992)
  • سيستخدم مطوّرو Java دوال الإضافة GltfModel.createAsync في GltfModel.kt. سيتم حذف الدوال غير المتزامنة في GltfModel. (I0af60)
  • تستخدم هذه المكتبة الآن تعليقات توضيحية بشأن القيم الخالية من JSpecify، وهي تعليقات توضيحية خاصة باستخدام النوع. على مطوّري Kotlin استخدام وسيطة المترجم البرمجي التالية لفرض الاستخدام الصحيح: -Xjspecify-annotations=strict (هذه هي القيمة التلقائية بدءًا من الإصدار 2.1.0 من مترجم Kotlin البرمجي) (Ia8420، b/326456246)
  • تمت إضافة دوال الإضافة subscribeAsFlowable إلى :xr:arcore:arcore-rxjava3 ليستخدمها مطوّرو Java. (Id3e49، b/427277298)

الإصدار ‎1.0.0-alpha04

‫7 مايو 2025

تم طرح androidx.xr.arcore:arcore:1.0.0-alpha04. يتضمّن الإصدار ‎1.0.0-alpha04 هذه التعديلات.

تغييرات واجهة برمجة التطبيقات

  • تتطلّب المشاريع التي تم إصدارها باستخدام Kotlin 2.0 استخدام الإصدار 2.0.0 من KGP أو إصدار أحدث. (Idb6b5)
  • تم نقل TrackingState وHandJointType من ARCore إلى Runtime.
  • تم تغيير Hand.State.isActive (boolean) إلى Hand.State.trackingState (androidx.xr.runtime.TrackingState).
  • تعرض الدالة Anchor.load القيمة Anchor.AnchorLoadInvalidUuid إذا كان المعرّف الفريد العالمي (UUID) غير صالح.

الإصدار ‎1.0.0-alpha03

‫26 فبراير 2025

تم إصدار androidx.xr.arcore:arcore:1.0.0-alpha03 بدون أي تغييرات ملحوظة منذ آخر إصدار أولي. يتضمّن الإصدار ‎1.0.0-alpha03 هذه التعديلات.

الإصدار ‎1.0.0-alpha02

‫12 فبراير 2025

تم طرح androidx.xr.arcore:arcore:1.0.0-alpha02. يتضمّن الإصدار ‎1.0.0-alpha02 هذه التعديلات.

الميزات الجديدة

  • تمت إضافة ميزة تتبُّع اليد. استخدِم Hand.left وHand.right للوصول إلى معلومات التتبُّع.
  • إنّ واجهات برمجة التطبيقات التي تنشئ رابطًا ثابتًا (Anchor.create وAnchor.load وPlane.createAnchor) تعرض الآن AnchorCreateResult وتنفّذ AnchorCreateResourcesExhausted بشكل صحيح.

إصلاح الأخطاء

  • لم يعُد Anchor.detach يتسبّب في حدوث عطل فادح بسبب حالة تزامن مع سلسلة تعليمات تعديل الجلسة.
  • تطبيق Anchor.create أكثر ثباتًا عند تشغيله على محاكي

الإصدار ‎1.0.0-alpha01

‫12 ديسمبر 2024

تم طرح androidx.xr.arcore:arcore-* 1.0.0-alpha01.

ميزات الإصدار الأوّلي

تستوحي مكتبة "ARCore في Jetpack XR" تصميمها من مكتبة ARCore الحالية، وتوفّر إمكانات لدمج المحتوى الرقمي مع العالم الحقيقي. تتضمّن هذه المكتبة تتبُّع الحركة، وعناصر ثابتة، واختبارات تحديد المواقع، وتحديد الأسطح باستخدام التصنيف الدلالي (مثل الأرضيات والجدران وأسطح الطاولات). يمكنك الاطّلاع على دليل المطوّرين لمزيد من المعلومات حول استخدام ARCore for Jetpack XR.

  • Session: تستخدم حزمة ARCore for Jetpack XR ميزة Jetpack XR Runtime في الخلفية لتشغيل وظائفها. ستستخدم Session للتفاعل مع معظم واجهات برمجة التطبيقات ARCore for Jetpack XR، لذا يُرجى الاطّلاع على مستنداتها.

  • Plane: استخدِم الطائرات لفهم العالم من حولك. يحتوي كل مستوى على Label يصفه دلاليًا. يمكنك استخدام subscribe لتلقّي إشعارات بشأن آخر الطائرات التي تم رصدها أو state لتلقّي إشعارات بشأن التغييرات التي تطرأ على طائرة معيّنة.

  • Anchor: رابط بين كائن افتراضي وموقع جغرافي في العالم الحقيقي يمكن ربط نقاط الارتكاز بموقع جغرافي محدّد في المساحة (باستخدام create) أو Trackable (باستخدام createAnchor).

    • يمكن إعادة استخدام نقاط الارتكاز في الجلسات المتعدّدة. يمكنك استخدام persist لتخزينها، وgetPersistedAnchorUuids لإدراجها، وload لاستردادها. احرص على unpersist هذه الأجهزة عندما تتوقف عن استخدامها.

    • تتسم نقاط الارتكاز بإمكانية التشغيل التفاعلي بين ARCore for Jetpack XR وJetpack SceneCore. يمكنك إنشاء AnchorEntity باستخدام نقطة ربط أو، إذا كان لديك AnchorEntity حالي، يمكنك استخدام getAnchor لاسترداد نقطة الربط الأساسية.

    • تقديم تفاعلات طبيعية مع المستخدمين باستخدام hitTest يستخدم اختبار إصابة Ray لتحديد المحتوى الذي يتقاطع معه وإنشاء Anchor من ذلك الموقع الجغرافي. ننصحك بإجراء اختبار hitTest من InputEvent.

المشاكل المعروفة

  • قد يحدث تأخير بين وقت طلب إزالة unpersist ووقت إزالة معرّف UUID الخاص به من النتائج التي تعرضها getPersistedAnchorUuids.

  • لن تتحقّق الدالة create من توفّر موارد كافية في النظام لعرض نقاط ارتكاز جديدة. قد يؤدي إنشاء عدد كبير جدًا من نقاط الارتكاز إلى حدوث عطل.

  • لا تتوفّر حاليًا إمكانية الاحتفاظ بـ Anchor تم الاحتفاظ به سابقًا ثم تم إلغاء الاحتفاظ به.

  • يمكن استخدامها في المحاكي، ولكن قد لا يكون السلوك ثابتًا كما هو الحال عند التشغيل على جهاز فعلي. على وجه الخصوص، قد يتعذّر إجراء مكالمات إلى create ويظهر خطأ في الرمز البرمجي الأصلي ويتم إنهاء النشاط على الفور.

  • في ظروف معيّنة، قد يتم عرض الخطأ RuntimeException بشكل خاطئ عند استدعاء persist مع الرسالة "لم يتم حفظ نقطة الارتكاز". وفي هذه الظروف، ستظل الدالة تعمل بنجاح وسيتم حفظ نقطة الارتكاز. ننصحك بتضمين طلب persist في كتلة try كحلّ بديل.