XR_ANDROID_recommended_resolution
Name String
XR_ANDROID_recommended_resolution
Erweiterungstyp
Instanzerweiterung
Registrierte Durchwahlnummer
462
Revision
1
Ratifikationsstatus
Nicht ratifiziert
Abhängigkeiten von Erweiterungen und Versionen
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
systemIdundviewConfigurationTypezurückgeben.
Die Struktur XrEventDataRecommendedResolutionChangedANDROID ist so definiert:
typedef struct XrEventDataRecommendedResolutionChangedANDROID {
XrStructureType type;
const void* next;
} XrEventDataRecommendedResolutionChangedANDROID;
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.
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)
- Die
XR_ANDROID_recommended_resolution-Erweiterung muss aktiviert werden, bevor XrEventDataRecommendedResolutionChangedANDROID verwendet werden kann. -
typemussXR_TYPE_EVENT_DATA_RECOMMENDED_RESOLUTION_CHANGED_ANDROIDsein -
nextmussNULLoder ein gültiger Zeiger auf die nächste Struktur in einer Strukturkette sein.
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