Geospatial API を使用するようにアプリの設定を完了したら、ArEarth_getCameraGeospatialPose
を呼び出して、最新フレームにおけるカメラのデバイスの地理空間位置を記述する ArGeospatialPose
を取得できます。このポーズは ArEarth
オブジェクトで管理され、次の情報を含みます。
- 緯度と経度で表されるロケーション
- 標高
- EUS 座標系で、ユーザーの向いている方向を近似する向き。X+ は東、Y+ は上、Z+ は南向きです。
追跡ステータスを確認する
地理空間値は、ArEarth.ArTrackingState
が ArTrackingState.AR_TRACKING_STATE_TRACKING
で、ArEarth.ArEarthState
が AR_EARTH_STATE_ENABLED
である場合にのみ有効です。すべての Geospatial API 呼び出しを ArEarth.ArTrackingState
コントロール ブロックでラップします。
if (ar_earth != NULL) { ArTrackingState earth_tracking_state = AR_TRACKING_STATE_STOPPED; ArTrackable_getTrackingState(ar_session, (ArTrackable*)ar_earth, &earth_tracking_state); if (earth_tracking_state == AR_TRACKING_STATE_TRACKING) { ArGeospatialPose* camera_geospatial_pose = NULL; ArGeospatialPose_create(ar_session, &camera_geospatial_pose); ArEarth_getCameraGeospatialPose(ar_session, ar_earth, camera_geospatial_pose); // camera_geospatial_pose contains geodetic location, rotation, and // confidences values. ArGeospatialPose_destroy(camera_geospatial_pose); } }
ArEarth.ArTrackingState
が ArTrackingState.AR_TRACKING_STATE_TRACKING
にならない場合、ArEarth.ArTrackingState
は AR_TRACKING_STATE_PAUSED
または AR_TRACKING_STATE_STOPPED
になります。上記のどちらの条件にも当てはまらない場合は、ArEarth.ArEarthState
を確認してください。ArEarth
オブジェクトによるトラッキングの妨げとなる他のエラー状態が表示されます。
正確にポーズをとる
デバイスをデフォルトの向きで縦向きにすると、AR トラッキングと自然に整合するため、ピッチ角(X+)とロール角(Z+)が正確になる傾向があります。ただし、ヨー(Y+)角度は、VPS データの可用性とその場所の時間的条件に応じて異なります。アプリによっては精度を上げるために調整が必要になる場合があります。
ArGeospatialPose_getOrientationYawAccuracy()
は特定の ArGeospatialPose
のヨー(Y+)角度の精度を推定します。向きのヨー精度は、ArGeospatialPose_getEastUpSouthQuaternion()
から返されたヨー角を中心とする 68 パーセンタイル信頼レベルの半径を度数で表す数値です。つまり、ArGeospatialPose
の実際のヨー角度が正確である可能性は 68% です。
値が大きいほど、精度が低くなります。例えば、推定されたヨー角度が 60 度でヨー精度が 10 度の場合、真のヨー角度が 50 度から 70 度の間にある確率は 68% です。
次のステップ
- アンカーの地理空間のポーズを取得して、地理空間アンカーを配置します。