XR_ANDROID_depth_texture
Name String
XR_ANDROID_depth_texture
نوع الإضافة
إضافة مثيل
رقم الإضافة المسجَّل
703
المراجعة
1
حالة التصديق
لم تتم المصادقة
الاعتماديات على الإضافات والإصدارات
تاريخ آخر تعديل
2024-09-11
حالة عنوان IP
ما مِن مطالبات معروفة بشأن الملكية الفكرية.
المساهمون
"سوشانت كولكارني"، Google
"كيرن أوفرتوف"، Google
"سبنسر كوين"، Google
"ليفانا تشين"، Google
نظرة عامة
يتيح هذا الامتداد للتطبيق طلب خرائط العمق للبيئة الواقعية المحيطة بسماعة الرأس والاستعلام عن دقة العمق المتوافقة عند الإنشاء.
تهدف هذه الإضافة إلى عرض بيانات العمق الأولية والسلسة من أجل الحجب واختبارات التفاعل والمهام المحدّدة الأخرى التي تستفيد من هندسة المشهد الدقيقة، مثل رصد الوجوه المزيفة.
ملاحظة
يتم إنشاء خرائط العمق بواسطة وقت التشغيل ومشاركتها مع التطبيق باستخدام XrDepthSwapchainANDROID . يجب ألا يغيّر وقت التشغيل دقة صور العمق التي يتم عرضها من خلال xrEnumerateDepthResolutionsANDROID طوال مدة تشغيل التطبيق.
الأذونات
يعرض هذا الامتداد نسيج عمق تم تصغير حجمه للحدّ من المخاوف بشأن معلومات تكشف الهوية الشخصية. يجب أن تتضمّن تطبيقات Android الإذن android.permission.SCENE_UNDERSTANDING_FINE في ملف البيان لأنّ هذه الإضافة تعرض هندسة البيئة. يُعدّ الإذن android.permission.SCENE_UNDERSTANDING_FINE إذنًا خطيرًا. يجب أن يطلب التطبيق الإذن أثناء التشغيل لاستخدام الوظائف التالية:
(مستوى الحماية: خطير)
فحص إمكانات النظام
يتم تعريف بنية XrSystemDepthTrackingPropertiesANDROID على النحو التالي:
typedef struct XrSystemDepthTrackingPropertiesANDROID {
XrStructureType type;
void* next;
XrBool32 supportsDepthTracking;
} XrSystemDepthTrackingPropertiesANDROID;
أوصاف الأعضاء
typeهو XrStructureType لهذه البنية.nextهوNULLأو مؤشر إلى البنية التالية في سلسلة البنية. لم يتم تحديد أي بنى من هذا النوع في OpenXR الأساسية أو في هذه الإضافة.-
supportsDepthTrackingهوXrBool32يشير إلى ما إذا كان النظام الحالي يتيح تتبُّع العمق.
يمكن لأحد التطبيقات التحقّق مما إذا كان النظام قادرًا على تتبُّع العمق من خلال توسيع XrSystemProperties باستخدام بنية XrSystemDepthTrackingPropertiesANDROID عند استدعاء xrGetSystemProperties .
إذا كانت بيئة التشغيل تعرض XR_FALSE للسمة supportsDepthTracking، يجب أن تعرض بيئة التشغيل XR_ERROR_FEATURE_UNSUPPORTED من xrCreateDepthSwapchainANDROID .
الاستخدام الصالح (الضمني)
- يجب تفعيل إضافة
XR_ANDROID_depth_textureقبل استخدام XrSystemDepthTrackingPropertiesANDROID - يجب أن يكون
typeXR_TYPE_SYSTEM_DEPTH_TRACKING_PROPERTIES_ANDROID - يجب أن تكون قيمة
nextهيNULLأو مؤشرًا صالحًا إلى البنية التالية في سلسلة البِنى
حلول لمشاكل عمق طلب البحث
يتم تعريف الدالة xrEnumerateDepthResolutionsANDROID على النحو التالي:
XrResult xrEnumerateDepthResolutionsANDROID(
XrSession session,
uint32_t resolutionCapacityInput,
uint32_t* resolutionCountOutput,
XrDepthCameraResolutionANDROID* resolutions);
أوصاف المَعلمات
-
sessionهو XrSession الذي يسرد دقة العمق المتوافقة. -
resolutionCapacityInputهي سعةresolutions، أو 0 لاسترداد السعة المطلوبة. resolutionCountOutputهو مؤشر إلى عددuint64_tresolutionsالمكتوب، أو مؤشر إلى السعة المطلوبة في حال عدم كفايةresolutionCapacityInput.-
resolutionsهو مؤشر إلى مصفوفة من XrDepthCameraResolutionANDROID، ولكن يمكن أن يكونNULLإذا كانresolutionCapacityInputهو0. - راجِع قسم مَعلمات حجم المخزن المؤقت للحصول على وصف تفصيلي حول استرداد حجم
resolutionsالمطلوب.
تعرض الدالة xrEnumerateDepthResolutionsANDROID درجات دقة العمق المتوافقة مع الجلسة الحالية. يجب أن تكون دقة العمق مرتبة من أعلى إعداد مفضّل لوقت التشغيل إلى أدناه. يجب أن يستخدم التطبيق أعلى إعداد مفضّل يتيحه لتحقيق أفضل أداء وجودة.
يجب أن تعرض أوقات التشغيل دائمًا محتويات المخزن المؤقت المتطابقة من هذا التعداد طوال مدة الجلسة.
الاستخدام الصالح (الضمني)
- يجب تفعيل إضافة
XR_ANDROID_depth_textureقبل استدعاء xrEnumerateDepthResolutionsANDROID - يجب أن يكون
sessionمعرّفًا صالحًا لـ XrSession - يجب أن يكون
resolutionCountOutputمؤشرًا إلى قيمةuint32_t - إذا لم يكن
resolutionCapacityInputهو0،resolutionsيجب أن يكون مؤشرًا إلى مصفوفة من قيمresolutionCapacityInputXrDepthCameraResolutionANDROID
رموز الإرجاع
XR_SUCCESSXR_SESSION_LOSS_PENDING
XR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_HANDLE_INVALIDXR_ERROR_INSTANCE_LOSTXR_ERROR_RUNTIME_FAILUREXR_ERROR_SESSION_LOSTXR_ERROR_SIZE_INSUFFICIENTXR_ERROR_VALIDATION_FAILURE
يصف تعداد XrDepthCameraResolutionANDROID درجات دقة العمق المتوافقة عند إنشاء XrDepthSwapchainANDROID .
typedef enum XrDepthCameraResolutionANDROID {
XR_DEPTH_CAMERA_RESOLUTION_80x80_ANDROID = 0,
XR_DEPTH_CAMERA_RESOLUTION_160x160_ANDROID = 1,
XR_DEPTH_CAMERA_RESOLUTION_320x320_ANDROID = 2,
XR_DEPTH_CAMERA_RESOLUTION_MAX_ENUM_ANDROID = 0x7FFFFFFF
} XrDepthCameraResolutionANDROID;
أوصاف القيم المُعدَّدة
XR_DEPTH_CAMERA_RESOLUTION_80x80_ANDROID— تبلغ دقة صور العمق والثقة 80x80.XR_DEPTH_CAMERA_RESOLUTION_160x160_ANDROID— تبلغ دقة صور العمق والثقة 160x160.XR_DEPTH_CAMERA_RESOLUTION_320x320_ANDROID— تبلغ دقة صور العمق والثقة 320x320.
إنشاء سلسلة تبديل العمق
XR_DEFINE_HANDLE(XrDepthSwapchainANDROID)
XrDepthSwapchainANDROID هو مقبض سلسلة تبديل العمق.
يتم تعريف الدالة xrCreateDepthSwapchainANDROID على النحو التالي:
XrResult xrCreateDepthSwapchainANDROID(
XrSession session,
const XrDepthSwapchainCreateInfoANDROID* createInfo,
XrDepthSwapchainANDROID* swapchain);
أوصاف المَعلمات
-
sessionهو XrSession الذي ينشئ سلسلة تبديل العمق. -
createInfoهو مؤشر إلى بنية XrDepthSwapchainCreateInfoANDROID تحتوي على مَعلمات سيتم استخدامها لإنشاء سلسلة التبديل. -
swapchainهو مؤشر إلى معرّف يتم فيه عرض XrDepthSwapchainANDROID الذي تم إنشاؤه.
يمكن للتطبيق استخدام الدالة xrCreateDepthSwapchainANDROID لإنشاء سلسلة تبديل لبيانات العمق تدير كلاً من صور العمق وصور الثقة.
- يجب أن تعرض بيئة التشغيل
XR_ERROR_FEATURE_UNSUPPORTEDإذا كان النظام لا يتيح تتبُّع العمق. - يجب أن تعرض بيئة التشغيل القيمة
XR_ERROR_PERMISSION_INSUFFICIENTإذا لم يتم منح الأذونات المطلوبة للتطبيق الذي يستدعيها. - يجب أن يعرض وقت التشغيل القيمة
XR_ERROR_VALIDATION_FAILUREإذا كانت درجة دقة العمق المحدّدة في XrDepthSwapchainCreateInfoANDROID غير متوافقة. - يجب أن ينشئ وقت التشغيل صورًا لمدى صحة العمق فقط عند ضبط وحدات البت المقابلة لـ
createInfoعند إنشاء سلسلة التبديل.
يمكن استخدام مقبض سلسلة تبديل العمق الذي تم عرضه لاحقًا في طلبات البيانات من واجهة برمجة التطبيقات. يجب تحرير مقبض XrDepthSwapchainANDROID في النهاية من خلال الدالة xrDestroyDepthSwapchainANDROID.
الاستخدام الصالح (الضمني)
- يجب تفعيل إضافة
XR_ANDROID_depth_textureقبل استدعاء xrCreateDepthSwapchainANDROID - يجب أن يكون
sessionمعرّفًا صالحًا لـ XrSession - يجب أن يكون
createInfoمؤشرًا إلى بنية XrDepthSwapchainCreateInfoANDROID صالحة - يجب أن يكون
swapchainمؤشرًا إلى مقبض XrDepthSwapchainANDROID
رموز الإرجاع
XR_SUCCESSXR_SESSION_LOSS_PENDING
XR_ERROR_FEATURE_UNSUPPORTEDXR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_HANDLE_INVALIDXR_ERROR_INSTANCE_LOSTXR_ERROR_LIMIT_REACHEDXR_ERROR_OUT_OF_MEMORYXR_ERROR_PERMISSION_INSUFFICIENTXR_ERROR_RUNTIME_FAILUREXR_ERROR_SESSION_LOST
يتم تعريف بنية XrDepthSwapchainCreateInfoANDROID على النحو التالي:
typedef struct XrDepthSwapchainCreateInfoANDROID {
XrStructureType type;
const void* next;
XrDepthCameraResolutionANDROID resolution;
XrDepthSwapchainCreateFlagsANDROID createFlags;
} XrDepthSwapchainCreateInfoANDROID;
أوصاف الأعضاء
typeهو XrStructureType لهذه البنية.nextهوNULLأو مؤشر إلى البنية التالية في سلسلة البنية. لم يتم تحديد أي بنى من هذا النوع في OpenXR الأساسية أو في هذه الإضافة.resolutionهي XrDepthCameraResolutionANDROID التي يتم إنشاء مواد العرض الخاصة بالعمق والثقة باستخدامها.-
createFlagsهي علامة واحدة أو أكثر من XrDepthSwapchainCreateFlagsANDROID .
يوفّر البنية XrDepthSwapchainCreateInfoANDROID خيارات إنشاء XrDepthSwapchainANDROID عند تمريرها إلى xrCreateDepthSwapchainANDROID .
الاستخدام الصالح (الضمني)
- يجب تفعيل إضافة
XR_ANDROID_depth_textureقبل استخدام XrDepthSwapchainCreateInfoANDROID - يجب أن يكون
typeXR_TYPE_DEPTH_SWAPCHAIN_CREATE_INFO_ANDROID - يجب أن تكون قيمة
nextهيNULLأو مؤشرًا صالحًا إلى البنية التالية في سلسلة البِنى - يجب أن تكون قيمة
resolutionقيمة صالحة XrDepthCameraResolutionANDROID - يجب أن يكون
createFlagsمجموعة صالحة من قيم XrDepthSwapchainCreateFlagBitsANDROID - يجب ألا يكون
createFlags0
تحدّد XrDepthSwapchainCreateFlagsANDROID خيارات إنشاء XrDepthSwapchainANDROID .
typedef XrFlags64 XrDepthSwapchainCreateFlagsANDROID;
يتم تحديد وحدات البت الصالحة لـ XrDepthSwapchainCreateFlagsANDROID من خلال XrDepthSwapchainCreateFlagBitsANDROID، ويتم تحديدها على النحو التالي:
// Flag bits for XrDepthSwapchainCreateFlagsANDROID
static const XrDepthSwapchainCreateFlagsANDROID XR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_DEPTH_IMAGE_BIT_ANDROID = 0x00000001;
static const XrDepthSwapchainCreateFlagsANDROID XR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_CONFIDENCE_IMAGE_BIT_ANDROID = 0x00000002;
static const XrDepthSwapchainCreateFlagsANDROID XR_DEPTH_SWAPCHAIN_CREATE_RAW_DEPTH_IMAGE_BIT_ANDROID = 0x00000004;
static const XrDepthSwapchainCreateFlagsANDROID XR_DEPTH_SWAPCHAIN_CREATE_RAW_CONFIDENCE_IMAGE_BIT_ANDROID = 0x00000008;
أوصاف الأعلام
-
XR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_DEPTH_IMAGE_BIT_ANDROID: يشير إلى أنّ سلسلة التبديل ستوفّر صورًا سلسة للعمق. -
XR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_CONFIDENCE_IMAGE_BIT_ANDROID: يشير إلى أنّ سلسلة التبديل ستوفّر صورًا سلسة لثقة العمق. -
XR_DEPTH_SWAPCHAIN_CREATE_RAW_DEPTH_IMAGE_BIT_ANDROID: يشير إلى أنّ سلسلة التبديل ستوفّر صورًا أولية للعمق. -
XR_DEPTH_SWAPCHAIN_CREATE_RAW_CONFIDENCE_IMAGE_BIT_ANDROID: يشير إلى أنّ سلسلة التبديل ستوفّر صورًا أولية لمدى صحة بيانات العمق.
يتم تعريف الدالة xrDestroyDepthSwapchainANDROID على النحو التالي:
XrResult xrDestroyDepthSwapchainANDROID(
XrDepthSwapchainANDROID swapchain);
أوصاف المَعلمات
-
swapchainهو معرّف XrDepthSwapchainANDROID تم إنشاؤه سابقًا بواسطة xrCreateDepthSwapchainANDROID .
تدمّر الدالة xrDestroyDepthSwapchainANDROID سلسلة تبديل العمق. بعد انتهاء هذه المكالمة، قد يحرّر وقت التشغيل جميع الذاكرة والموارد ذات الصلة.
الاستخدام الصالح (الضمني)
- يجب تفعيل الإضافة
XR_ANDROID_depth_textureقبل استدعاء xrDestroyDepthSwapchainANDROID - يجب أن يكون
swapchainمقودًا صالحًا XrDepthSwapchainANDROID
أمان سلاسل المحادثات
- يجب مزامنة الوصول إلى
swapchainوأي أسماء مستخدمين للأطفال خارجيًا
رموز الإرجاع
XR_SUCCESS
XR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_HANDLE_INVALID
الوصول إلى خرائط العمق
يتم تعريف الدالة xrEnumerateDepthSwapchainImagesANDROID على النحو التالي:
XrResult xrEnumerateDepthSwapchainImagesANDROID(
XrDepthSwapchainANDROID depthSwapchain,
uint32_t depthImageCapacityInput,
uint32_t* depthImageCountOutput,
XrDepthSwapchainImageANDROID* depthImages);
أوصاف المَعلمات
-
depthSwapchainهو XrDepthSwapchainANDROID الذي يتم الحصول على الصور منه. depthImageCapacityInputهي سعة مصفوفةdepthImages، أو 0 للإشارة إلى طلب استرداد السعة المطلوبة.depthImageCountOutputهو مؤشر إلى عدد وحداتdepthImagesالتي تمّت كتابتها، أو مؤشر إلى السعة المطلوبة في حال عدم كفايةdepthImageCapacityInput.-
depthImagesهو مؤشر إلى مصفوفة من بنى XrDepthSwapchainImageANDROID. يمكن أن تكون القيمةNULLإذا كانت قيمةdepthImageCapacityInputهي 0. - راجِع قسم مَعلمات حجم المخزن المؤقت للحصول على وصف تفصيلي حول استرداد حجم
depthImagesالمطلوب.
تعبئ الدالة xrEnumerateDepthSwapchainImagesANDROID مصفوفة من بنى XrDepthSwapchainImageANDROID. يجب أن تكون الموارد ثابتة وصالحة طوال مدة XrDepthSwapchainANDROID . تعمل هذه الدالة بشكل مشابه للدالة xrEnumerateSwapchainImages .
يجب أن يعرض وقت التشغيل دائمًا محتويات المخزن المؤقت المتطابقة من هذا التعداد طوال مدة سلسلة التبديل.
الاستخدام الصالح (الضمني)
- يجب تفعيل إضافة
XR_ANDROID_depth_textureقبل استدعاء xrEnumerateDepthSwapchainImagesANDROID - يجب أن يكون
depthSwapchainمقودًا صالحًا XrDepthSwapchainANDROID - يجب أن يكون
depthImageCountOutputمؤشرًا إلى قيمةuint32_t - إذا لم يكن
depthImageCapacityInputهو0،depthImagesيجب أن يكون مؤشرًا إلى مصفوفة من بنىdepthImageCapacityInputXrDepthSwapchainImageANDROID
رموز الإرجاع
XR_SUCCESSXR_SESSION_LOSS_PENDING
XR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_HANDLE_INVALIDXR_ERROR_INSTANCE_LOSTXR_ERROR_RUNTIME_FAILUREXR_ERROR_SESSION_LOSTXR_ERROR_SIZE_INSUFFICIENTXR_ERROR_VALIDATION_FAILURE
يتم تعريف بنية XrDepthSwapchainImageANDROID على النحو التالي:
typedef struct XrDepthSwapchainImageANDROID {
XrStructureType type;
void* next;
const float* rawDepthImage;
const uint8_t* rawDepthConfidenceImage;
const float* smoothDepthImage;
const uint8_t* smoothDepthConfidenceImage;
} XrDepthSwapchainImageANDROID;
أوصاف الأعضاء
typeهو XrStructureType لهذه البنية.nextهوNULLأو مؤشر إلى البنية التالية في سلسلة البنية. لم يتم تحديد أي بنى من هذا النوع في OpenXR الأساسية أو في هذه الإضافة.-
rawDepthImageهوNULLأو المؤشر إلى صور العمق الأولية لكل من العرضَين الأيمن والأيسر اللذين تم تخصيصهما بواسطة وقت التشغيل. تكون القيم بوحدة المتر. القيم الخاصة: يشير0.0إلى بكسل عمق غير صالح أو فارغ في العمق الأولي، ويشيرInfإلى عمق معروف بعيد جدًا. -
rawDepthConfidenceImageهوNULLأو المؤشر إلى صور الثقة في العمق الأولي لكل من العرضَين الأيسر والأيمن اللذين تم تخصيصهما بواسطة وقت التشغيل. -
smoothDepthImageهوNULLأو المؤشر إلى صور العمق السلسة لكل من العرضَين الأيمن والأيسر اللذين يخصّصهما وقت التشغيل. تكون القيم بوحدة المتر. القيم الخاصة: يشير0.0إلى بكسل عمق غير صالح أو فارغ في العمق السلس، ويشيرInfإلى عمق معروف بعيد جدًا. -
smoothDepthConfidenceImageهوNULLأو المؤشر إلى صور ثقة العمق السلسة لكل من العرضين الأيسر والأيمن التي يخصّصها وقت التشغيل.
لن تكون مؤشرات مخزن الصور المؤقت صالحة إلا أثناء عمر سلسلة التبديل. بعد إيقاف سلسلة التبديل، سيتم اعتبار المؤشرات معلّقة.
يمثّل XrDepthSwapchainImageANDROID صور العمق من XrDepthSwapchainANDROID قابلة للقراءة، ويتم تخصيصها كما هو موضّح في XrDepthSwapchainCreateInfoANDROID :: resolution وXrDepthSwapchainCreateInfoANDROID :: createFlags أثناء استدعاء xrCreateDepthSwapchainANDROID . لكل صورة عمق:
- يتم ترتيب قيم الصور في الذاكرة بترتيب الصفوف الرئيسية، بدون مساحة متروكة بين الصفوف.
- القيمة الأولى هي أعلى اليسار والقيمة الأخيرة هي أسفل اليمين.
- يتم تحديد حجم الذاكرة المشار إليها من خلال قيمة xrEnumerateDepthSwapchainImagesANDROID ويتم ضبطها من خلال XrDepthSwapchainCreateInfoANDROID ::
resolutionأثناء استدعاء xrCreateDepthSwapchainANDROID . على سبيل المثال، إذا كانت قيمة XrDepthSwapchainCreateInfoANDROID ::resolutionهيXR_DEPTH_CAMERA_RESOLUTION_160x160_ANDROID، سيكون حجم صور العمق2*160*160*sizeof(float). - يجب أن تكون قيمة
rawDepthImageهيNULLإذا لم يتضمّن XrDepthSwapchainCreateInfoANDROID ::createFlagsالقيمةXR_DEPTH_SWAPCHAIN_CREATE_RAW_DEPTH_IMAGE_BIT_ANDROID. - يجب أن تكون قيمة
rawDepthConfidenceImageهيNULLإذا لم يتضمّن XrDepthSwapchainCreateInfoANDROID ::createFlagsالقيمةXR_DEPTH_SWAPCHAIN_CREATE_RAW_CONFIDENCE_IMAGE_BIT_ANDROID. - يجب أن تكون قيمة
smoothDepthImageهيNULLإذا لم يتضمّن XrDepthSwapchainCreateInfoANDROID ::createFlagsالقيمةXR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_DEPTH_IMAGE_BIT_ANDROID. - يجب أن تكون قيمة
smoothDepthImageهيNULLإذا لم يتضمّن XrDepthSwapchainCreateInfoANDROID ::createFlagsالقيمةXR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_CONFIDENCE_IMAGE_BIT_ANDROID.
الاستخدام الصالح (الضمني)
- يجب تفعيل إضافة
XR_ANDROID_depth_textureقبل استخدام XrDepthSwapchainImageANDROID - يجب أن يكون
typeXR_TYPE_DEPTH_SWAPCHAIN_IMAGE_ANDROID - يجب أن تكون قيمة
nextهيNULLأو مؤشرًا صالحًا إلى البنية التالية في سلسلة البِنى
يتم تعريف الدالة xrAcquireDepthSwapchainImagesANDROID على النحو التالي:
XrResult xrAcquireDepthSwapchainImagesANDROID(
XrDepthSwapchainANDROID depthSwapchain,
const XrDepthAcquireInfoANDROID* acquireInfo,
XrDepthAcquireResultANDROID* acquireResult);
أوصاف المَعلمات
-
depthSwapchainهو مقبض XrDepthSwapchainANDROID لصورة العمق. -
acquireInfoهو XrDepthAcquireInfoANDROID يحتوي على معلومات حول كيفية الحصول على صورة العمق. -
acquireResultهو XrDepthAcquireResultANDROID الذي تم عرضه ويحتوي على معلومات عن صورة العمق التي تم الحصول عليها.
يمكن للتطبيقات استخدام الدالة xrAcquireDepthSwapchainImagesANDROID للحصول على أحدث فهرس متاح لصورة سلسلة التبديل، أي XrDepthAcquireResultANDROID :: acquiredIndex، في مصفوفة XrDepthSwapchainImageANDROID التي تم تعدادها بواسطة xrEnumerateDepthSwapchainImagesANDROID. يحتوي XrDepthAcquireResultANDROID الذي يتم عرضه أيضًا على معلومات أخرى، مثل مجال الرؤية والوضع، وهي معلومات ضرورية لتفسير بيانات العمق. يمكنك قراءة البيانات من الخانة التي تم الحصول عليها في مصفوفة الصور إلى حين إجراء عملية استدعاء أخرى للدالة xrAcquireDepthSwapchainImagesANDROID .
يجب عدم إجراء أكثر من طلب واحد إلى xrAcquireDepthSwapchainImagesANDROID بين أي زوج من طلبات xrBeginFrame وxrEndFrame المتطابقة في إحدى الجلسات.
- قد يحظر وقت التشغيل إذا كان لا يزال يستخدم صور swapchain التي تم الحصول عليها سابقًا.
- يجب أن تعرض بيئة التشغيل القيمة
XR_ERROR_CALL_ORDER_INVALIDإذا تم استدعاء xrAcquireDepthSwapchainImagesANDROID قبل xrBeginFrame أو بعد xrEndFrame . - يجب أن تعرض بيئة التشغيل القيمة
XR_ERROR_LIMIT_REACHEDإذا تم استدعاء xrAcquireDepthSwapchainImagesANDROID أكثر من مرة في كل إطار، أي في جلسة قيد التشغيل، بعد استدعاء xrBeginFrame لم يتم ربطه بـ xrEndFrame. - قد تعرض بيئة التشغيل القيمة
XR_ERROR_DEPTH_NOT_AVAILABLE_ANDROIDإذا لم تتوفّر بيانات عمق البيئة بعد. في حال حدوث ذلك، يجب أن يعيد التطبيق استدعاء الدالة xrAcquireDepthSwapchainImagesANDROID في إطار لاحق.
الاستخدام الصالح (الضمني)
- يجب تفعيل إضافة
XR_ANDROID_depth_textureقبل استدعاء xrAcquireDepthSwapchainImagesANDROID - يجب أن يكون
depthSwapchainمقبضًا صالحًا XrDepthSwapchainANDROID - يجب أن يكون
acquireInfoمؤشرًا إلى بنية XrDepthAcquireInfoANDROID صالحة - يجب أن يكون
acquireResultمؤشرًا إلى بنية XrDepthAcquireResultANDROID
رموز الإرجاع
XR_SUCCESSXR_SESSION_LOSS_PENDING
XR_ERROR_CALL_ORDER_INVALIDXR_ERROR_DEPTH_NOT_AVAILABLE_ANDROIDXR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_HANDLE_INVALIDXR_ERROR_INSTANCE_LOSTXR_ERROR_LIMIT_REACHEDXR_ERROR_RUNTIME_FAILUREXR_ERROR_SESSION_LOSTXR_ERROR_TIME_INVALIDXR_ERROR_VALIDATION_FAILURE
يتم تعريف بنية XrDepthAcquireInfoANDROID على النحو التالي:
typedef struct XrDepthAcquireInfoANDROID {
XrStructureType type;
const void* next;
XrSpace space;
XrTime displayTime;
} XrDepthAcquireInfoANDROID;
أوصاف الأعضاء
typeهو XrStructureType لهذه البنية.nextهوNULLأو مؤشر إلى البنية التالية في سلسلة البنية. لم يتم تحديد أي بنى من هذا النوع في OpenXR الأساسية أو في هذه الإضافة.-
spaceهو XrSpace يحدّد الإطار المرجعي للوضعية التي تم إرجاعها في XrDepthAcquireResultANDROID ::views. -
displayTimeهوXrTimeيحدّد الوقت المستخدَم لاحتساب الوضع الذي تم عرضه في XrDepthAcquireResultANDROID ::views. يجب أن تتجاوز التطبيقات وقت العرض المتوقّع للإطار الحالي.
الاستخدام الصالح (الضمني)
- يجب تفعيل إضافة
XR_ANDROID_depth_textureقبل استخدام XrDepthAcquireInfoANDROID - يجب أن يكون
typeXR_TYPE_DEPTH_ACQUIRE_INFO_ANDROID - يجب أن تكون قيمة
nextهيNULLأو مؤشرًا صالحًا إلى البنية التالية في سلسلة البِنى - يجب أن يكون
spaceمقدارًا صالحًا من XrSpace
يتم تعريف بنية XrDepthAcquireResultANDROID على النحو التالي:
typedef struct XrDepthAcquireResultANDROID {
XrStructureType type;
const void* next;
uint32_t acquiredIndex;
XrTime exposureTimestamp;
XrDepthViewANDROID views[2];
} XrDepthAcquireResultANDROID;
أوصاف الأعضاء
typeهو XrStructureType لهذه البنية.nextهوNULLأو مؤشر إلى البنية التالية في سلسلة البنية. لم يتم تحديد أي بنى من هذا النوع في OpenXR الأساسية أو في هذه الإضافة.acquiredIndexهو فهرس المادة التي تم الحصول عليها في مصفوفة XrDepthSwapchainImageANDROID التي تم تعدادها بواسطة xrEnumerateDepthSwapchainImagesANDROID .exposureTimestampهوXrTimeالذي يحدّد الوقت الذي تم فيه التقاط خريطة العمق.-
viewsهو مصفوفة من عنصرين من النوع XrDepthViewANDROID، أحدهما لكل عين، حيث يكون الفهرس 0 للعين اليسرى والفهرس 1 للعين اليمنى.
الاستخدام الصالح (الضمني)
- يجب تفعيل إضافة
XR_ANDROID_depth_textureقبل استخدام XrDepthAcquireResultANDROID - يجب أن يكون
typeXR_TYPE_DEPTH_ACQUIRE_RESULT_ANDROID - يجب أن تكون قيمة
nextهيNULLأو مؤشرًا صالحًا إلى البنية التالية في سلسلة البِنى - يجب أن يكون أي عنصر من
viewsبنية XrDepthViewANDROID صالحة
يتم تعريف بنية XrDepthViewANDROID على النحو التالي:
typedef struct XrDepthViewANDROID {
XrStructureType type;
const void* next;
XrFovf fov;
XrPosef pose;
} XrDepthViewANDROID;
أوصاف الأعضاء
typeهو XrStructureType لهذه البنية.nextهوNULLأو مؤشر إلى البنية التالية في سلسلة البنية. لم يتم تحديد أي بنى من هذا النوع في OpenXR الأساسية أو في هذه الإضافة.-
fovهو XrFovf يحدّد مجال الرؤية المستخدَم لإنشاء هذا العرض. لا يتم قلب العرض أفقيًا أو عموديًا أبدًا. -
poseهو XrPosef يحدّد الوضع الذي تم عرض خريطة العمق منه. يتم تحديد الإطار المرجعي في XrDepthAcquireInfoANDROID .
الاستخدام الصالح (الضمني)
- يجب تفعيل إضافة
XR_ANDROID_depth_textureقبل استخدام XrDepthViewANDROID - يجب أن يكون
typeXR_TYPE_DEPTH_VIEW_ANDROID - يجب أن تكون قيمة
nextهيNULLأو مؤشرًا صالحًا إلى البنية التالية في سلسلة البِنى
مثال على الرمز البرمجي لتتبُّع العمق
يوضّح نموذج الرمز البرمجي التالي كيفية الحصول على صور العمق واستخدام قيم العمق لربط إحداثيات صورة العمق بمساحة المشهد.
XrInstance instance; // previously initialized
XrSystemId systemId; // previously initialized
XrSession session; // previously initialized
XrSpace stageSpace; // space created for XR_REFERENCE_SPACE_TYPE_STAGE.
// The function pointers are previously initialized using xrGetInstanceProcAddr.
PFN_xrCreateDepthSwapchainANDROID xrCreateDepthSwapchainANDROID; // previously initialized
PFN_xrDestroyDepthSwapchainANDROID xrDestroyDepthSwapchainANDROID; // previously initialized
PFN_xrEnumerateDepthSwapchainImagesANDROID xrEnumerateDepthSwapchainImagesANDROID; // previously initialized
PFN_xrEnumerateDepthResolutionsANDROID xrEnumerateDepthResolutionsANDROID; // previously initialized
PFN_xrAcquireDepthSwapchainImagesANDROID xrAcquireDepthSwapchainImagesANDROID; // previously initialized
float tanf(float);
// Inspect system capability
XrSystemProperties properties{XR_TYPE_SYSTEM_PROPERTIES};
XrSystemDepthTrackingPropertiesANDROID depthTrackingProperties{XR_TYPE_SYSTEM_DEPTH_TRACKING_PROPERTIES_ANDROID};
properties.next = &depthTrackingProperties;
CHK_XR(xrGetSystemProperties(instance, systemId, &properties));
if (!depthTrackingProperties.supportsDepthTracking) {
// depth tracking is not supported.
return;
}
// Query the supported depth resolution.
XrDepthCameraResolutionANDROID supportedDepthResolution;
uint32_t supportedResolutionCount = 0;
CHK_XR(xrEnumerateDepthResolutionsANDROID(
session, 1, &supportedResolutionCount, &supportedDepthResolution));
// Define metadata to access the raw and smooth depth along with confidences.
XrDepthSwapchainCreateInfoANDROID swapchainCreateInfo = {
.type = XR_TYPE_DEPTH_SWAPCHAIN_CREATE_INFO_ANDROID,
.next = nullptr,
// Use the resolution supported by the runtime.
.resolution = supportedDepthResolution,
.createFlags =
XR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_DEPTH_IMAGE_BIT_ANDROID |
XR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_CONFIDENCE_IMAGE_BIT_ANDROID |
XR_DEPTH_SWAPCHAIN_CREATE_RAW_DEPTH_IMAGE_BIT_ANDROID |
XR_DEPTH_SWAPCHAIN_CREATE_RAW_CONFIDENCE_IMAGE_BIT_ANDROID,
};
XrDepthSwapchainANDROID depthSwapchain;
CHK_XR(xrCreateDepthSwapchainANDROID(
session, &swapchainCreateInfo, &depthSwapchain));
// Enumerate depth images.
uint32_t imageCountOutput = 0;
CHK_XR(xrEnumerateDepthSwapchainImagesANDROID(
depthSwapchain, 0, &imageCountOutput, nullptr));
std::vector<XrDepthSwapchainImageANDROID> depthImages(imageCountOutput);
for (int i = 0; i < imageCountOutput; i++) {
depthImages[i].type = XR_TYPE_DEPTH_SWAPCHAIN_IMAGE_ANDROID;
}
CHK_XR(xrEnumerateDepthSwapchainImagesANDROID(
depthSwapchain, imageCountOutput, &imageCountOutput, depthImages.data()));
while (1) {
// ...
// For every frame in frame loop
// ...
XrFrameState frameState; // previously returned from xrWaitFrame
const XrTime time = frameState.predictedDisplayTime;
XrDepthAcquireInfoANDROID acquireInfo = {
.type = XR_TYPE_DEPTH_ACQUIRE_INFO_ANDROID,
.space = stageSpace,
.displayTime = time
};
XrDepthAcquireResultANDROID acquireResult = {
.type = XR_TYPE_DEPTH_ACQUIRE_RESULT_ANDROID,
};
CHK_XR(xrAcquireDepthSwapchainImagesANDROID(
depthSwapchain, &acquireInfo, &acquireResult));
// Each value in a depth image corresponds to a point in the real world.
// The sample code below shows how to find the stageSpace position of
// the point corresponding to a particular value in the depth image.
// For this sample code, assume we are using a right handed coordinate system
// with +X to the right, +Y up and -Z forward.
XrDepthSwapchainImageANDROID *image =
&depthImages[acquireResult.acquiredIndex];
// Assume supported resolution is XR_DEPTH_CAMERA_RESOLUTION_160x160_ANDROID.
const int imageResolution = 160;
int imageY = 80; // value in [0, imageResolution)
int imageX = 80; // value in [0, imageResolution)
// Get depth value from left eye.
// A right depth value is obtained with the following expression:
// depthR = image->rawDepthImage[imageResolution*imageResolution+i*imageResolution+j]
float depthL = image->rawDepthImage[imageY*imageResolution + imageX];
XrDepthViewANDROID viewL = acquireResult.views[0];
float tanL = tanf(viewL.fov.angleLeft);
float tanR = tanf(viewL.fov.angleRight);
float tanU = tanf(viewL.fov.angleUp);
float tanD = tanf(viewL.fov.angleDown);
float s = (imageX + 0.5f) / (float)imageResolution;
float t = (imageY + 0.5f) / (float)imageResolution;
// Calculate the depth camera space position of the point
// corresponding to this depth value.
XrVector3f posInCameraSpace;
posInCameraSpace.z = -depthL;
posInCameraSpace.x = (tanL + (tanR - tanL)*s)*depthL;
posInCameraSpace.y = (tanD + (tanU - tanD)*t)*depthL;
XrPosef depthCameraPoseL = viewL.pose;
// Transform posInCameraSpace by depthCameraPoseL
// ...
// Finish frame loop
// ...
}
أنواع العناصر الجديدة
الأوامر الجديدة
- xrAcquireDepthSwapchainImagesANDROID
- xrCreateDepthSwapchainANDROID
- xrDestroyDepthSwapchainANDROID
- xrEnumerateDepthResolutionsANDROID
- xrEnumerateDepthSwapchainImagesANDROID
المنشآت الجديدة
- XrDepthAcquireInfoANDROID
- XrDepthAcquireResultANDROID
- XrDepthSwapchainCreateInfoANDROID
- XrDepthSwapchainImageANDROID
- XrDepthViewANDROID
تمديد XrSystemProperties :
عمليات التعداد الجديدة
New Bitmasks
ثوابت التعداد الجديدة
XR_ANDROID_DEPTH_TEXTURE_EXTENSION_NAMEXR_ANDROID_depth_texture_SPEC_VERSIONتمديد XrObjectType :
XR_OBJECT_TYPE_DEPTH_SWAPCHAIN_ANDROID
تمديد XrResult :
XR_ERROR_DEPTH_NOT_AVAILABLE_ANDROID
توسيع XrStructureType :
XR_TYPE_DEPTH_ACQUIRE_INFO_ANDROIDXR_TYPE_DEPTH_ACQUIRE_RESULT_ANDROIDXR_TYPE_DEPTH_SWAPCHAIN_CREATE_INFO_ANDROIDXR_TYPE_DEPTH_SWAPCHAIN_IMAGE_ANDROIDXR_TYPE_DEPTH_VIEW_ANDROIDXR_TYPE_SYSTEM_DEPTH_TRACKING_PROPERTIES_ANDROID
المشاكل
سجلّ التعديلات
المراجعة 1، 09-09-2024 (Levana Chen)
- الوصف الأوّلي للإضافة