XR_ANDROID_depth_texture
Chaîne de nom
XR_ANDROID_depth_texture
Type d'extension
Extension d'instance
Numéro d'extension enregistré
703
Révision
1
État de ratification
Non ratifié
Dépendances des extensions et des versions
Date de dernière modification
2024-09-11
État de l'adresse IP
Aucune réclamation connue pour atteinte à la propriété intellectuelle.
Contributeurs
Sushant Kulkarni, Google
Cairn Overturf, Google
Spencer Quin, Google
Levana Chen, Google
Présentation
Cette extension permet à l'application de demander des cartes de profondeur de l'environnement réel autour du casque et d'interroger les résolutions de profondeur compatibles lors de la création.
Cette extension est destinée à exposer la profondeur brute et lissée pour l'occlusion, les tests de sélection et d'autres tâches spécifiques qui exploitent une géométrie de scène précise, par exemple la détection de faux visages.
Remarque
Les cartes de profondeur sont générées par le runtime et partagées avec l'application à l'aide de XrDepthSwapchainANDROID . Le runtime ne doit pas modifier les résolutions d'image de profondeur renvoyées par xrEnumerateDepthResolutionsANDROID tout au long de la durée de vie de l'application.
Autorisations
Cette extension expose une texture de profondeur sous-échantillonnée pour atténuer les problèmes liés aux informations permettant d'identifier personnellement les utilisateurs. Les applications Android doivent inclure l'autorisation android.permission.SCENE_UNDERSTANDING_FINE dans leur fichier manifeste, car cette extension expose la géométrie de l'environnement. L'autorisation android.permission.SCENE_UNDERSTANDING_FINE est considérée comme dangereuse. L'application doit demander l'autorisation au moment de l'exécution pour utiliser ces fonctions :
(niveau de protection : dangereux)
Inspecter les capacités du système
La structure XrSystemDepthTrackingPropertiesANDROID est définie comme suit :
typedef struct XrSystemDepthTrackingPropertiesANDROID {
XrStructureType type;
void* next;
XrBool32 supportsDepthTracking;
} XrSystemDepthTrackingPropertiesANDROID;
Descriptions des membres
typeest le XrStructureType de cette structure.nextestNULLou un pointeur vers la structure suivante dans une chaîne de structures. Aucune structure de ce type n'est définie dans l'extension ni dans le cœur d'OpenXR.supportsDepthTrackingest une valeurXrBool32indiquant si le système actuel est compatible avec le suivi de la profondeur.
Une application peut inspecter si le système est capable de suivre la profondeur en étendant XrSystemProperties avec la structure XrSystemDepthTrackingPropertiesANDROID lors de l'appel de xrGetSystemProperties .
Si et seulement si un moteur d'exécution renvoie XR_FALSE pour supportsDepthTracking , le moteur d'exécution doit renvoyer XR_ERROR_FEATURE_UNSUPPORTED à partir de xrCreateDepthSwapchainANDROID .
Utilisation valide (implicite)
- L'extension
XR_ANDROID_depth_texturedoit être activée avant d'utiliser XrSystemDepthTrackingPropertiesANDROID. -
typedoit êtreXR_TYPE_SYSTEM_DEPTH_TRACKING_PROPERTIES_ANDROID. -
nextdoit êtreNULLou un pointeur valide vers la structure suivante dans une chaîne de structures.
Résolutions de la profondeur de la requête
La fonction xrEnumerateDepthResolutionsANDROID est définie comme suit :
XrResult xrEnumerateDepthResolutionsANDROID(
XrSession session,
uint32_t resolutionCapacityInput,
uint32_t* resolutionCountOutput,
XrDepthCameraResolutionANDROID* resolutions);
Descriptions des paramètres
sessionest la XrSession qui énumère les résolutions de profondeur compatibles.resolutionCapacityInputcorrespond à la capacité deresolutionsou à 0 pour récupérer la capacité requise.resolutionCountOutputest un pointeur vers le nombre deuint64_tresolutionsécrits ou un pointeur vers la capacité requise siresolutionCapacityInputest insuffisant.resolutionsest un pointeur vers un tableau de XrDepthCameraResolutionANDROID , mais can peut êtreNULLsiresolutionCapacityInputest0.- Pour obtenir une description détaillée de la récupération de la taille
resolutionsrequise, consultez la section Paramètres de taille du tampon.
xrEnumerateDepthResolutionsANDROID énumère les résolutions de profondeur compatibles avec la session actuelle. Les résolutions de profondeur doivent être classées de la préférence d'exécution la plus élevée à la plus faible. L'application doit utiliser la préférence la plus élevée qu'elle prend en charge pour des performances et une qualité optimales.
Les runtimes doivent toujours renvoyer des contenus de tampon identiques à partir de cette énumération pour la durée de la session.
Utilisation valide (implicite)
- L'extension
XR_ANDROID_depth_texturedoit être activée avant d'appeler xrEnumerateDepthResolutionsANDROID. -
sessiondoit être un handle XrSession valide -
resolutionCountOutputmust être un pointeur vers une valeuruint32_t - Si
resolutionCapacityInputn'est pas0,resolutionsdoit être un pointeur vers un tableau de valeurs XrDepthCameraResolutionANDROID deresolutionCapacityInput.
Codes de retour
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
L'énumération XrDepthCameraResolutionANDROID décrit les résolutions de profondeur acceptées lors de la création d'une 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;
Descriptions des énumérants
XR_DEPTH_CAMERA_RESOLUTION_80x80_ANDROID: la résolution des images de profondeur et de confiance est de 80 x 80.XR_DEPTH_CAMERA_RESOLUTION_160x160_ANDROID: la résolution des images de profondeur et de confiance est de 160 x 160.XR_DEPTH_CAMERA_RESOLUTION_320x320_ANDROID: la résolution des images de profondeur et de confiance est de 320 x 320.
Créer une chaîne d'échange de profondeur
XR_DEFINE_HANDLE(XrDepthSwapchainANDROID)
XrDepthSwapchainANDROID est un handle de chaîne d'échange de profondeur.
La fonction xrCreateDepthSwapchainANDROID est définie comme suit :
XrResult xrCreateDepthSwapchainANDROID(
XrSession session,
const XrDepthSwapchainCreateInfoANDROID* createInfo,
XrDepthSwapchainANDROID* swapchain);
Descriptions des paramètres
sessionest la XrSession qui crée la chaîne d'échange de profondeur.createInfoest un pointeur vers une structure XrDepthSwapchainCreateInfoANDROID contenant les paramètres à utiliser pour créer la swapchain.swapchainest un pointeur vers un handle dans lequel l'élément XrDepthSwapchainANDROID créé est renvoyé.
L'application peut utiliser la fonction xrCreateDepthSwapchainANDROID pour créer une chaîne d'échange de profondeur qui gère à la fois les images de profondeur et de confiance.
- L'environnement d'exécution doit renvoyer
XR_ERROR_FEATURE_UNSUPPORTEDsi le système n'est pas compatible avec le suivi de la profondeur. - L'exécution doit renvoyer
XR_ERROR_PERMISSION_INSUFFICIENTsi les autorisations requises n'ont pas été accordées à l'application appelante. - L'exécution doit renvoyer
XR_ERROR_VALIDATION_FAILUREsi la résolution de profondeur spécifiée dans XrDepthSwapchainCreateInfoANDROID n'est pas compatible. - Le runtime doit uniquement créer des images de confiance de profondeur lorsque les bits correspondants sont définis pour
createInfolors de la création de la chaîne d'échange.
Le handle de swapchain de profondeur renvoyé peut être utilisé ultérieurement dans les appels d'API. Le handle XrDepthSwapchainANDROID doit être libéré à terme via la fonction xrDestroyDepthSwapchainANDROID.
Utilisation valide (implicite)
- L'extension
XR_ANDROID_depth_texturedoit être activée avant d'appeler xrCreateDepthSwapchainANDROID. -
sessiondoit être un handle XrSession valide -
createInfomust être un pointeur vers une structure XrDepthSwapchainCreateInfoANDROID valide -
swapchainmust be a pointer to an XrDepthSwapchainANDROID handle
Codes de retour
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
La structure XrDepthSwapchainCreateInfoANDROID est définie comme suit :
typedef struct XrDepthSwapchainCreateInfoANDROID {
XrStructureType type;
const void* next;
XrDepthCameraResolutionANDROID resolution;
XrDepthSwapchainCreateFlagsANDROID createFlags;
} XrDepthSwapchainCreateInfoANDROID;
Descriptions des membres
typeest le XrStructureType de cette structure.nextestNULLou un pointeur vers la structure suivante dans une chaîne de structures. Aucune structure de ce type n'est définie dans l'extension ni dans le cœur d'OpenXR.resolutionest la XrDepthCameraResolutionANDROID avec laquelle les textures de profondeur et de confiance sont créées.createFlagscorrespond à un ou plusieurs XrDepthSwapchainCreateFlagsANDROID .
La structure XrDepthSwapchainCreateInfoANDROID fournit des options de création pour XrDepthSwapchainANDROID lorsqu'elle est transmise à xrCreateDepthSwapchainANDROID .
Utilisation valide (implicite)
- L'extension
XR_ANDROID_depth_texturedoit être activée avant d'utiliser XrDepthSwapchainCreateInfoANDROID. -
typedoit êtreXR_TYPE_DEPTH_SWAPCHAIN_CREATE_INFO_ANDROID. -
nextdoit êtreNULLou un pointeur valide vers la structure suivante dans une chaîne de structures. -
resolutionmust être une valeur XrDepthCameraResolutionANDROID valide -
createFlagsmust être une combinaison valide de valeurs XrDepthSwapchainCreateFlagBitsANDROID -
createFlagsne doit pas être0
XrDepthSwapchainCreateFlagsANDROID spécifie les options de création pour XrDepthSwapchainANDROID .
typedef XrFlags64 XrDepthSwapchainCreateFlagsANDROID;
Les bits valides pour XrDepthSwapchainCreateFlagsANDROID sont définis par XrDepthSwapchainCreateFlagBitsANDROID , qui est spécifié comme suit :
// 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;
Descriptions des indicateurs
XR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_DEPTH_IMAGE_BIT_ANDROID: indique que la chaîne d'échange fournira des images de profondeur fluides.XR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_CONFIDENCE_IMAGE_BIT_ANDROID: indique que la chaîne d'échange fournira des images de confiance de profondeur fluides.XR_DEPTH_SWAPCHAIN_CREATE_RAW_DEPTH_IMAGE_BIT_ANDROID: indique que la chaîne d'échange fournira des images de profondeur brutes.XR_DEPTH_SWAPCHAIN_CREATE_RAW_CONFIDENCE_IMAGE_BIT_ANDROID: indique que la chaîne d'échange fournira des images de confiance de profondeur brute.
La fonction xrDestroyDepthSwapchainANDROID est définie comme suit :
XrResult xrDestroyDepthSwapchainANDROID(
XrDepthSwapchainANDROID swapchain);
Descriptions des paramètres
swapchainest un handle XrDepthSwapchainANDROID précédemment créé par xrCreateDepthSwapchainANDROID .
La fonction xrDestroyDepthSwapchainANDROID détruit la chaîne d'échange de profondeur. Après cet appel, le runtime peut libérer toute la mémoire et les ressources associées.
Utilisation valide (implicite)
- L'extension
XR_ANDROID_depth_texturedoit être activée avant d'appeler xrDestroyDepthSwapchainANDROID. -
swapchainmust être un handle XrDepthSwapchainANDROID valide
Sécurité des threads
- L'accès à
swapchainet à tous les identifiants enfants doit être synchronisé en externe.
Codes de retour
XR_SUCCESS
XR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_HANDLE_INVALID
Accéder aux textures de profondeur
La fonction xrEnumerateDepthSwapchainImagesANDROID est définie comme suit :
XrResult xrEnumerateDepthSwapchainImagesANDROID(
XrDepthSwapchainANDROID depthSwapchain,
uint32_t depthImageCapacityInput,
uint32_t* depthImageCountOutput,
XrDepthSwapchainImageANDROID* depthImages);
Descriptions des paramètres
depthSwapchainest le XrDepthSwapchainANDROID à partir duquel obtenir les images.depthImageCapacityInputcorrespond à la capacité du tableaudepthImagesou à 0 pour indiquer une requête visant à récupérer la capacité requise.depthImageCountOutputest un pointeur vers le nombre dedepthImagesécrits ou un pointeur vers la capacité requise dans le cas oùdepthImageCapacityInputest insuffisant.depthImagesest un pointeur vers un tableau de structures XrDepthSwapchainImageANDROID. Elle peut êtreNULLsidepthImageCapacityInputest défini sur 0.- Pour obtenir une description détaillée de la récupération de la taille
depthImagesrequise, consultez la section Paramètres de taille du tampon.
xrEnumerateDepthSwapchainImagesANDROID remplit un tableau de structures XrDepthSwapchainImageANDROID. Les ressources doivent être constantes et valides pour la durée de vie de XrDepthSwapchainANDROID . Cette fonction se comporte de manière analogue à xrEnumerateSwapchainImages .
L'exécution doit toujours renvoyer un contenu de tampon identique à partir de cette énumération pour la durée de vie de la chaîne d'échange.
Utilisation valide (implicite)
- L'extension
XR_ANDROID_depth_texturedoit être activée avant d'appeler xrEnumerateDepthSwapchainImagesANDROID. -
depthSwapchainmust être un handle XrDepthSwapchainANDROID valide -
depthImageCountOutputmust être un pointeur vers une valeuruint32_t - Si
depthImageCapacityInputn'est pas0,depthImagesdoit être un pointeur vers un tableau de structures XrDepthSwapchainImageANDROID dedepthImageCapacityInput.
Codes de retour
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
La structure XrDepthSwapchainImageANDROID est définie comme suit :
typedef struct XrDepthSwapchainImageANDROID {
XrStructureType type;
void* next;
const float* rawDepthImage;
const uint8_t* rawDepthConfidenceImage;
const float* smoothDepthImage;
const uint8_t* smoothDepthConfidenceImage;
} XrDepthSwapchainImageANDROID;
Descriptions des membres
typeest le XrStructureType de cette structure.nextestNULLou un pointeur vers la structure suivante dans une chaîne de structures. Aucune structure de ce type n'est définie dans l'extension ni dans le cœur d'OpenXR.rawDepthImagecorrespond àNULLou au pointeur vers les images de profondeur brutes pour les vues de gauche et de droite allouées par le runtime. Les valeurs sont exprimées en mètres. Valeurs spéciales :0.0indique un pixel de profondeur non valide ou vide dans la profondeur brute,Infindique une profondeur connue qui est effectivement infiniment éloignée.rawDepthConfidenceImageestNULLou le pointeur vers les images de confiance de profondeur brute pour les vues de gauche et de droite allouées par le runtime.smoothDepthImagecorrespond àNULLou au pointeur vers les images de profondeur lissées pour les vues de gauche et de droite allouées par le runtime. Les valeurs sont exprimées en mètres. Valeurs spéciales :0.0indique un pixel de profondeur non valide ou vide dans la profondeur lissée,Infindique une profondeur connue qui est effectivement infiniment éloignée.smoothDepthConfidenceImagecorrespond àNULLou au pointeur vers les images de confiance de profondeur lissées pour les vues de gauche et de droite allouées par le runtime.
Les pointeurs de tampon d'image ne seront valides que pendant la durée de vie de la chaîne d'échange. Une fois la chaîne d'échange détruite, les pointeurs seront considérés comme suspendus.
XrDepthSwapchainImageANDROID représente les images de profondeur d'une XrDepthSwapchainANDROID lisible , allouées comme décrit dans XrDepthSwapchainCreateInfoANDROID :: resolution et XrDepthSwapchainCreateInfoANDROID :: createFlags lors de l'appel de xrCreateDepthSwapchainANDROID . Pour chaque image de profondeur :
- Les valeurs d'image sont disposées en mémoire dans l'ordre des lignes, sans marge intérieure entre les lignes.
- La première valeur correspond au coin supérieur gauche et la dernière au coin inférieur droit.
- La taille de la mémoire pointée est déterminée par la valeur de xrEnumerateDepthSwapchainImagesANDROID et définie par XrDepthSwapchainCreateInfoANDROID ::
resolutionlors de l'appel de xrCreateDepthSwapchainANDROID . Par exemple, si XrDepthSwapchainCreateInfoANDROID ::resolutionestXR_DEPTH_CAMERA_RESOLUTION_160x160_ANDROID, les images de profondeur auront la taille2*160*160*sizeof(float). - La valeur de
rawDepthImagedoit êtreNULLsi XrDepthSwapchainCreateInfoANDROID ::createFlagsn'incluait pasXR_DEPTH_SWAPCHAIN_CREATE_RAW_DEPTH_IMAGE_BIT_ANDROID. - La valeur de
rawDepthConfidenceImagedoit êtreNULLsi XrDepthSwapchainCreateInfoANDROID ::createFlagsn'incluait pasXR_DEPTH_SWAPCHAIN_CREATE_RAW_CONFIDENCE_IMAGE_BIT_ANDROID. - La valeur de
smoothDepthImagedoit êtreNULLsi XrDepthSwapchainCreateInfoANDROID ::createFlagsn'incluait pasXR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_DEPTH_IMAGE_BIT_ANDROID. - La valeur de
smoothDepthImagedoit êtreNULLsi XrDepthSwapchainCreateInfoANDROID ::createFlagsn'incluait pasXR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_CONFIDENCE_IMAGE_BIT_ANDROID.
Utilisation valide (implicite)
- L'extension
XR_ANDROID_depth_texturedoit être activée avant d'utiliser XrDepthSwapchainImageANDROID. -
typedoit êtreXR_TYPE_DEPTH_SWAPCHAIN_IMAGE_ANDROID. -
nextdoit êtreNULLou un pointeur valide vers la structure suivante dans une chaîne de structures.
La fonction xrAcquireDepthSwapchainImagesANDROID est définie comme suit :
XrResult xrAcquireDepthSwapchainImagesANDROID(
XrDepthSwapchainANDROID depthSwapchain,
const XrDepthAcquireInfoANDROID* acquireInfo,
XrDepthAcquireResultANDROID* acquireResult);
Descriptions des paramètres
depthSwapchainest un handle XrDepthSwapchainANDROID pour l'image de profondeur.acquireInfoest un XrDepthAcquireInfoANDROID contenant des informations sur la façon d'acquérir l'image de profondeur.acquireResultest l'élément XrDepthAcquireResultANDROID renvoyé, qui contient des informations sur l'image de profondeur acquise.
Les applications peuvent utiliser la fonction xrAcquireDepthSwapchainImagesANDROID pour acquérir le dernier index d'image de la chaîne d'échange disponible, c'est-à-dire XrDepthAcquireResultANDROID :: acquiredIndex , dans le tableau XrDepthSwapchainImageANDROID énuméré par xrEnumerateDepthSwapchainImagesANDROID. Le XrDepthAcquireResultANDROID renvoyé contient également d'autres informations, telles que le champ de vision et la pose, qui sont nécessaires pour interpréter les données de profondeur. Il est possible de lire à partir de l'emplacement acquis dans le tableau d'images jusqu'au prochain appel à xrAcquireDepthSwapchainImagesANDROID .
Il ne doit pas y avoir plus d'un appel à xrAcquireDepthSwapchainImagesANDROID entre deux appels xrBeginFrame et xrEndFrame correspondants dans une session.
- L'environnement d'exécution peut bloquer si les images de la chaîne d'échange acquises précédemment sont toujours utilisées par l'environnement d'exécution.
- L'exécution doit renvoyer
XR_ERROR_CALL_ORDER_INVALIDsi xrAcquireDepthSwapchainImagesANDROID est appelé avant xrBeginFrame ou après xrEndFrame . - Le runtime doit renvoyer
XR_ERROR_LIMIT_REACHEDsi xrAcquireDepthSwapchainImagesANDROID est appelé plusieurs fois par frame, c'est-à-dire dans une session en cours, après un appel à xrBeginFrame qui n'a pas été associé à xrEndFrame. - Le runtime peut renvoyer
XR_ERROR_DEPTH_NOT_AVAILABLE_ANDROIDsi les données de profondeur de l'environnement ne sont pas encore disponibles. Dans ce cas, l'application doit appeler xrAcquireDepthSwapchainImagesANDROID à une frame ultérieure.
Utilisation valide (implicite)
- L'extension
XR_ANDROID_depth_texturedoit être activée avant d'appeler xrAcquireDepthSwapchainImagesANDROID. -
depthSwapchainmust être un handle XrDepthSwapchainANDROID valide -
acquireInfomust être un pointeur vers une structure XrDepthAcquireInfoANDROID valide -
acquireResultmust être un pointeur vers une structure XrDepthAcquireResultANDROID
Codes de retour
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
La structure XrDepthAcquireInfoANDROID est définie comme suit :
typedef struct XrDepthAcquireInfoANDROID {
XrStructureType type;
const void* next;
XrSpace space;
XrTime displayTime;
} XrDepthAcquireInfoANDROID;
Descriptions des membres
typeest le XrStructureType de cette structure.nextestNULLou un pointeur vers la structure suivante dans une chaîne de structures. Aucune structure de ce type n'est définie dans l'extension ni dans le cœur d'OpenXR.spaceest un XrSpace qui définit le cadre de référence de la pose renvoyée dans XrDepthAcquireResultANDROID ::views.displayTimeest unXrTimespécifiant l'heure utilisée pour calculer la pose de la pose renvoyée dans XrDepthAcquireResultANDROID::views. Les applications doivent transmettre le temps d'affichage prévu pour le frame actuel.
Utilisation valide (implicite)
- L'extension
XR_ANDROID_depth_texturedoit être activée avant d'utiliser XrDepthAcquireInfoANDROID. -
typedoit êtreXR_TYPE_DEPTH_ACQUIRE_INFO_ANDROID. -
nextdoit êtreNULLou un pointeur valide vers la structure suivante dans une chaîne de structures. -
spacemust être un handle XrSpace valide
La structure XrDepthAcquireResultANDROID est définie comme suit :
typedef struct XrDepthAcquireResultANDROID {
XrStructureType type;
const void* next;
uint32_t acquiredIndex;
XrTime exposureTimestamp;
XrDepthViewANDROID views[2];
} XrDepthAcquireResultANDROID;
Descriptions des membres
typeest le XrStructureType de cette structure.nextestNULLou un pointeur vers la structure suivante dans une chaîne de structures. Aucune structure de ce type n'est définie dans l'extension ni dans le cœur d'OpenXR.acquiredIndexest l'index de la texture acquise dans le tableau XrDepthSwapchainImageANDROID énuméré par xrEnumerateDepthSwapchainImagesANDROID .exposureTimestampest leXrTimequi spécifie l'heure à laquelle la carte de profondeur a été capturée.viewsest un tableau de deux XrDepthViewANDROID , un pour chaque œil, où l'index 0 correspond à l'œil gauche et l'index 1 à l'œil droit.
Utilisation valide (implicite)
- L'extension
XR_ANDROID_depth_texturedoit être activée avant d'utiliser XrDepthAcquireResultANDROID. -
typedoit êtreXR_TYPE_DEPTH_ACQUIRE_RESULT_ANDROID. -
nextdoit êtreNULLou un pointeur valide vers la structure suivante dans une chaîne de structures. - Chaque élément de
viewsdoit être une structure XrDepthViewANDROID valide.
La structure XrDepthViewANDROID est définie comme suit :
typedef struct XrDepthViewANDROID {
XrStructureType type;
const void* next;
XrFovf fov;
XrPosef pose;
} XrDepthViewANDROID;
Descriptions des membres
typeest le XrStructureType de cette structure.nextestNULLou un pointeur vers la structure suivante dans une chaîne de structures. Aucune structure de ce type n'est définie dans l'extension ni dans le cœur d'OpenXR.fovest un XrFovf qui spécifie le champ de vision utilisé pour générer cette vue. La vue n'est jamais inversée horizontalement ni verticalement.poseest un XrPosef qui spécifie la pose à partir de laquelle la carte de profondeur a été affichée. Le cadre de référence est spécifié dans XrDepthAcquireInfoANDROID .
Utilisation valide (implicite)
- L'extension
XR_ANDROID_depth_texturedoit être activée avant d'utiliser XrDepthViewANDROID. -
typedoit êtreXR_TYPE_DEPTH_VIEW_ANDROID. -
nextdoit êtreNULLou un pointeur valide vers la structure suivante dans une chaîne de structures.
Exemple de code pour le suivi de la profondeur
L'exemple de code suivant montre comment acquérir des images de profondeur et utiliser les valeurs de profondeur pour mapper les coordonnées des images de profondeur à l'espace de scène.
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
// ...
}
Nouveaux types d'objets
Nouvelles commandes
- xrAcquireDepthSwapchainImagesANDROID
- xrCreateDepthSwapchainANDROID
- xrDestroyDepthSwapchainANDROID
- xrEnumerateDepthResolutionsANDROID
- xrEnumerateDepthSwapchainImagesANDROID
Nouvelles structures
- XrDepthAcquireInfoANDROID
- XrDepthAcquireResultANDROID
- XrDepthSwapchainCreateInfoANDROID
- XrDepthSwapchainImageANDROID
- XrDepthViewANDROID
Étendre XrSystemProperties :
Nouveaux enums
Nouveaux masques de bits
Nouvelles constantes d'énumération
XR_ANDROID_DEPTH_TEXTURE_EXTENSION_NAMEXR_ANDROID_depth_texture_SPEC_VERSIONExtension de XrObjectType :
XR_OBJECT_TYPE_DEPTH_SWAPCHAIN_ANDROID
Extension de XrResult :
XR_ERROR_DEPTH_NOT_AVAILABLE_ANDROID
Extension de 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
Problèmes
Historique des versions
Révision 1, 09/09/2024 (Levana Chen)
- Description initiale de l'extension