XR_ANDROID_enumerate_system_extension_properties

Name String

XR_ANDROID_enumerate_system_extension_properties

نوع الإضافة

إضافة مثيل

رقم الإضافة المسجَّل

725

المراجعة

1

حالة التصديق

لم تتم المصادقة

الاعتماديات على الإضافات والإصدارات

OpenXR 1.0

تاريخ آخر تعديل

2026-02-11

حالة عنوان IP

ما مِن مطالبات معروفة بشأن الملكية الفكرية.

المساهمون

Spencer Quin، Google
Nihav Jain، Google
Kenny Vercaemer، Google

نظرة عامة

تتيح هذه الإضافة للتطبيقات تحديد الإضافات المتوافقة مع إعدادات النظام الحالية. حتى إذا كان وقت التشغيل يتيح استخدام إضافة، قد لا تتوافق مع أجهزة النظام الحالية.

يتم تعريف بنية XrSystemExtensionPropertiesANDROID على النحو التالي:

typedef struct XrSystemExtensionPropertiesANDROID {
    XrStructureType          type;
    void*                    next;
    XrExtensionProperties    properties;
    XrBool32                 isSupported;
} XrSystemExtensionPropertiesANDROID;

أوصاف الأعضاء

  • type هو XrStructureType لهذه البنية.
  • next هو NULL أو مؤشر إلى البنية التالية في سلسلة البنية.
  • properties هو XrExtensionProperties الذي يتضمّن اسم الإضافة.
  • isSupported هي قيمة منطقية تشير إلى ما إذا كان النظام يتيح استخدام الإضافة حاليًا.

الاستخدام الصالح (الضمني)

يتم تعريف بنية XrEventDataSystemPropertiesChangedANDROID على النحو التالي:

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

أوصاف الأعضاء

  • type هو XrStructureType لهذه البنية.
  • next هو NULL أو مؤشر إلى البنية التالية في سلسلة البنية.

يجب أن يضع وقت التشغيل هذا الحدث في قائمة الانتظار عندما تتغيّر خصائص إضافة النظام. على سبيل المثال، عند توصيل أجهزة طرفية جديدة تتيح وظائف جديدة

يجب أن تعرض جميع طلبات xrEnumerateSystemExtensionPropertiesANDROID القيمة نفسها إلى أن يتم وضع حدث جديد XrEventDataSystemPropertiesChangedANDROID في قائمة الانتظار.

عندما يتلقّى تطبيق هذا الحدث، يجب أن يستدعي xrEnumerateSystemExtensionPropertiesANDROID مرة أخرى لتحديد أحدث خصائص إضافات النظام، وربما إنشاء أدوات التتبُّع المرتبطة بهذه الإضافات أو إيقافها حسب الحاجة.

الاستخدام الصالح (الضمني)

يتم تعريف الدالة xrEnumerateSystemExtensionPropertiesANDROID على النحو التالي:

XrResult xrEnumerateSystemExtensionPropertiesANDROID(
    XrInstance                                  instance,
    XrSystemId                                  systemId,
    uint32_t                                    propertyCapacityInput,
    uint32_t*                                   propertyCountOutput,
    XrSystemExtensionPropertiesANDROID*         properties);

أوصاف المَعلمات

  • instance هو XrInstance صالح .
  • systemId هو معرّف صالح لنظام sliink:XrSystemId لاسترداد سمات الإضافة.
  • propertyCapacityInput هي سعة مصفوفة properties، أو 0 للإشارة إلى طلب استرداد السعة المطلوبة.
  • propertyCountOutput هو عدد سمات الإضافة المطلوبة.
  • properties هي مصفوفة من بنى XrSystemExtensionPropertiesANDROID. يمكن أن تكون القيمة NULL إذا كانت قيمة propertyCapacityInput هي 0.
  • راجِع قسم مَعلمات حجم المخزن المؤقت للحصول على وصف تفصيلي حول كيفية استرداد حجم properties المطلوب.

الاستخدام الصالح (الضمني)

  • يجب تفعيل الإضافة XR_ANDROID_enumerate_system_extension_properties قبل استدعاء xrEnumerateSystemExtensionPropertiesANDROID
  • يجب أن يكون instance مقبض XrInstance صالحًا
  • يجب أن يكون propertyCountOutput مؤشرًا إلى قيمة uint32_t
  • إذا لم يكن propertyCapacityInput هو 0 ، properties يجب أن يكون مؤشرًا إلى مصفوفة من بنى propertyCapacityInput XrSystemExtensionPropertiesANDROID

رموز الإرجاع

ناجحة

  • XR_SUCCESS

فشل

  • XR_ERROR_FUNCTION_UNSUPPORTED
  • XR_ERROR_HANDLE_INVALID
  • XR_ERROR_INSTANCE_LOST
  • XR_ERROR_RUNTIME_FAILURE
  • XR_ERROR_SYSTEM_INVALID
  • XR_ERROR_VALIDATION_FAILURE

مثال

XrInstance instance; // XrInstance previously created

XrSystemId systemId; // XrSystemId from a previously created instance

PFN_xrEnumerateSystemExtensionPropertiesANDROID xrEnumerateSystemExtensionPropertiesANDROID;

// 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_SYSTEM_PROPERTIES_CHANGED_ANDROID:
            // It's possible that the system was lost and a new id will be returned
            XrSystemId newSystemId;
            XrSystemGetInfo getInfo = {XR_TYPE_SYSTEM_GET_INFO};
            getInfo.formFactor = XR_FORM_FACTOR_HEAD_MOUNTED_DISPLAY;
            if(XR_SUCCESS == xrGetSystem(instance, &getInfo, &newSystemId)) {
                if(systemId != newSystemId) {
                    //Do things like recreate the session
                    systemId = newSystemId;
                }
            }

            // Enumerate the extensions to see which ones are now supported based on hardware changes
            uint32_t extensionsCount;
            xrEnumerateSystemExtensionPropertiesANDROID(instance, systemId, 0, &extensionsCount, NULL);

            std::vector<XrSystemExtensionPropertiesANDROID> properties(extensionsCount,
                {.type = XR_TYPE_SYSTEM_EXTENSION_PROPERTIES_ANDROID});

            XrResult result = xrEnumerateSystemExtensionPropertiesANDROID(
                instance,
                systemId,
                extensionsCount,
                &extensionsCount,
                properties.data()
            );

            // Do something based on which extensions are now supported by the system
            break;
    }
}
PFN_xrEnumerateSystemExtensionPropertiesANDROID xrEnumerateSystemExtensionPropertiesANDROID;

XrInstance instance;
XrInstanceCreateInfo createInfo = {XR_TYPE_INSTANCE_CREATE_INFO};
// Initialize the createInfo with appropriate values for the application
CHK_XR(xrCreateInstance(&createInfo, &instance));

// Get the systemId for the system.
XrSystemId systemId;
XrSystemGetInfo getInfo = {XR_TYPE_SYSTEM_GET_INFO};
getInfo.formFactor = XR_FORM_FACTOR_HEAD_MOUNTED_DISPLAY;
CHK_XR(xrGetSystem(instance, &getInfo, &systemId));

// Enumerate the system extension properties.
uint32_t extensionsCount;
xrEnumerateSystemExtensionPropertiesANDROID(instance, systemId, 0, &extensionsCount, NULL);

std::vector<XrSystemExtensionPropertiesANDROID> properties(extensionsCount,
    {.type = XR_TYPE_SYSTEM_EXTENSION_PROPERTIES_ANDROID});

XrResult result = xrEnumerateSystemExtensionPropertiesANDROID(
    instance,
    systemId,
    extensionsCount,
    &extensionsCount,
    properties.data()
);

المشاكل

سجلّ التعديلات

  • المراجعة 1، ‎17-03-2026 (كيني فيركامير)

    • إصدار الإضافة الأوّلي