Name String

XR_ANDROID_recommended_resolution

Erweiterungstyp

Instanzerweiterung

Registrierte Durchwahlnummer

462

Revision

1

Ratifikationsstatus

Nicht ratifiziert

Abhängigkeiten von Erweiterungen und Versionen

OpenXR 1.0

Datum der letzten Änderung

IP-Status

Mitwirkende

Trevor Debrechtabel, Google
Spencer Quin, Google
Lachlan Ford, Google
Vasiliy Baranov, Google

Übersicht

Mit dieser Erweiterung kann die Laufzeit die Anwendung benachrichtigen, wenn sich die empfohlene Auflösung basierend auf der aktuellen Systemleistung, der Geräte-Temperatur oder anderen Faktoren ändert.

Diese Erweiterung ändert die Spezifikation so:

  • Die Laufzeit kann für die Lebensdauer der Instanz nicht identische Pufferinhalte aus der xrEnumerateViewConfigurationViews-Aufzählung für die angegebene systemId und viewConfigurationType zurückgeben.

Die Struktur XrEventDataRecommendedResolutionChangedANDROID ist so definiert:

typedef struct XrEventDataRecommendedResolutionChangedANDROID {
    XrStructureType    type;
    const void*        next;
} XrEventDataRecommendedResolutionChangedANDROID;

Mitgliederbeschreibungen

  • type ist der XrStructureType dieser Struktur.
  • next ist NULL oder ein Zeiger auf die nächste Struktur in einer Strukturkette. Solche Strukturen sind in OpenXR Core oder dieser Erweiterung nicht definiert.

Wenn Sie die Ereignisstruktur XrEventDataRecommendedResolutionChangedANDROID erhalten, bedeutet das, dass sich die empfohlene Auflösung geändert hat. Die Anwendung sollte die Laufzeit mit xrEnumerateViewConfigurationViews nach der neuen empfohlenen Auflösung fragen .

Gültige Nutzung (implizit)

Beispielcode

Der folgende Beispielcode zeigt, wie Sie auf Ereignisse für empfohlene Änderungen der Auflösung warten.

// Created at app startup time.
XrInstance instance;
XrSystemId systemId; // Previously initialized.
uint32_t viewCountOutput; // Previously initialized.

// View configuration type the application uses.
XrViewConfigurationType viewConfigType;

// Poll events for recommended resolution changes.
XrEventDataBuffer event = {XR_TYPE_EVENT_DATA_BUFFER};
XrResult result = xrPollEvent(instance, &event);
if (result == XR_SUCCESS) {
  switch (event.type) {
    case XR_TYPE_EVENT_DATA_RECOMMENDED_RESOLUTION_CHANGED_ANDROID: {
        uint32_t viewCapacityInput = viewCountOutput;
        std::vector<XrViewConfigurationView> views(viewCapacityInput);
        result = xrEnumerateViewConfigurationViews(instance, systemId,
          viewConfigType, viewCapacityInput, &viewCountOutput, views.data());
        if(!XR_SUCCEEDED(result)) {
          // Handle error
        }

        // New recommended resolution is found in
        // views.recommendedImageRectWidth and views.recommendedImageRectHeight
        // Change the resolution for the viewConfigType
      break;
    }
    default:
      break;
  }
}

Versionsverlauf

  • Version 1, 04.04.2025 (Kenny Vercaemer)

    • Erste Beschreibung der Erweiterung