デバイスのカメラの地理空間ポーズを取得する

Geospatial API を使用するようにアプリの設定を完了したら、ArEarth_getCameraGeospatialPose を呼び出して、最新フレームにおけるカメラのデバイスの地理空間位置を記述する ArGeospatialPose を取得できます。このポーズは ArEarth オブジェクトで管理され、次の情報を含みます。

  • 緯度と経度で表されるロケーション
  • 標高
  • EUS 座標系で、ユーザーの向いている方向を近似する向き。X+ は東、Y+ は上、Z+ は南向きです。

追跡ステータスを確認する

地理空間値は、ArEarth.ArTrackingStateArTrackingState.AR_TRACKING_STATE_TRACKING で、ArEarth.ArEarthStateAR_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.ArTrackingStateArTrackingState.AR_TRACKING_STATE_TRACKING にならない場合、ArEarth.ArTrackingStateAR_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% です。

次のステップ