XR_ANDROID_face_tracking_data_source

Name String

XR_ANDROID_face_tracking_data_source

एक्सटेंशन टाइप

इंस्टेंस एक्सटेंशन

रजिस्टर किया गया एक्सटेंशन नंबर

707

बदलाव

1

पुष्टि की स्थिति

पुष्टि नहीं की गई

एक्सटेंशन और वर्शन की डिपेंडेंसी

XR_ANDROID_face_tracking

पिछली बार बदलाव किए जाने की तारीख

2025-12-16

आईपी स्टेटस

आईपी से जुड़े किसी भी दावे की जानकारी नहीं है.

योगदान देने वाले

कैनी वर्केमर, Google
यिंगलेई झांग, Google
निहाव जैन, Google
स्पेंसर क्विन, Google

खास जानकारी

इस एक्सटेंशन की मदद से, ऐप्लिकेशन को कई डेटा सोर्स से फ़ेस ट्रैकिंग का डेटा मिलता है.

क्वेरी के लिए इस्तेमाल किए जा सकने वाले डेटा सोर्स

ऐप्लिकेशन को, फ़ेस ट्रैकिंग के लिए इस्तेमाल किए जा सकने वाले डेटा सोर्स की सूची पाने के लिए, xrEnumerateFaceTrackingDataSourcesANDROID को कॉल करना चाहिए.

xrEnumerateFaceTrackingDataSourcesANDROID फ़ंक्शन को इस तरह से परिभाषित किया गया है:

XrResult                                                                                 xrEnumerateFaceTrackingDataSourcesANDROID(
    XrInstance                                  instance,
    XrSystemId                                  systemId,
    uint32_t                                    supportedDataSourcesInputCapacity,
    uint32_t*                                   supportedDataSourcesOutputCount,
    XrFaceTrackingDataSourceANDROID*            supportedDataSources);

पैरामीटर की जानकारी

  • instance, XrInstance का हैंडल है .
  • systemId वह XrSystemId है जिसके लिए फ़ेस ट्रैकिंग के डेटा सोर्स की गिनती की जाएगी.
  • supportedDataSourcesInputCapacity, supportedDataSources ऐरे की क्षमता है. अगर आपको ज़रूरी क्षमता वापस पाने का अनुरोध करना है, तो इसे 0 पर सेट करें.
  • supportedDataSourcesOutputCount, इस्तेमाल किए जा सकने वाले डेटा सोर्स की संख्या है. अगर supportedDataSourcesInputCapacity कम है, तो यह ज़रूरी क्षमता है.
  • supportedDataSources, XrFaceTrackingDataSourceANDROID का ऐरे है . अगर supportedDataSourcesInputCapacity की वैल्यू 0 है, तो इसकी वैल्यू NULL हो सकती है.
  • ज़रूरी supportedDataSources का साइज़ वापस पाने के बारे में ज़्यादा जानकारी के लिए, बफ़र साइज़ के पैरामीटर सेक्शन देखें.

ऐप्लिकेशन, xrEnumerateFaceTrackingDataSourcesANDROID फ़ंक्शन को कॉल करके, सिस्टम के साथ काम करने वाले डेटा सोर्स की सूची बना सकता है.

अगर XrSystemFaceTrackingPropertiesANDROID :: supportsFaceTracking की वैल्यू XR_TRUE है, तो रनटाइम को xrEnumerateFaceTrackingDataSourcesANDROID से XR_FACE_TRACKING_DATA_SOURCE_IMAGE_ANDROID की वैल्यू भी ज़रूर दिखानी चाहिए .

अगर रनटाइम में कोई डेटा सोर्स नहीं मिलता है, तो इसका मतलब है कि इसमें किसी भी तरह की फ़ेस ट्रैकिंग की सुविधा नहीं है.

रनटाइम को डेटा सोर्स, सबसे अच्छी क्वालिटी से लेकर सबसे खराब क्वालिटी के क्रम में ज़रूर दिखाने चाहिए.

मान्य इस्तेमाल (इंप्लिसिट)

  • xrEnumerateFaceTrackingDataSourcesANDROID को कॉल करने से पहले, XR_ANDROID_face_tracking_data_source एक्सटेंशन को चालू करना ज़रूरी है
  • instance, XrInstance का मान्य हैंडल होना चाहिए
  • supportedDataSourcesOutputCount, uint32_t वैल्यू का पॉइंटर होना चाहिए
  • अगर supportedDataSourcesInputCapacity 0 नहीं है, तो supportedDataSources, supportedDataSourcesInputCapacity XrFaceTrackingDataSourceANDROID वैल्यू के ऐरे का पॉइंटर होना चाहिए

रिटर्न कोड

सफल

  • XR_SUCCESS

Failure

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

XrFaceTrackingDataSourceANDROID इन्यूमरेशन से, उन अलग-अलग डेटा सोर्स की पहचान होती है जिन्हें रनटाइम सपोर्ट कर सकता है.

typedef enum XrFaceTrackingDataSourceANDROID {
    XR_FACE_TRACKING_DATA_SOURCE_IMAGE_ANDROID = 1,
    XR_FACE_TRACKING_DATA_SOURCE_AUDIO_ANDROID = 2,
    XR_FACE_TRACKING_DATA_SOURCE_MULTIMODAL_ANDROID = 3,
    XR_FACE_TRACKING_DATA_SOURCE_MAX_ENUM_ANDROID = 0x7FFFFFFF
} XrFaceTrackingDataSourceANDROID;

इन वैल्यू का मतलब यहां दिया गया है:

Enum की जानकारी

XR_FACE_TRACKING_DATA_SOURCE_IMAGE_ANDROID

इससे पता चलता है कि यह कॉन्फ़िगरेशन, इमेज डेटा का इस्तेमाल करता है

XR_FACE_TRACKING_DATA_SOURCE_AUDIO_ANDROID

इससे पता चलता है कि यह कॉन्फ़िगरेशन, ऑडियो डेटा का इस्तेमाल करता है

XR_FACE_TRACKING_DATA_SOURCE_MULTIMODAL_ANDROID

इससे पता चलता है कि यह कॉन्फ़िगरेशन, इमेज और ऑडियो डेटा का इस्तेमाल करता है

डेटा सोर्स कॉन्फ़िगर करना

XrFaceTrackingDataSourceInfoANDROID स्ट्रक्चर के बारे में यहां बताया गया है:

typedef struct XrFaceTrackingDataSourceInfoANDROID {
    XrStructureType                           type;
    const void*                               next;
    uint32_t                                  requestedDataSourceCount;
    const XrFaceTrackingDataSourceANDROID*    requestedDataSources;
} XrFaceTrackingDataSourceInfoANDROID;

सदस्यों के बारे में जानकारी

  • type इस स्ट्रक्चर का XrStructureType है.
  • next, NULL होता है या स्ट्रक्चर चेन में अगले स्ट्रक्चर का पॉइंटर होता है. इस तरह के स्ट्रक्चर, OpenXR के मुख्य स्पेसिफ़िकेशन या इस एक्सटेंशन में तय नहीं किए गए हैं.
  • requestedDataSourceCount, ऐप्लिकेशन के अनुरोध किए गए डेटा सोर्स की संख्या है.
  • requestedDataSources, XrFaceTrackingDataSourceANDROID वैल्यू का ऐरे है. इसमें ऐप्लिकेशन के अनुरोध किए गए डेटा सोर्स के बारे में जानकारी दी गई है.

XrFaceTrackingDataSourceInfoANDROID स्ट्रक्चर, XrFaceTrackerANDROID हैंडल बनाने के लिए डेटा सोर्स के बारे में बताता है.

कोई ऐप्लिकेशन, xrCreateFaceTrackerANDROID को कॉल करते समय, चेहरे को ट्रैक करने के लिए एक या उससे ज़्यादा डेटा सोर्स का अनुरोध करने के लिए, XrFaceTrackerCreateInfoANDROID स्ट्रक्चर की अगली चेन में XrFaceTrackingDataSourceInfoANDROID स्ट्रक्चर पास कर सकता है .

अगर ऐप्लिकेशन में कोई डेटा सोर्स नहीं है या xrEnumerateFaceTrackingDataSourcesANDROID ने किसी भी डेटा सोर्स की गिनती नहीं की है, तो रनटाइम को XR_ERROR_VALIDATION_FAILURE दिखाना ज़रूरी है .

अगर उपयोगकर्ता ने अनुरोध किए गए सभी डेटा सोर्स के लिए, ज़रूरी अनुमतियां नहीं दी हैं, तो रनटाइम को XR_ERROR_PERMISSION_INSUFFICIENT ज़रूर दिखाना चाहिए .

हर डेटा सोर्स के लिए ज़रूरी अनुमतियों के बारे में यहां बताया गया है:

  • XR_FACE_TRACKING_DATA_SOURCE_IMAGE_ANDROID के लिए, android.permission.FACE_TRACKING की अनुमति ज़रूरी है.
  • XR_FACE_TRACKING_DATA_SOURCE_AUDIO_ANDROID के लिए, android.permission.RECORD_AUDIO की अनुमति ज़रूरी है.
  • XR_FACE_TRACKING_DATA_SOURCE_MULTIMODAL_ANDROID के लिए, android.permission.FACE_TRACKING और android.permission.RECORD_AUDIO, दोनों अनुमतियां ज़रूरी हैं.

रनटाइम को XrFaceTrackingDataSourceInfoANDROID : requestedDataSources ऐरे को, ऐप्लिकेशन के हिसाब से सबसे ज़्यादा प्राथमिकता से लेकर सबसे कम प्राथमिकता तक के तौर पर समझना ज़रूरी है. रनटाइम को, अनुरोध किए गए पहले डेटा सोर्स का इस्तेमाल करके ट्रैकिंग डेटा जनरेट करना ज़रूरी है. साथ ही, यह भी ज़रूरी है कि यह डेटा सोर्स, ज़रूरी अनुमतियों का पालन करता हो. अगर ट्रैकर के लाइफ़टाइम के दौरान अनुमति वापस ले ली जाती है, तो डेटा सोर्स का इस्तेमाल नहीं किया जा सकेगा. ऐसे में, रनटाइम को ज़रूर सबसे ज़्यादा प्राथमिकता वाले अगले डेटा सोर्स का इस्तेमाल करने की कोशिश करनी चाहिए. अगर अनुरोध किए गए किसी भी डेटा सोर्स का इस्तेमाल नहीं किया जा सकता, तो रनटाइम को xrGetFaceStateANDROID को कॉल करते समय, XrFaceStateANDROID :: isValid को XR_FALSE पर सेट करना ज़रूरी है. साथ ही, अन्य फ़ील्ड को अपरिभाषित माना जाता है.

मान्य इस्तेमाल (इंप्लिसिट)

अनुमतियां

Android ऐप्लिकेशन के मेनिफ़ेस्ट में, उन अनुमतियों की सूची दी गई होनी चाहिए जिनके लिए ऐप्लिकेशन अनुरोध करता है. android.permission.FACE_TRACKING अनुमति को खतरनाक अनुमति माना जाता है. android.permission.RECORD_AUDIO अनुमति को खतरनाक अनुमति माना जाता है. इन फ़ंक्शन का इस्तेमाल करने के लिए, ऐप्लिकेशन को रनटाइम के दौरान अनुमतियों का अनुरोध ज़रूर करना चाहिए:

(सुरक्षा का लेवल: खतरनाक)

XrFaceTrackingDataSourceStateANDROID स्ट्रक्चर के बारे में यहां बताया गया है:

typedef struct XrFaceTrackingDataSourceStateANDROID {
    XrStructureType                    type;
    void*                              next;
    XrFaceTrackingDataSourceANDROID    dataSource;
} XrFaceTrackingDataSourceStateANDROID;

सदस्यों के बारे में जानकारी

  • type इस स्ट्रक्चर का XrStructureType है.
  • next, NULL होता है या स्ट्रक्चर चेन में अगले स्ट्रक्चर का पॉइंटर होता है. इस तरह के स्ट्रक्चर, OpenXR के मुख्य स्पेसिफ़िकेशन या इस एक्सटेंशन में तय नहीं किए गए हैं.
  • dataSource, XrFaceTrackingDataSourceANDROID है. इसका इस्तेमाल, फ़ेस ट्रैकिंग का डेटा जनरेट करने के लिए किया जाता है.

कोई ऐप्लिकेशन, XrFaceTrackingDataSourceStateANDROID स्ट्रक्चर को XrFaceStateANDROID स्ट्रक्चर से लिंक कर सकता है. इस स्ट्रक्चर को xrGetFaceStateANDROID को पास किया जाता है, ताकि उस कॉल के लिए फ़ेस ट्रैकिंग डेटा जनरेट करने वाले डेटा सोर्स के बारे में क्वेरी की जा सके.

मान्य इस्तेमाल (इंप्लिसिट)

डेटा सोर्स के साथ फ़ेस ट्रैकिंग के लिए कोड का उदाहरण.

XrInstance instance; // previously initialized
XrSystemId systemId; // previously initialized
XrSession session; // previously initialized, e.g. created at app startup.

// The function pointers are previously initialized using xrGetInstanceProcAddr.
PFN_xrCreateFaceTrackerANDROID xrCreateFaceTrackerANDROID; // previously initialized
PFN_xrDestroyFaceTrackerANDROID xrDestroyFaceTrackerANDROID; // previously initialized
PFN_xrGetFaceStateANDROID xrGetFaceStateANDROID; // previously initialized
PFN_xrEnumerateFaceTrackingDataSourcesANDROID xrEnumerateFaceTrackingDataSourcesANDROID; // previously initialized
bool (*requestPermission)(const char* permission);

// Inspect data sources supported by the system.
uint32_t dataSourcesCount = 0;
CHK_XR(xrEnumerateFaceTrackingDataSourcesANDROID(instance, systemId, dataSourcesCount,
       &dataSourcesCount, nullptr));
std::vector<XrFaceTrackingDataSourceANDROID> dataSources(dataSourcesCount);
CHK_XR(xrEnumerateFaceTrackingDataSourcesANDROID(instance, systemId, dataSourcesCount,
       &dataSourcesCount, dataSources.data()));

if (dataSources.size() == 0) {
  // System does not support face tracking at all ...
  return;
}

auto requestDataSourcePermissions = [requestPermission](XrFaceTrackingDataSourceANDROID dataSource) {
  switch (dataSource) {
    case XR_FACE_TRACKING_DATA_SOURCE_IMAGE_ANDROID:
      return requestPermission("android.permission.FACE_TRACKING");
    case XR_FACE_TRACKING_DATA_SOURCE_AUDIO_ANDROID:
      return requestPermission("android.permission.RECORD_AUDIO");
    case XR_FACE_TRACKING_DATA_SOURCE_MULTIMODAL_ANDROID:
      return requestPermission("android.permission.FACE_TRACKING") &&
             requestPermission("android.permission.RECORD_AUDIO");
    default:
      return false;
  }
};

// Request permissions and remove data sources that are not granted.
for (uint32_t i = 0; i < dataSources.size();) {
  if (requestDataSourcePermissions(dataSources[i])) {
    ++i;
    continue;
  }

  dataSources.erase(dataSources.begin() + i);
}

if (dataSources.size() == 0) {
  // User denied all permissions, cannot create face tracker.
  return;
}

// Create face tracker with requested data sources.
XrFaceTrackerANDROID faceTracker;
XrFaceTrackingDataSourceInfoANDROID
        faceTrackerModeInfo{.type = XR_TYPE_FACE_TRACKING_DATA_SOURCE_INFO_ANDROID,
                       .next = nullptr,
                       .requestedDataSourceCount = static_cast<uint32_t>(
                           dataSources.size()),
                       .requestedDataSources = dataSources.data()};
XrFaceTrackerCreateInfoANDROID
        createInfo{.type = XR_TYPE_FACE_TRACKER_CREATE_INFO_ANDROID,
                    .next = &faceTrackerModeInfo};
CHK_XR(xrCreateFaceTrackerANDROID(session, &createInfo, &faceTracker));

XrFaceTrackingDataSourceStateANDROID dataSourceState{
  .type = XR_TYPE_FACE_TRACKING_DATA_SOURCE_STATE_ANDROID,
  .next = nullptr};
XrFaceStateANDROID faceState;
float faceExpressionParameters[XR_FACE_PARAMETER_COUNT_ANDROID];
faceState.type = XR_TYPE_FACE_STATE_ANDROID;
faceState.next = &dataSourceState;
faceState.parametersCapacityInput = XR_FACE_PARAMETER_COUNT_ANDROID;
faceState.parameters = faceExpressionParameters;

while (1) {
    // ...
    // For every frame in the frame loop
    // ...
    XrFrameState frameState; // previously returned from xrWaitFrame

    XrFaceStateGetInfoANDROID faceGetInfo{
            .type = XR_TYPE_FACE_STATE_GET_INFO_ANDROID,
            .next = nullptr,
            .time = frameState.predictedDisplayTime,
    };

    CHK_XR(xrGetFaceStateANDROID(faceTracker, &faceGetInfo, &faceState));
    if (faceState.isValid) {
        for (uint32_t i = 0; i < XR_FACE_PARAMETER_COUNT_ANDROID; ++i) {
            // parameters[i] contains a weight of specific blend shape
        }

        // If the system changes data source because of permission changes,
        // handle the new data source ...
        switch (dataSourceState.dataSource) {
          default:
            break;
        }
    }
}

// after usage
CHK_XR(xrDestroyFaceTrackerANDROID(faceTracker));

समस्याएं

वर्शन इतिहास

  • पहला संशोधन, 07-10-2024 (कैनी वर्केमर)

    • एक्सटेंशन की शुरुआती जानकारी