XR_ANDROID_depth_texture
Name String
XR_ANDROID_depth_texture
Erweiterungstyp
Instanzerweiterung
Registrierte Durchwahlnummer
703
Revision
1
Ratifikationsstatus
Nicht ratifiziert
Abhängigkeiten von Erweiterungen und Versionen
Datum der letzten Änderung
2024-09-11
IP-Status
Es sind keine Ansprüche wegen geistigen Eigentums bekannt.
Mitwirkende
Sushant Kulkarni, Google
Cairn Overturf, Google
Spencer Quin, Google
Levana Chen, Google
Übersicht
Mit dieser Erweiterung kann die Anwendung Tiefenkarten der realen Umgebung um das Headset herum anfordern und unterstützte Tiefenauflösungen bei der Erstellung abfragen.
Diese Erweiterung soll rohe und geglättete Tiefe für Verdeckung, Trefferprüfung und andere spezifische Aufgaben bereitstellen, die eine genaue Szenengeometrie erfordern, z. B. die Erkennung gefälschter Gesichter.
Hinweis
Die Tiefenkarten werden von der Laufzeit generiert und über XrDepthSwapchainANDROID mit der Anwendung geteilt . Die Laufzeit darf die über xrEnumerateDepthResolutionsANDROID zurückgegebenen Tiefenbildauflösungen während des Lebenszyklus der Anwendung nicht ändern.
Berechtigungen
Diese Erweiterung stellt eine downsampled-Tiefentextur zur Verfügung, um Bedenken hinsichtlich personenidentifizierbarer Informationen zu minimieren. Android-Anwendungen müssen die Berechtigung „android.permission.SCENE_UNDERSTANDING_FINE“ in ihrem Manifest aufführen, da diese Erweiterung die Geometrie der Umgebung offenlegt. Die Berechtigung „android.permission.SCENE_UNDERSTANDING_FINE“ gilt als gefährliche Berechtigung. Die App muss die Berechtigung zur Laufzeit anfordern, um diese Funktionen zu verwenden:
(Schutzebene: gefährlich)
Systemfunktionen prüfen
Die Struktur XrSystemDepthTrackingPropertiesANDROID ist so definiert:
typedef struct XrSystemDepthTrackingPropertiesANDROID {
XrStructureType type;
void* next;
XrBool32 supportsDepthTracking;
} XrSystemDepthTrackingPropertiesANDROID;
Mitgliederbeschreibungen
typeist der XrStructureType dieser Struktur.nextistNULLoder ein Zeiger auf die nächste Struktur in einer Strukturkette. Solche Strukturen sind in OpenXR Core oder dieser Erweiterung nicht definiert.supportsDepthTrackingist einXrBool32-Wert, der angibt, ob das aktuelle System die Tiefenmessung unterstützt.
Eine Anwendung kann prüfen, ob das System Tiefenmessung unterstützt, indem sie die XrSystemProperties beim Aufrufen von xrGetSystemProperties mit der Struktur XrSystemDepthTrackingPropertiesANDROID erweitert .
Wenn und nur wenn eine Laufzeit XR_FALSE für supportsDepthTracking zurückgibt , muss die Laufzeit XR_ERROR_FEATURE_UNSUPPORTED von xrCreateDepthSwapchainANDROID zurückgeben .
Gültige Nutzung (implizit)
- Die
XR_ANDROID_depth_texture-Erweiterung muss aktiviert werden, bevor XrSystemDepthTrackingPropertiesANDROID verwendet werden kann. -
typemussXR_TYPE_SYSTEM_DEPTH_TRACKING_PROPERTIES_ANDROIDsein -
nextmussNULLoder ein gültiger Zeiger auf die nächste Struktur in einer Strukturkette sein.
Lösungen für die Suchtiefe
Die Funktion xrEnumerateDepthResolutionsANDROID ist so definiert:
XrResult xrEnumerateDepthResolutionsANDROID(
XrSession session,
uint32_t resolutionCapacityInput,
uint32_t* resolutionCountOutput,
XrDepthCameraResolutionANDROID* resolutions);
Parameterbeschreibungen
sessionist die XrSession, in der die unterstützten Tiefenauflösungen aufgelistet werden.resolutionCapacityInputist die Kapazität vonresolutionsoder 0 , um die erforderliche Kapazität abzurufen.resolutionCountOutputist ein Zeiger auf die Anzahl der geschriebenenuint64_tresolutionsoder ein Zeiger auf die erforderliche Kapazität, fallsresolutionCapacityInputnicht ausreicht.resolutionsist ein Zeiger auf ein Array von XrDepthCameraResolutionANDROID, kann aberNULLsein, wennresolutionCapacityInput0ist.- Eine detaillierte Beschreibung zum Abrufen der erforderlichen
resolutions-Größe finden Sie im Abschnitt Puffergrößenparameter.
xrEnumerateDepthResolutionsANDROID listet die von der aktuellen Sitzung unterstützten Tiefenauflösungen auf. Die Tiefenauflösungen sollten nach der Laufzeitpräferenz sortiert sein, von der höchsten zur niedrigsten. Die Anwendung sollte die höchste unterstützte Einstellung für optimale Leistung und Qualität verwenden.
Runtimes müssen für die gesamte Dauer der Sitzung immer identische Pufferinhalte aus dieser Aufzählung zurückgeben.
Gültige Nutzung (implizit)
- Die Erweiterung
XR_ANDROID_depth_texturemuss aktiviert sein, bevor xrEnumerateDepthResolutionsANDROID aufgerufen wird. -
sessionmuss ein gültiger XrSession-Handle sein -
resolutionCountOutputmuss ein Zeiger auf einenuint32_t-Wert sein. - Wenn
resolutionCapacityInputnicht0ist ,resolutionsmuss ein Zeiger auf ein Array vonresolutionCapacityInputXrDepthCameraResolutionANDROID-Werten sein.
Rückgabecodes
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
Die Enumeration XrDepthCameraResolutionANDROID beschreibt die unterstützten Tiefenauflösungen beim Erstellen einer 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;
Beschreibungen der Aufzählungswerte
XR_DEPTH_CAMERA_RESOLUTION_80x80_ANDROID: Die Auflösung der Tiefen- und Konfidenzbilder beträgt 80 × 80.XR_DEPTH_CAMERA_RESOLUTION_160x160_ANDROID– Die Auflösung der Tiefen- und Vertrauensbilder beträgt 160 × 160.XR_DEPTH_CAMERA_RESOLUTION_320x320_ANDROID: Die Auflösung der Tiefen- und Vertrauenswürdigkeitsbilder beträgt 320 × 320.
Tiefen-Swapchain erstellen
XR_DEFINE_HANDLE(XrDepthSwapchainANDROID)
Ein XrDepthSwapchainANDROID ist ein Handle für eine Depth-Swapchain.
Die Funktion xrCreateDepthSwapchainANDROID ist so definiert:
XrResult xrCreateDepthSwapchainANDROID(
XrSession session,
const XrDepthSwapchainCreateInfoANDROID* createInfo,
XrDepthSwapchainANDROID* swapchain);
Parameterbeschreibungen
sessionist die XrSession, mit der die Swapchain für die Tiefe erstellt wird.createInfoist ein Zeiger auf eine XrDepthSwapchainCreateInfoANDROID-Struktur, die Parameter zum Erstellen der Swapchain enthält.swapchainist ein Zeiger auf ein Handle, in dem die erstellte XrDepthSwapchainANDROID zurückgegeben wird.
Die Anwendung kann die Funktion xrCreateDepthSwapchainANDROID verwenden, um eine Depth-Swapchain zu erstellen, die sowohl Tiefen- als auch Vertrauensbilder verwaltet.
- Die Laufzeit muss
XR_ERROR_FEATURE_UNSUPPORTEDzurückgeben, wenn das System keine Tiefenverfolgung unterstützt. - Die Laufzeit muss
XR_ERROR_PERMISSION_INSUFFICIENTzurückgeben, wenn der Anruf-App die erforderlichen Berechtigungen nicht erteilt wurden. - Die Laufzeit muss
XR_ERROR_VALIDATION_FAILUREzurückgeben, wenn die in XrDepthSwapchainCreateInfoANDROID angegebene Tiefenauflösung nicht unterstützt wird. - Die Laufzeit sollte nur dann Bilder mit Tiefenkonfidenz erstellen, wenn die entsprechenden Bits für
createInfobeim Erstellen der Swapchain festgelegt sind.
Das zurückgegebene Handle für die Tiefen-Swapchain kann anschließend in API-Aufrufen verwendet werden. Das XrDepthSwapchainANDROID-Handle muss schließlich über die Funktion xrDestroyDepthSwapchainANDROID freigegeben werden.
Gültige Nutzung (implizit)
- Die
XR_ANDROID_depth_texture-Erweiterung muss aktiviert sein, bevor xrCreateDepthSwapchainANDROID aufgerufen wird. -
sessionmuss ein gültiger XrSession-Handle sein -
createInfomuss ein Zeiger auf eine gültige XrDepthSwapchainCreateInfoANDROID-Struktur sein. -
swapchainmuss ein Zeiger auf ein XrDepthSwapchainANDROID-Handle sein.
Rückgabecodes
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
Die Struktur XrDepthSwapchainCreateInfoANDROID ist so definiert:
typedef struct XrDepthSwapchainCreateInfoANDROID {
XrStructureType type;
const void* next;
XrDepthCameraResolutionANDROID resolution;
XrDepthSwapchainCreateFlagsANDROID createFlags;
} XrDepthSwapchainCreateInfoANDROID;
Mitgliederbeschreibungen
typeist der XrStructureType dieser Struktur.nextistNULLoder ein Zeiger auf die nächste Struktur in einer Strukturkette. Solche Strukturen sind in OpenXR Core oder dieser Erweiterung nicht definiert.resolutionist die XrDepthCameraResolutionANDROID, mit der die Tiefen- und Vertrauenswürdigkeitstexturen erstellt werden.createFlagsist ein oder mehrere XrDepthSwapchainCreateFlagsANDROID .
Die Struktur XrDepthSwapchainCreateInfoANDROID bietet Erstellungsoptionen für die XrDepthSwapchainANDROID, wenn sie an xrCreateDepthSwapchainANDROID übergeben wird .
Gültige Nutzung (implizit)
- Die
XR_ANDROID_depth_texture-Erweiterung muss aktiviert werden, bevor XrDepthSwapchainCreateInfoANDROID verwendet wird. -
typemussXR_TYPE_DEPTH_SWAPCHAIN_CREATE_INFO_ANDROIDsein -
nextmussNULLoder ein gültiger Zeiger auf die nächste Struktur in einer Strukturkette sein. -
resolutionmuss ein gültiger XrDepthCameraResolutionANDROID-Wert sein. -
createFlagsmuss eine gültige Kombination von XrDepthSwapchainCreateFlagBitsANDROID-Werten sein -
createFlagsdarf nicht0sein
Mit XrDepthSwapchainCreateFlagsANDROID werden Erstellungsoptionen für XrDepthSwapchainANDROID angegeben .
typedef XrFlags64 XrDepthSwapchainCreateFlagsANDROID;
Gültige Bits für XrDepthSwapchainCreateFlagsANDROID werden durch XrDepthSwapchainCreateFlagBitsANDROID definiert , das so angegeben wird:
// 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;
Flag-Beschreibungen
XR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_DEPTH_IMAGE_BIT_ANDROID: Gibt an, dass der Swapchain flüssige Tiefenbilder bereitstellt.XR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_CONFIDENCE_IMAGE_BIT_ANDROID: Gibt an, dass der Swapchain flüssige Bilder mit Tiefenkonfidenz bereitstellt.XR_DEPTH_SWAPCHAIN_CREATE_RAW_DEPTH_IMAGE_BIT_ANDROID: Gibt an, dass der Swapchain Rohbilder mit Tiefeninformationen bereitstellt.XR_DEPTH_SWAPCHAIN_CREATE_RAW_CONFIDENCE_IMAGE_BIT_ANDROID: Gibt an, dass die Swapchain Rohdaten-Bilder für die Tiefenkonfidenz bereitstellt.
Die Funktion xrDestroyDepthSwapchainANDROID ist so definiert:
XrResult xrDestroyDepthSwapchainANDROID(
XrDepthSwapchainANDROID swapchain);
Parameterbeschreibungen
swapchainist ein XrDepthSwapchainANDROID-Handle, das zuvor von xrCreateDepthSwapchainANDROID erstellt wurde .
Mit der Funktion xrDestroyDepthSwapchainANDROID wird die Depth-Swapchain zerstört. Nach diesem Aufruf kann die Laufzeit den gesamten zugehörigen Speicher und alle zugehörigen Ressourcen freigeben.
Gültige Nutzung (implizit)
- Die
XR_ANDROID_depth_texture-Erweiterung muss aktiviert werden, bevor xrDestroyDepthSwapchainANDROID aufgerufen wird. -
swapchainmuss ein gültiger XrDepthSwapchainANDROID-Handle sein
Threadsicherheit
- Der Zugriff auf
swapchainund alle untergeordneten Handles muss extern synchronisiert werden.
Rückgabecodes
XR_SUCCESS
XR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_HANDLE_INVALID
Tiefentexturen abrufen
Die Funktion xrEnumerateDepthSwapchainImagesANDROID ist so definiert:
XrResult xrEnumerateDepthSwapchainImagesANDROID(
XrDepthSwapchainANDROID depthSwapchain,
uint32_t depthImageCapacityInput,
uint32_t* depthImageCountOutput,
XrDepthSwapchainImageANDROID* depthImages);
Parameterbeschreibungen
depthSwapchainist die XrDepthSwapchainANDROID, aus der Bilder abgerufen werden sollen.depthImageCapacityInputist die Kapazität desdepthImages-Arrays oder 0, um eine Anfrage zum Abrufen der erforderlichen Kapazität anzugeben.depthImageCountOutputist ein Zeiger auf die Anzahl der geschriebenendepthImagesoder ein Zeiger auf die erforderliche Kapazität, fallsdepthImageCapacityInputnicht ausreicht.depthImagesist ein Zeiger auf ein Array von XrDepthSwapchainImageANDROID-Strukturen. KannNULLsein, wenndepthImageCapacityInput= 0.- Eine detaillierte Beschreibung zum Abrufen der erforderlichen
depthImages-Größe finden Sie im Abschnitt Puffergrößenparameter.
xrEnumerateDepthSwapchainImagesANDROID füllt ein Array von XrDepthSwapchainImageANDROID-Strukturen aus. Die Ressourcen müssen konstant und für die gesamte Lebensdauer von XrDepthSwapchainANDROID gültig sein . Diese Funktion verhält sich analog zu xrEnumerateSwapchainImages .
Die Laufzeit muss während der gesamten Lebensdauer der Swapchain immer identische Pufferinhalte aus dieser Aufzählung zurückgeben.
Gültige Nutzung (implizit)
- Die Erweiterung
XR_ANDROID_depth_texturemuss aktiviert sein, bevor xrEnumerateDepthSwapchainImagesANDROID aufgerufen wird. -
depthSwapchainmuss ein gültiger XrDepthSwapchainANDROID-Handle sein -
depthImageCountOutputmuss ein Zeiger auf einenuint32_t-Wert sein. - : Wenn
depthImageCapacityInputnicht0ist ,depthImagesmuss ein Zeiger auf ein Array vondepthImageCapacityInputXrDepthSwapchainImageANDROID-Strukturen sein.
Rückgabecodes
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
Die Struktur XrDepthSwapchainImageANDROID ist so definiert:
typedef struct XrDepthSwapchainImageANDROID {
XrStructureType type;
void* next;
const float* rawDepthImage;
const uint8_t* rawDepthConfidenceImage;
const float* smoothDepthImage;
const uint8_t* smoothDepthConfidenceImage;
} XrDepthSwapchainImageANDROID;
Mitgliederbeschreibungen
typeist der XrStructureType dieser Struktur.nextistNULLoder ein Zeiger auf die nächste Struktur in einer Strukturkette. Solche Strukturen sind in OpenXR Core oder dieser Erweiterung nicht definiert.rawDepthImageistNULLoder der Zeiger auf Rohbilder mit Tiefeninformationen für die linke und rechte Ansicht, die von der Laufzeit zugewiesen werden. Die Werte haben die Einheit Meter. Sonderwerte:0.0gibt einen ungültigen oder leeren Tiefenpixel in der Roh-Tiefe an,Infgibt eine bekannte Tiefe an, die effektiv unendlich weit entfernt ist.rawDepthConfidenceImageistNULLoder der Zeiger auf Rohbilder für die Tiefenvertrauenswürdigkeit für die linke und rechte Ansicht, die von der Laufzeit zugewiesen werden.smoothDepthImageistNULLoder der Zeiger auf geglättete Tiefenbilder für die linke und rechte Ansicht, die von der Laufzeit zugewiesen werden. Die Werte haben die Einheit Meter. Sonderwerte:0.0gibt einen ungültigen oder leeren Tiefenpixel in der geglätteten Tiefe an,Infgibt eine bekannte Tiefe an, die effektiv unendlich weit entfernt ist.smoothDepthConfidenceImageistNULLoder der Zeiger auf geglättete Bilder mit Tiefenvertrauen für die linke und rechte Ansicht, die von der Laufzeit zugewiesen werden.
Die Bildpuffer-Pointer sind nur während der Lebensdauer der Swapchain gültig. Sobald die Swapchain zerstört ist, gelten die Zeiger als „dangling“ (nicht mehr gültig).
XrDepthSwapchainImageANDROID stellt die Tiefenbilder aus einer lesbaren XrDepthSwapchainANDROID dar, die wie in XrDepthSwapchainCreateInfoANDROID :: resolution und XrDepthSwapchainCreateInfoANDROID :: createFlags beschrieben zugewiesen werden, während xrCreateDepthSwapchainANDROID aufgerufen wird . Für jedes Tiefenbild:
- Bildwerte werden im Speicher in zeilenweiser Reihenfolge ohne Auffüllung zwischen den Zeilen angeordnet.
- Der erste Wert ist die obere linke Ecke und der letzte Wert die untere rechte Ecke.
- Die Größe des Speichers, auf den verwiesen wird, wird durch den Wert von xrEnumerateDepthSwapchainImagesANDROID bestimmt und durch XrDepthSwapchainCreateInfoANDROID ::
resolutionbeim Aufrufen von xrCreateDepthSwapchainANDROID festgelegt . Wenn beispielsweise XrDepthSwapchainCreateInfoANDROID ::resolutiongleichXR_DEPTH_CAMERA_RESOLUTION_160x160_ANDROIDist, haben die Tiefenbilder die Größe2*160*160*sizeof(float). - Der Wert von
rawDepthImagemussNULLsein, wenn XrDepthSwapchainCreateInfoANDROID ::createFlagsnichtXR_DEPTH_SWAPCHAIN_CREATE_RAW_DEPTH_IMAGE_BIT_ANDROIDenthält . - Der Wert von
rawDepthConfidenceImagemussNULLsein, wenn XrDepthSwapchainCreateInfoANDROID ::createFlagsnichtXR_DEPTH_SWAPCHAIN_CREATE_RAW_CONFIDENCE_IMAGE_BIT_ANDROIDenthält . - Der Wert von
smoothDepthImagemussNULLsein, wenn XrDepthSwapchainCreateInfoANDROID ::createFlagsnichtXR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_DEPTH_IMAGE_BIT_ANDROIDenthält . - Der Wert von
smoothDepthImagemussNULLsein, wenn XrDepthSwapchainCreateInfoANDROID ::createFlagsnichtXR_DEPTH_SWAPCHAIN_CREATE_SMOOTH_CONFIDENCE_IMAGE_BIT_ANDROIDenthält .
Gültige Nutzung (implizit)
- Die
XR_ANDROID_depth_texture-Erweiterung muss aktiviert werden, bevor XrDepthSwapchainImageANDROID verwendet wird. -
typemussXR_TYPE_DEPTH_SWAPCHAIN_IMAGE_ANDROIDsein -
nextmussNULLoder ein gültiger Zeiger auf die nächste Struktur in einer Strukturkette sein.
Die Funktion xrAcquireDepthSwapchainImagesANDROID ist so definiert:
XrResult xrAcquireDepthSwapchainImagesANDROID(
XrDepthSwapchainANDROID depthSwapchain,
const XrDepthAcquireInfoANDROID* acquireInfo,
XrDepthAcquireResultANDROID* acquireResult);
Parameterbeschreibungen
depthSwapchainist ein XrDepthSwapchainANDROID-Handle für das Tiefenbild.acquireInfoist ein XrDepthAcquireInfoANDROID, das Informationen zum Erfassen des Tiefenbilds enthält.acquireResultist das zurückgegebene XrDepthAcquireResultANDROID mit Informationen zum aufgenommenen Tiefenbild.
Anwendungen können die Funktion xrAcquireDepthSwapchainImagesANDROID verwenden, um den neuesten verfügbaren Swapchain-Image-Index, d.h. XrDepthAcquireResultANDROID :: acquiredIndex , in das Array XrDepthSwapchainImageANDROID abzurufen, das von xrEnumerateDepthSwapchainImagesANDROID aufgezählt wird . Das zurückgegebene XrDepthAcquireResultANDROID enthält auch andere Informationen wie das Sichtfeld und die Pose, die zum Interpretieren der Tiefendaten erforderlich sind. Es ist sicher, bis zum nächsten Aufruf von xrAcquireDepthSwapchainImagesANDROID aus dem erworbenen Slot im Bild-Array zu lesen .
Zwischen zwei entsprechenden xrBeginFrame- und xrEndFrame-Aufrufen in einer Sitzung darf es höchstens einen Aufruf von xrAcquireDepthSwapchainImagesANDROID geben.
- Die Laufzeit kann blockieren, wenn zuvor abgerufene Swapchain-Bilder noch von der Laufzeit verwendet werden.
- Die Laufzeit muss
XR_ERROR_CALL_ORDER_INVALIDzurückgeben, wenn xrAcquireDepthSwapchainImagesANDROID vor xrBeginFrame oder nach xrEndFrame aufgerufen wird . - Die Laufzeit muss
XR_ERROR_LIMIT_REACHEDzurückgeben, wenn xrAcquireDepthSwapchainImagesANDROID mehr als einmal pro Frame aufgerufen wird, d.h. in einer laufenden Sitzung nach einem Aufruf von xrBeginFrame, dem kein zugehöriges xrEndFrame folgt . - Die Laufzeit kann
XR_ERROR_DEPTH_NOT_AVAILABLE_ANDROIDzurückgeben, wenn noch keine Daten zur Umgebungstiefe verfügbar sind. In diesem Fall sollte die Anwendung in einem späteren Frame noch einmal xrAcquireDepthSwapchainImagesANDROID aufrufen.
Gültige Nutzung (implizit)
- Die
XR_ANDROID_depth_texture-Erweiterung muss aktiviert werden, bevor xrAcquireDepthSwapchainImagesANDROID aufgerufen wird. -
depthSwapchainmuss ein gültiger XrDepthSwapchainANDROID-Handle sein -
acquireInfomuss ein Zeiger auf eine gültige XrDepthAcquireInfoANDROID-Struktur sein. -
acquireResultmuss ein Zeiger auf eine XrDepthAcquireResultANDROID-Struktur sein.
Rückgabecodes
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
Die Struktur XrDepthAcquireInfoANDROID ist so definiert:
typedef struct XrDepthAcquireInfoANDROID {
XrStructureType type;
const void* next;
XrSpace space;
XrTime displayTime;
} XrDepthAcquireInfoANDROID;
Mitgliederbeschreibungen
typeist der XrStructureType dieser Struktur.nextistNULLoder ein Zeiger auf die nächste Struktur in einer Strukturkette. Solche Strukturen sind in OpenXR Core oder dieser Erweiterung nicht definiert.spaceist ein XrSpace, der den Referenzrahmen der zurückgegebenen Pose in XrDepthAcquireResultANDROID ::viewsdefiniert .displayTimeist einXrTime, der die Zeit angibt, die zum Berechnen der Pose für die zurückgegebene Pose in XrDepthAcquireResultANDROID ::viewsverwendet wird . Anwendungen sollten die vorhergesagte Anzeigezeit für den aktuellen Frame übergeben.
Gültige Nutzung (implizit)
- Die Erweiterung
XR_ANDROID_depth_texturemuss aktiviert werden, bevor XrDepthAcquireInfoANDROID verwendet werden kann. -
typemussXR_TYPE_DEPTH_ACQUIRE_INFO_ANDROIDsein -
nextmussNULLoder ein gültiger Zeiger auf die nächste Struktur in einer Strukturkette sein. -
spacemuss ein gültiger XrSpace-Handle sein
Die Struktur XrDepthAcquireResultANDROID ist so definiert:
typedef struct XrDepthAcquireResultANDROID {
XrStructureType type;
const void* next;
uint32_t acquiredIndex;
XrTime exposureTimestamp;
XrDepthViewANDROID views[2];
} XrDepthAcquireResultANDROID;
Mitgliederbeschreibungen
typeist der XrStructureType dieser Struktur.nextistNULLoder ein Zeiger auf die nächste Struktur in einer Strukturkette. Solche Strukturen sind in OpenXR Core oder dieser Erweiterung nicht definiert.acquiredIndexist der Index der erfassten Textur im XrDepthSwapchainImageANDROID-Array, das von xrEnumerateDepthSwapchainImagesANDROID aufgezählt wird .exposureTimestampist derXrTime-Wert, der den Zeitpunkt angibt, zu dem die Tiefenkarte aufgenommen wurde.viewsist ein Array mit zwei XrDepthViewANDROID, einem für jedes Auge. Index 0 ist das linke Auge und Index 1 das rechte Auge.
Gültige Nutzung (implizit)
- Die
XR_ANDROID_depth_texture-Erweiterung muss aktiviert werden, bevor XrDepthAcquireResultANDROID verwendet werden kann. -
typemussXR_TYPE_DEPTH_ACQUIRE_RESULT_ANDROIDsein -
nextmussNULLoder ein gültiger Zeiger auf die nächste Struktur in einer Strukturkette sein. - Jedes Element von
viewsmuss eine gültige XrDepthViewANDROID-Struktur sein.
Die Struktur XrDepthViewANDROID ist so definiert:
typedef struct XrDepthViewANDROID {
XrStructureType type;
const void* next;
XrFovf fov;
XrPosef pose;
} XrDepthViewANDROID;
Mitgliederbeschreibungen
typeist der XrStructureType dieser Struktur.nextistNULLoder ein Zeiger auf die nächste Struktur in einer Strukturkette. Solche Strukturen sind in OpenXR Core oder dieser Erweiterung nicht definiert.fovist ein XrFovf, das das Sichtfeld angibt, das zum Generieren dieser Ansicht verwendet wurde. Die Ansicht wird weder horizontal noch vertikal gespiegelt.poseist ein XrPosef, das die Pose angibt, aus der die Tiefenkarte gerendert wurde. Der Referenzrahmen wird in XrDepthAcquireInfoANDROID angegeben .
Gültige Nutzung (implizit)
- Die
XR_ANDROID_depth_texture-Erweiterung muss aktiviert werden, bevor XrDepthViewANDROID verwendet werden kann. -
typemussXR_TYPE_DEPTH_VIEW_ANDROIDsein -
nextmussNULLoder ein gültiger Zeiger auf die nächste Struktur in einer Strukturkette sein.
Beispielcode für die Tiefenverfolgung
Der folgende Beispielcode zeigt, wie Sie Tiefenbilder erfassen und Tiefenwerte verwenden, um Tiefenbildkoordinaten dem Anzeigebereich zuzuordnen.
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
// ...
}
Neue Objekttypen
Neue Befehle
- xrAcquireDepthSwapchainImagesANDROID
- xrCreateDepthSwapchainANDROID
- xrDestroyDepthSwapchainANDROID
- xrEnumerateDepthResolutionsANDROID
- xrEnumerateDepthSwapchainImagesANDROID
Neue Strukturen
- XrDepthAcquireInfoANDROID
- XrDepthAcquireResultANDROID
- XrDepthSwapchainCreateInfoANDROID
- XrDepthSwapchainImageANDROID
- XrDepthViewANDROID
XrSystemProperties erweitern :
Neue Enums
Neue Bitmasken
Neue Enum-Konstanten
XR_ANDROID_DEPTH_TEXTURE_EXTENSION_NAMEXR_ANDROID_depth_texture_SPEC_VERSIONXrObjectType erweitern :
XR_OBJECT_TYPE_DEPTH_SWAPCHAIN_ANDROID
XrResult erweitern :
XR_ERROR_DEPTH_NOT_AVAILABLE_ANDROID
Erweitern von 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
Probleme
Versionsverlauf
Revision 1, 09.09.2024 (Levana Chen)
- Erste Beschreibung der Erweiterung