Name String
XR_ANDROID_depth_texture
סוג התוסף
תוסף למכונה
מספר תוסף רשום
703
גרסה
1
תלות בתוספים ובגרסאות
תאריך השינוי האחרון
2024-09-11
סטטוס כתובת ה-IP
לא ידוע על תלונות על הפרת זכויות יוצרים בנושא כתובת IP.
שותפים ביצירת התוכן
Sushant Kulkarni, Google
קארן אוברטורף (Cairn Overturf), Google
ספנסר קווין (Spencer Quin), Google
לונן צ'ן, Google
סקירה כללית
התוסף הזה מאפשר לאפליקציה לבקש מפות עומק של הסביבה בעולם האמיתי סביב ה-VR, ולבצע שאילתה לגבי רזולוציות עומק נתמכות בזמן היצירה.
התוסף הזה נועד לחשוף עומק גולמי וחלק לצורך חסימה, בדיקות היטים ומשימות ספציפיות אחרות שמשתמשות בגיאומטריה מדויקת של סצנה, למשל זיהוי פנים מזויפים.
בדיקת יכולות המערכת
המבנה XrSystemDepthTrackingPropertiesANDROID מוגדר כך:
typedef struct XrSystemDepthTrackingPropertiesANDROID {
XrStructureType type;
const void* next;
XrBool32 supportsDepthTracking;
} XrSystemDepthTrackingPropertiesANDROID;
תיאורי חברים
typeהוא XrStructureType של המבנה הזה.nextהואNULLאו הפניה למבנה הבא בשרשרת המבנים. אין מבנים כאלה מוגדרים ב-OpenXR או בתוסף הזה.supportsDepthTrackingהואXrBool32שמציין אם המערכת הנוכחית תומכת במעקב עומק.
כדי לבדוק אם המערכת מסוגלת לעקוב אחרי עומק, אפליקציה יכולה להרחיב את המבנה XrSystemProperties באמצעות המבנה XrSystemDepthTrackingPropertiesANDROID בזמן הקריאה ל-xrGetSystemProperties.
שימוש תקין (מרומז)
- חובה להפעיל את התוסף
XR_ANDROID_depth_textureלפני שמשתמשים ב-XrSystemDepthTrackingPropertiesANDROID - הערך של
typeחייב להיותXR_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חייב להיות הפניה למערך שלresolutionCapacityInputערכים מסוג XrDepthCameraResolutionANDROID
קודי החזרה
XR_SUCCESSXR_SESSION_LOSS_PENDING
XR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_VALIDATION_FAILUREXR_ERROR_RUNTIME_FAILUREXR_ERROR_HANDLE_INVALIDXR_ERROR_INSTANCE_LOSTXR_ERROR_SESSION_LOSTXR_ERROR_SIZE_INSUFFICIENT
המאפיין המסווג 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
} 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 הוא ידית של swapchain עומק.
הפונקציה xrCreateDepthSwapchainANDROID מוגדרת כך:
XrResult xrCreateDepthSwapchainANDROID(
XrSession session,
const XrDepthSwapchainCreateInfoANDROID* createInfo,
XrDepthSwapchainANDROID* swapchain);
תיאורי פרמטרים
sessionהוא XrSession שיוצר את שרשרת ה-swap של העומק.createInfoהוא הפניה למבנה XrDepthSwapchainCreateInfoANDROID שמכיל פרמטרים שישמשו ליצירת שרשרת ההחלפה.swapchainהוא הפניה למזהה שבו מוחזר הערך שנוצר של XrDepthSwapchainANDROID.
האפליקציה יכולה להשתמש בפונקציה xrCreateDepthSwapchainANDROID כדי ליצור שרשרת תמונות עומק שמנהלת גם תמונות עומק וגם תמונות אמינות.
יכול להיות שבהמשך ייעשה שימוש במזהה של שרשרת ה-swap של העומק שהוחזרה בקריאות ל-API. צריך לפנות את ה-handle של XrDepthSwapchainANDROID בסופו של דבר באמצעות הפונקציה xrDestroyDepthSwapchainANDROID.
שימוש תקין (מרומז)
- חובה להפעיל את התוסף
XR_ANDROID_depth_textureלפני שמפעילים את xrCreateDepthSwapchainANDROID sessionחייב להיות מזהה XrSession תקיןcreateInfoחייב להיות הפניה למבנה תקין של XrDepthSwapchainCreateInfoANDROIDswapchainחייב להיות הפניה למזהה של XrDepthSwapchainANDROID
קודי החזרה
XR_SUCCESSXR_SESSION_LOSS_PENDING
XR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_RUNTIME_FAILUREXR_ERROR_INSTANCE_LOSTXR_ERROR_SESSION_LOSTXR_ERROR_OUT_OF_MEMORYXR_ERROR_HANDLE_INVALIDXR_ERROR_LIMIT_REACHED
המבנה 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 - הערך של
typeחייב להיותXR_TYPE_DEPTH_SWAPCHAIN_CREATE_INFO_ANDROID nextחייב להיותNULLאו מצביע תקין למבנה הבא בשרשרת המבנים- הערך
resolutionחייב להיות ערך חוקי של XrDepthCameraResolutionANDROID createFlagsחייב להיות שילוב תקין של ערכים של XrDepthSwapchainCreateFlagBitsANDROID- הערך של
createFlagsלא יכול להיות 0
המאפיין 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;
הפונקציה xrDestroyDepthSwapchainANDROID מוגדרת כך:
XrResult xrDestroyDepthSwapchainANDROID(
XrDepthSwapchainANDROID swapchain);
תיאורי פרמטרים
swapchainהוא אחיזה של XrDepthSwapchainANDROID שנוצרה בעבר על ידיxrCreateDepthSwapchainANDROID.
הפונקציה xrDestroyDepthSwapchainANDROID משמידה את ה-swapchain של העומק.
שימוש תקין (מרומז)
- חובה להפעיל את התוסף
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חייב להיות הפניה למערך שלdepthImageCapacityInputמבנים מסוג XrDepthSwapchainImageANDROID
קודי החזרה
XR_SUCCESSXR_SESSION_LOSS_PENDING
XR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_VALIDATION_FAILUREXR_ERROR_RUNTIME_FAILUREXR_ERROR_HANDLE_INVALIDXR_ERROR_INSTANCE_LOSTXR_ERROR_SESSION_LOSTXR_ERROR_SIZE_INSUFFICIENT
המבנה 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. לדוגמה, אם הערך של
resolutionהואXR_DEPTH_CAMERA_RESOLUTION_160x160_ANDROID, גודל קובצי התמונות של העומק יהיה2*160*160*sizeof(float). - הערך של
rawDepthImageחייב להיותNULLאםXR_DEPTH_SWAPCHAIN_CREATE_RAW_DEPTH_IMAGE_BIT_ANDROIDלא הוגדר ב-XrDepthSwapchainCreateInfoANDROID::createFlags. - הערך של
rawDepthConfidenceImageחייב להיותNULLאםXR_DEPTH_SWAPCHAIN_CREATE_RAW_CONFIDENCE_IMAGE_BIT_ANDROIDלא הוגדר ב-XrDepthSwapchainCreateInfoANDROID::createFlags. - הערך של
smoothDepthImageחייב להיותNULLאםXR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_DEPTH_IMAGE_BIT_ANDROIDלא הוגדר ב-XrDepthSwapchainCreateInfoANDROID::createFlags. - הערך של
smoothDepthConfidenceImageחייב להיותNULLאםXR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_CONFIDENCE_IMAGE_BIT_ANDROIDלא הוגדר ב-XrDepthSwapchainCreateInfoANDROID::createFlags.
שימוש תקין (מרומז)
- חובה להפעיל את התוסף
XR_ANDROID_depth_textureלפני שמשתמשים ב-XrDepthSwapchainImageANDROID - הערך של
typeחייב להיותXR_TYPE_DEPTH_SWAPCHAIN_IMAGE_ANDROID nextחייב להיותNULLאו מצביע תקין למבנה הבא בשרשרת המבנים
הפונקציה xrAcquireDepthSwapchainImagesANDROID מוגדרת בתור:
XrResult xrAcquireDepthSwapchainImagesANDROID(
XrDepthSwapchainANDROID depthSwapchain,
const XrDepthAcquireInfoANDROID* acquireInfo,
XrDepthAcquireResultANDROID* acquireResult);
תיאורי פרמטרים
depthSwapchainהוא אחיזה מסוג XrDepthSwapchainANDROID לתמונה של עומק התמונה.acquireInfoהוא XrDepthAcquireInfoANDROID שמכיל מידע על אופן קבלת תמונת העומק.acquireResultהוא הערך המוחזר של XrDepthAcquireResultANDROID שמכיל מידע על תמונת העומק שנרכשה.
אפליקציות יכולות להשתמש בפונקציה xrAcquireDepthSwapchainImagesANDROID כדי לקבל את האינדקס העדכני ביותר של תמונה זמינה ב-swapchain, כמו XrDepthAcquireResultANDROID::acquiredIndex, במערך XrDepthSwapchainImageANDROID שמנוהל על ידי xrEnumerateDepthSwapchainImagesANDROID. הערך המוחזר של XrDepthAcquireResultANDROID מכיל גם מידע נוסף, כמו שדה הראייה והתנוחה הנדרשים כדי לפרש את נתוני העומק. אפשר לקרוא מהחריץ שנרכש במערך התמונות בבטחה עד לקריאה הבאה ל-xrAcquireDepthSwapchainImagesANDROID.
אסור לבצע יותר מקריאה אחת ל-xrAcquireDepthSwapchainImagesANDROID בין כל זוג של קריאות תואמות ל-xrBeginFrame ול-xrEndFrame בסשן.
שימוש תקין (מרומז)
- חובה להפעיל את התוסף
XR_ANDROID_depth_textureלפני שמפעילים את xrAcquireDepthSwapchainImagesANDROID depthSwapchainחייב להיות XrDepthSwapchainANDROID ידית חוקית- המשתנה
acquireInfoחייב להיות הפניה למבנה תקין של XrDepthAcquireInfoANDROID acquireResultחייב להיות הפניה למבנה XrDepthAcquireResultANDROID
קודי החזרה
XR_SUCCESSXR_SESSION_LOSS_PENDING
XR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_VALIDATION_FAILUREXR_ERROR_RUNTIME_FAILUREXR_ERROR_HANDLE_INVALIDXR_ERROR_INSTANCE_LOSTXR_ERROR_SESSION_LOSTXR_ERROR_DEPTH_NOT_AVAILABLE_ANDROIDXR_ERROR_CALL_ORDER_INVALIDXR_ERROR_LIMIT_REACHEDXR_ERROR_TIME_INVALID
המבנה 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 - הערך של
typeחייב להיותXR_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 - הערך של
typeחייב להיותXR_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 - הערך של
typeחייב להיותXR_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
// 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,
.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,
// Use the resolution supported by the runtime.
.resolution = supportedDepthResolution,
};
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(xrAcquireDepthImagesANDROID(
depthSwapchain, &acquireInfo, &acquireResult));
// Each value in a depth image corresponds to a point in the real world.
// The sample code in this section 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.acquireIndex];
// Assume supported resolution is XR_DEPTH_CAMERA_RESOLUTION_160x160_ANDROID.
const int imageResolution = 160;
int imageY = // value in [0, imageResolution)
int imageX = // value in [0, imageResolution)
// Get depth value from left eye.
// A right depth value would be 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 = (tanB + (tanU - tanB)*t)*depthL;
XrPosef depthCameraPoseL = viewL.pose;
// Transform posInCameraSpace by depthCameraPoseL
// ...
// Finish frame loop
// ...
}
סוגי אובייקטים חדשים
ערכי קבועים חדשים של טיפוס בן מנייה (enum)
המניין XrObjectType הורחב עם:
XR_OBJECT_TYPE_DEPTH_SWAPCHAIN_ANDROID
המניין XrResult הורחב עם:
XR_ERROR_DEPTH_NOT_AVAILABLE_ANDROID
המניין XrStructureType הורחב עם:
XR_TYPE_DEPTH_SWAPCHAIN_CREATE_INFO_ANDROIDXR_TYPE_DEPTH_VIEW_ANDROIDXR_TYPE_DEPTH_ACQUIRE_INFO_ANDROIDXR_TYPE_DEPTH_ACQUIRE_RESULT_ANDROIDXR_TYPE_SYSTEM_DEPTH_TRACKING_PROPERTIES_ANDROIDXR_TYPE_DEPTH_SWAPCHAIN_IMAGE_ANDROID
Enums חדשים
מבנים חדשים
- XrDepthSwapchainCreateInfoANDROID
- XrDepthSwapchainImageANDROID
- XrDepthAcquireInfoANDROID
- XrDepthViewANDROID
- XrDepthAcquireResultANDROID
- XrSystemDepthTrackingPropertiesANDROID
פונקציות חדשות
- xrCreateDepthSwapchainANDROID
- xrDestroyDepthSwapchainANDROID
- xrEnumerateDepthSwapchainImagesANDROID
- xrEnumerateDepthResolutionsANDROID
- xrAcquireDepthSwapchainImagesANDROID
בעיות
היסטוריית גרסאות
- גרסה 1, 09 בספטמבר 2024 (Levana Chen)
- תיאור ראשוני של התוסף
OpenXR™ והלוגו של OpenXR הם סימנים מסחריים בבעלות The Khronos Group Inc., והם רשומים כסימנים מסחריים בסין, באיחוד האירופי, ביפן ובבריטניה.