XR_ANDROID_eye_tracking
名前文字列
XR_ANDROID_eye_tracking
拡張機能の種類
インスタンス拡張機能
登録済み拡張機能番号
457
リビジョン
1
批准ステータス
批准されていません
拡張機能とバージョンの依存関係
最終更新日
2025-01-17
IP ステータス
既知の IP クレームはありません。
寄与者
Spencer Quin(Google)
Jared Finder(Google)
Levana Chen(Google)
Kenny Vercaemer(Google)
Prasanthi Gurumurthy(Google)
Nihav Jain(Google)
概要
この拡張機能を使用すると、アプリケーションはユーザーの目の位置と向き、およびアイ トラッキングのステータスを取得できます。
アイ トラッキング データは、粗いモードと細かいモードの 2 つのモードで提供されます。粗いトラッキングでは、ユーザーの目の粗い推定値が提供されますが、細かいトラッキングでは、より正確な推定値が提供されます。粗いトラッキングは、基本的なアバターのような表現を提供したいアプリケーションを対象としていますが、細かいトラッキングは、より正確なアプリケーションを対象としています。
インタラクションには、XR_EXT_eye_gaze_interaction を使用する必要があります 。
権限
Android アプリケーションは、マニフェストに android.permission.EYE_TRACKING_COARSE 権限または android.permission.EYE_TRACKING_FINE 権限を記載する必要があります 。これらの権限は危険な権限と見なされます。アプリケーションは、これらの関数を使用するために、実行時に権限をリクエストする必要があります 。
- xrCreateEyeTrackerANDROID(権限のいずれか 1 つ)
- xrGetCoarseTrackingEyesInfoANDROID(android.permission.EYE_TRACKING_COARSE)
- xrGetFineTrackingEyesInfoANDROID(android.permission.EYE_TRACKING_FINE)
(保護レベル: 危険)
システム機能の検査
XrSystemEyeTrackingPropertiesANDROID 構造体は次のように定義されます。
typedef struct XrSystemEyeTrackingPropertiesANDROID {
XrStructureType type;
void* next;
XrBool32 supportsEyeTracking;
} XrSystemEyeTrackingPropertiesANDROID;
メンバーの説明
typeは、この構造体の XrStructureType です。nextは、NULLまたは構造体チェーン内の次の構造体へのポインタです。このような構造体は、コア OpenXR またはこの拡張機能では定義されていません。supportsEyeTrackingは、現在のシステムがアイ トラッキングをサポートしているかどうかを示すXrBool32です。
アプリケーションは、xrGetSystemProperties を呼び出すときに XrSystemProperties を XrSystemEyeTrackingPropertiesANDROID 構造体で拡張することで、システムがアイ トラッキングに対応しているかどうかを検査できます 。
ランタイムが XR_FALSE に対して supportsEyeTracking を返す場合のみ、ランタイムは xrCreateEyeTrackerANDROID から XR_ERROR_FEATURE_UNSUPPORTED を返す必要があります 。
有効な使用方法(暗黙的)
- XrSystemEyeTrackingPropertiesANDROID を使用する前に、
XR_ANDROID_eye_tracking拡張機能を有効にする必要があります -
typeはXR_TYPE_SYSTEM_EYE_TRACKING_PROPERTIES_ANDROIDである**必要があります** -
nextは、NULLまたは構造体チェーン内の次の構造体への有効なポインタである**必要があります**。
アイトラッカー ハンドルの作成
XR_DEFINE_HANDLE(XrEyeTrackerANDROID)
XrEyeTrackerANDROID ハンドルは、目をトラッキングし、ユーザーが見ている場所を正確にマッピングするアイトラッカーを表します。
アイ トラッキング データは機密性の高い個人情報であり、個人のプライバシーと完全性に密接に関連しています。アイ トラッキング データを保存または転送するアプリケーションでは、常にユーザーに明示的な同意を求めることを強くおすすめします。
アプリケーションは、このハンドルを使用して、この拡張機能の他の関数を使用してアイ トラッキング データにアクセスします。
アイ トラッキングは、シーン内の目のポーズとステータスの表現を提供します。
xrCreateEyeTrackerANDROID 関数は次のように定義されます。
XrResult xrCreateEyeTrackerANDROID(
XrSession session,
const XrEyeTrackerCreateInfoANDROID* createInfo,
XrEyeTrackerANDROID* eyeTracker);
パラメータの説明
sessionは、XrSession ハンドルで、アイ トラッキングが有効になります。createInfoは、アイ トラッキングの指定に使用される XrEyeTrackerCreateInfoANDROID です。eyeTrackerは、返される XrEyeTrackerANDROID ハンドルです。
アプリケーションは、XrEyeTrackerANDROID ハンドルを xrCreateEyeTrackerANDROID 関数を使用して作成します。
システムがアイ トラッキングをサポートしていない場合、ランタイムは 返す必要があります XR_ERROR_FEATURE_UNSUPPORTED xrCreateEyeTrackerANDROID から 。
有効な使用方法(暗黙的)
-
XR_ANDROID_eye_tracking拡張機能を xrCreateEyeTrackerANDROID を呼び出す前に有効にする必要があります。 -
sessionは有効な XrSession ハンドルである必要があります -
createInfoは、有効な XrEyeTrackerCreateInfoANDROID 構造体へのポインタである**必要があります** 。 -
eyeTrackerは、XrEyeTrackerANDROID ハンドルへのポインタである**必要があります**。
戻りコード
XR_SUCCESSXR_SESSION_LOSS_PENDING
XR_ERROR_FEATURE_UNSUPPORTEDXR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_HANDLE_INVALIDXR_ERROR_INSTANCE_LOSTXR_ERROR_LIMIT_REACHEDXR_ERROR_OUT_OF_MEMORYXR_ERROR_RUNTIME_FAILUREXR_ERROR_SESSION_LOSTXR_ERROR_VALIDATION_FAILURE
XrEyeTrackerCreateInfoANDROID 構造体は次のように定義されます。
typedef struct XrEyeTrackerCreateInfoANDROID {
XrStructureType type;
const void* next;
} XrEyeTrackerCreateInfoANDROID;
メンバーの説明
typeは、この構造体の XrStructureType です。nextは、NULLまたは構造体チェーン内の次の構造体へのポインタです。このような構造体は、コア OpenXR またはこの拡張機能では定義されていません。
XrEyeTrackerCreateInfoANDROID 構造体は、XrEyeTrackerANDROID ハンドルを作成するための情報を記述します。
有効な使用方法(暗黙的)
- XrEyeTrackerCreateInfoANDROID を使用する前に、
XR_ANDROID_eye_tracking拡張機能を有効にする必要があります -
typeはXR_TYPE_EYE_TRACKER_CREATE_INFO_ANDROIDである**必要があります** -
nextは、NULLまたは構造体チェーン内の次の構造体への有効なポインタである**必要があります**。
xrDestroyEyeTrackerANDROID 関数は次のように定義されます。
XrResult xrDestroyEyeTrackerANDROID(
XrEyeTrackerANDROID eyeTracker);
パラメータの説明
eyeTrackerは、XrEyeTrackerANDROID で以前に作成された xrCreateEyeTrackerANDROID です。
xrDestroyEyeTrackerANDROID 関数は、アイ トラッキング エクスペリエンスが終了すると、eyeTracker と基盤となるリソースを解放します。
有効な使用方法(暗黙的)
-
XR_ANDROID_eye_tracking拡張機能を xrDestroyEyeTrackerANDROID を呼び出す前に有効にする 必要があります -
eyeTrackerは有効な XrEyeTrackerANDROID ハンドルである必要があります
スレッドセーフ
eyeTrackerと子ハンドルへのアクセスは、外部で同期する必要があります 。
戻りコード
XR_SUCCESS
XR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_HANDLE_INVALID
目の情報の取得
xrGetCoarseTrackingEyesInfoANDROID 関数は次のように定義されます。
XrResult xrGetCoarseTrackingEyesInfoANDROID(
XrEyeTrackerANDROID eyeTracker,
const XrEyesGetInfoANDROID* getInfo,
XrEyesANDROID* eyesOutput);
パラメータの説明
eyeTrackerは、XrEyeTrackerANDROID で以前に作成された xrCreateEyeTrackerANDROID です。getInfoは、目のポーズと状態のクエリに使用する情報を提供する XrEyesGetInfoANDROID へのポインタです。eyesOutputは、ポーズや状態などの返された目の情報を含む XrEyesANDROID へのポインタです。
xrGetCoarseTrackingEyesInfoANDROID 関数は、ユーザーのプライバシーを保護する方法で、目の状態とポーズの情報を取得します。
アプリケーションに android.permission.EYE_TRACKING_COARSE 権限がない場合、ランタイムは XR_ERROR_PERMISSION_INSUFFICIENT を返す必要があります 。
目のポーズは、XrEyesGetInfoANDROID :: time の XrEyesGetInfoANDROID :: baseSpace で表されます。
目のポーズの位置と方向は、いつでもトラッキングまたはトラッキング解除されます。つまり、ランタイムは、指定された XrEyesANDROID :: eyes で XR_SPACE_LOCATION_POSITION_TRACKED_BIT と XR_SPACE_LOCATION_ORIENTATION_TRACKED_BIT の両方を設定するか、XR_SPACE_LOCATION_POSITION_TRACKED_BIT と XR_SPACE_LOCATION_ORIENTATION_TRACKED_BIT の両方をクリアし、XrEyesANDROID :: mode を設定してトラッキング状態を示す必要があります 。
有効な使用方法(暗黙的)
- xrGetCoarseTrackingEyesInfoANDROID を呼び出す前に、
XR_ANDROID_eye_tracking拡張機能を有効にする必要があります 。 -
eyeTrackerは有効な XrEyeTrackerANDROID ハンドルである必要があります -
getInfoは、有効な XrEyesGetInfoANDROID 構造体へのポインタである**必要があります** -
eyesOutputは、XrEyesANDROID 構造体へのポインタである**必要があります**
戻りコード
XR_SUCCESSXR_SESSION_LOSS_PENDING
XR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_HANDLE_INVALIDXR_ERROR_INSTANCE_LOSTXR_ERROR_LIMIT_REACHEDXR_ERROR_OUT_OF_MEMORYXR_ERROR_PERMISSION_INSUFFICIENTXR_ERROR_RUNTIME_FAILUREXR_ERROR_SESSION_LOSTXR_ERROR_TIME_INVALIDXR_ERROR_VALIDATION_FAILURE
xrGetFineTrackingEyesInfoANDROID 関数は次のように定義されます。
XrResult xrGetFineTrackingEyesInfoANDROID(
XrEyeTrackerANDROID eyeTracker,
const XrEyesGetInfoANDROID* getInfo,
XrEyesANDROID* eyesOutput);
パラメータの説明
eyeTrackerは、XrEyeTrackerANDROID で以前に作成された xrCreateEyeTrackerANDROID です。getInfoは、必要な出力を指定するために使用される XrEyesGetInfoANDROID へのポインタです。eyesOutputは、ポーズや状態などの返された目の情報を含む XrEyesANDROID へのポインタです。
xrGetFineTrackingEyesInfoANDROID 関数は、xrGetCoarseTrackingEyesInfoANDROID よりも高い精度で目の状態とポーズの情報を取得します。
アプリケーションに android.permission.EYE_TRACKING_FINE 権限がない場合、ランタイムは XR_ERROR_PERMISSION_INSUFFICIENT を返す必要があります 。
目の情報は、xrGetFineTrackingEyesInfoANDROID の呼び出し時のベース空間に対して、XrEyesGetInfoANDROID :: time 、XrEyesGetInfoANDROID :: baseSpace を使用して解決され、相対的に解決されます。ランタイムは、呼び出し時に XrEyesGetInfoANDROID :: baseSpace で定義された場所を解決する必要があります 。
目のポーズの位置と方向は、いつでもトラッキングまたはトラッキング解除されます。つまり、ランタイムは、指定された XrEyesANDROID :: eyes で XR_SPACE_LOCATION_POSITION_TRACKED_BIT と XR_SPACE_LOCATION_ORIENTATION_TRACKED_BIT の両方を設定するか、XR_SPACE_LOCATION_POSITION_TRACKED_BIT と XR_SPACE_LOCATION_ORIENTATION_TRACKED_BIT の両方をクリアし、XrEyesANDROID :: mode を設定してトラッキング状態を示す必要があります 。
有効な使用方法(暗黙的)
-
XR_ANDROID_eye_tracking拡張機能を xrGetFineTrackingEyesInfoANDROID を呼び出す前に有効にする 必要があります 。 -
eyeTrackerは有効な XrEyeTrackerANDROID ハンドルである必要があります -
getInfoは、有効な XrEyesGetInfoANDROID 構造体へのポインタである**必要があります** -
eyesOutputは、XrEyesANDROID 構造体へのポインタである**必要があります**
戻りコード
XR_SUCCESSXR_SESSION_LOSS_PENDING
XR_ERROR_FUNCTION_UNSUPPORTEDXR_ERROR_HANDLE_INVALIDXR_ERROR_INSTANCE_LOSTXR_ERROR_LIMIT_REACHEDXR_ERROR_OUT_OF_MEMORYXR_ERROR_PERMISSION_INSUFFICIENTXR_ERROR_RUNTIME_FAILUREXR_ERROR_SESSION_LOSTXR_ERROR_TIME_INVALIDXR_ERROR_VALIDATION_FAILURE
XrEyesGetInfoANDROID 構造体には、目のポーズと状態を取得するために必要な情報が含まれています。
typedef struct XrEyesGetInfoANDROID {
XrStructureType type;
const void* next;
XrTime time;
XrSpace baseSpace;
} XrEyesGetInfoANDROID;
メンバーの説明
typeは、この構造体の XrStructureType です。nextは、NULLまたは構造体チェーン内の次の構造体へのポインタです。このような構造体は、コア OpenXR またはこの拡張機能では定義されていません。timeは、baseSpaceを基準とした座標を評価するXrTimeです。baseSpaceは、目のポーズがtimeで相対的に配置される XrSpace です。
有効な使用方法(暗黙的)
-
XR_ANDROID_eye_tracking拡張機能を XrEyesGetInfoANDROID を使用する前に有効にする必要があります -
typeはXR_TYPE_EYES_GET_INFO_ANDROIDである**必要があります** -
nextは、NULLまたは構造体チェーン内の次の構造体への有効なポインタである**必要があります**。 -
baseSpaceは有効な XrSpace ハンドルである必要があります
XrEyesANDROID 構造体には、トラッキングされた目に関する情報が含まれています。
typedef struct XrEyesANDROID {
XrStructureType type;
void* next;
XrEyeANDROID eyes[XR_EYE_MAX_ANDROID];
XrEyeTrackingModeANDROID mode;
} XrEyesANDROID;
メンバーの説明
typeは、この構造体の XrStructureType です。nextは、NULLまたは構造体チェーン内の次の構造体へのポインタです。このような構造体は、コア OpenXR またはこの拡張機能では定義されていません。eyesは、XrEyeIndexANDROID でインデックス付けされた左右の目のXR_EYE_MAX_ANDROIDサイズの XrEyeANDROID の配列です。modeは、現在トラッキングしている目を示す XrEyeTrackingModeANDROID です。
有効な使用方法(暗黙的)
- XrEyesANDROID を使用する前に、
XR_ANDROID_eye_tracking拡張機能を有効にする必要があります -
typeはXR_TYPE_EYES_ANDROIDである**必要があります** -
nextは、NULLまたは構造体チェーン内の次の構造体への有効なポインタである**必要があります**。 -
eyesの任意の要素は、有効な XrEyeANDROID 構造体である必要があります。 -
modeは有効な XrEyeTrackingModeANDROID 値である必要があります
XrEyeANDROID 構造体は、目の状態、位置、向きを表します。
typedef struct XrEyeANDROID {
XrEyeStateANDROID eyeState;
XrPosef eyePose;
} XrEyeANDROID;
メンバーの説明
eyeStateは、目の XrEyeStateANDROID です。eyePoseは、対応する XrEyesGetInfoANDROID ::baseSpaceの参照フレーム内の目の瞳孔の位置と向きを定義する XrPosef です。ここで、同一の向きは、ユーザーの目に +Z、右に +X、上に +Y の座標軸を表します。
有効な使用方法(暗黙的)
- XrEyeANDROID を使用する前に、
XR_ANDROID_eye_tracking拡張機能を有効にする必要があります -
eyeStateは有効な XrEyeStateANDROID 値である必要があります
XrEyeStateANDROID 列挙型は、トラッキングされた目のさまざまな状態を識別します。
typedef enum XrEyeStateANDROID {
XR_EYE_STATE_INVALID_ANDROID = 0,
XR_EYE_STATE_GAZING_ANDROID = 1,
XR_EYE_STATE_SHUT_ANDROID = 2,
XR_EYE_STATE_MAX_ENUM_ANDROID = 0x7FFFFFFF
} XrEyeStateANDROID;
列挙型には次の意味があります。
列挙型の説明
XR_EYE_STATE_INVALID_ANDROID
目がエラー状態にあるか、存在しないことを示します。
XR_EYE_STATE_GAZING_ANDROID
目が現在凝視していることを示します。
XR_EYE_STATE_SHUT_ANDROID
まばたきや瞬きで目が閉じていることを示します。
XrEyeIndexANDROID 列挙型は、左目または右目のインデックスを識別します。
typedef enum XrEyeIndexANDROID {
XR_EYE_INDEX_LEFT_ANDROID = 0,
XR_EYE_INDEX_RIGHT_ANDROID = 1,
XR_EYE_INDEX_MAX_ENUM_ANDROID = 0x7FFFFFFF
} XrEyeIndexANDROID;
列挙型には次の意味があります。
列挙型の説明
XR_EYE_INDEX_LEFT_ANDROID
左目。
XR_EYE_INDEX_RIGHT_ANDROID
右目。
XrEyeTrackingModeANDROID 列挙型は、トラッキングされた目のさまざまな状態を識別します。
typedef enum XrEyeTrackingModeANDROID {
XR_EYE_TRACKING_MODE_NOT_TRACKING_ANDROID = 0,
XR_EYE_TRACKING_MODE_RIGHT_ANDROID = 1,
XR_EYE_TRACKING_MODE_LEFT_ANDROID = 2,
XR_EYE_TRACKING_MODE_BOTH_ANDROID = 3,
XR_EYE_TRACKING_MODE_MAX_ENUM_ANDROID = 0x7FFFFFFF
} XrEyeTrackingModeANDROID;
列挙型には次の意味があります。
列挙型の説明
XR_EYE_TRACKING_MODE_NOT_TRACKING_ANDROID
アイ トラッキングが現在アクティブでないことを示します。
XR_EYE_TRACKING_MODE_RIGHT_ANDROID
右目のみがトラッキングしていることを示します。
XR_EYE_TRACKING_MODE_LEFT_ANDROID
左目のみがトラッキングしていることを示します。
XR_EYE_TRACKING_MODE_BOTH_ANDROID
左右両方の目がトラッキングしていることを示します。
アイ トラッキングのサンプルコード
次のサンプルコードは、ビュー空間を基準とした目の情報を取得する方法を示しています。
XrSession session; // previously initialized, e.g. created at app startup.
XrSpace viewSpace; // space created for XR_REFERENCE_SPACE_TYPE_VIEW.
// The function pointers are previously initialized using xrGetInstanceProcAddr.
PFN_xrCreateEyeTrackerANDROID xrCreateEyeTrackerANDROID; // previously initialized
PFN_xrDestroyEyeTrackerANDROID xrDestroyEyeTrackerANDROID; // previously initialized
PFN_xrGetCoarseTrackingEyesInfoANDROID xrGetCoarseTrackingEyesInfoANDROID; // previously initialized
PFN_xrGetFineTrackingEyesInfoANDROID xrGetFineTrackingEyesInfoANDROID; // previously initialized
// This will use the XrSession that is bound to the eye tracker done at time of creation.
XrEyeTrackerANDROID eyeTracker;
XrEyeTrackerCreateInfoANDROID createInfo{
.type = XR_TYPE_EYE_TRACKER_CREATE_INFO_ANDROID,
.next = nullptr};
CHK_XR(xrCreateEyeTrackerANDROID(session, &createInfo, &eyeTracker));
while (1) {
// ...
// For every frame in frame loop
// ...
XrFrameState frameState; // previously returned from xrWaitFrame
const XrTime time = frameState.predictedDisplayTime;
XrEyesANDROID fineEyesInfo{.type = XR_TYPE_EYES_ANDROID,
.next = nullptr,
.mode = XR_EYE_TRACKING_MODE_BOTH_ANDROID};
XrEyesANDROID coarseEyesInfo{.type = XR_TYPE_EYES_ANDROID,
.next = nullptr,
.mode = XR_EYE_TRACKING_MODE_BOTH_ANDROID};
XrEyesGetInfoANDROID eyesGetInfo{.type = XR_TYPE_EYES_GET_INFO_ANDROID,
.next = nullptr,
.time = time,
.baseSpace = viewSpace};
CHK_XR(xrGetCoarseTrackingEyesInfoANDROID(eyeTracker, &eyesGetInfo, &coarseEyesInfo));
CHK_XR(xrGetFineTrackingEyesInfoANDROID(eyeTracker, &eyesGetInfo, &fineEyesInfo));
// eyes tracking information is now available:
// drawLeftEye(eyesInfo.eyes[XR_EYE_INDEX_LEFT_ANDROID].eyePose);
// drawRightEye(eyesInfo.eyes[XR_EYE_INDEX_RIGHT_ANDROID].eyePose);
// ...
// Finish frame loop
// ...
}
// after usage
CHK_XR(xrDestroyEyeTrackerANDROID(eyeTracker));
新しいオブジェクトの種類
新しいコマンド
- xrCreateEyeTrackerANDROID
- xrDestroyEyeTrackerANDROID
- xrGetCoarseTrackingEyesInfoANDROID
- xrGetFineTrackingEyesInfoANDROID
新しい構造体
- XrEyeANDROID
- XrEyeTrackerCreateInfoANDROID
- XrEyesANDROID
- XrEyesGetInfoANDROID
XrSystemProperties の拡張 :
新しい列挙型
新しい列挙型定数
XR_ANDROID_EYE_TRACKING_EXTENSION_NAMEXR_ANDROID_eye_tracking_SPEC_VERSIONXR_EYE_MAX_ANDROIDXrObjectType の拡張 :
XR_OBJECT_TYPE_EYE_TRACKER_ANDROID
XrStructureType の拡張 :
XR_TYPE_EYES_ANDROIDXR_TYPE_EYES_GET_INFO_ANDROIDXR_TYPE_EYE_TRACKER_CREATE_INFO_ANDROIDXR_TYPE_SYSTEM_EYE_TRACKING_PROPERTIES_ANDROID
問題
変更履歴
リビジョン 1、2025-01-17(Kenny Vercaemer)
- 拡張機能の最初の説明