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वैल्यू का पॉइंटर होना चाहिए - अगर
supportedDataSourcesInputCapacity0नहीं है, तोsupportedDataSources,supportedDataSourcesInputCapacityXrFaceTrackingDataSourceANDROID वैल्यू के ऐरे का पॉइंटर होना चाहिए
रिटर्न कोड
XR_SUCCESS
XR_ERROR_FEATURE_UNSUPPORTEDXR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_HANDLE_INVALIDXR_ERROR_INSTANCE_LOSTXR_ERROR_RUNTIME_FAILUREXR_ERROR_SYSTEM_INVALIDXR_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 पर सेट करना ज़रूरी है. साथ ही, अन्य फ़ील्ड को अपरिभाषित माना जाता है.
मान्य इस्तेमाल (इंप्लिसिट)
- XrFaceTrackingDataSourceInfoANDROID का इस्तेमाल करने से पहले,
XR_ANDROID_face_tracking_data_sourceएक्सटेंशन को चालू करना ज़रूरी है -
typeज़रूरी तौर परXR_TYPE_FACE_TRACKING_DATA_SOURCE_INFO_ANDROIDहोना चाहिए -
next,NULLया स्ट्रक्चर चेन में मौजूद अगले स्ट्रक्चर का मान्य पॉइंटर होना चाहिए -
requestedDataSources,requestedDataSourceCountमान्य XrFaceTrackingDataSourceANDROID वैल्यू के ऐरे का पॉइंटर होना चाहिए -
requestedDataSourceCountपैरामीटर की वैल्यू,0से ज़्यादा होनी चाहिए
अनुमतियां
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 को पास किया जाता है, ताकि उस कॉल के लिए फ़ेस ट्रैकिंग डेटा जनरेट करने वाले डेटा सोर्स के बारे में क्वेरी की जा सके.
मान्य इस्तेमाल (इंप्लिसिट)
- XrFaceTrackingDataSourceStateANDROID का इस्तेमाल करने से पहले,
XR_ANDROID_face_tracking_data_sourceएक्सटेंशन को चालू करना ज़रूरी है -
typeज़रूरी तौर परXR_TYPE_FACE_TRACKING_DATA_SOURCE_STATE_ANDROIDहोना चाहिए -
next,NULLया स्ट्रक्चर चेन में मौजूद अगले स्ट्रक्चर का मान्य पॉइंटर होना चाहिए -
dataSource, XrFaceTrackingDataSourceANDROID की मान्य वैल्यू होनी चाहिए
डेटा सोर्स के साथ फ़ेस ट्रैकिंग के लिए कोड का उदाहरण.
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 (कैनी वर्केमर)
- एक्सटेंशन की शुरुआती जानकारी