Android 앱에 Geospatial API 사용 설정 (Kotlin/자바)

Geospatial API를 사용할 수 있도록 앱의 설정을 구성합니다.

기본 요건

계속 진행하기 전에 기본 AR 개념ARCore 세션 구성 방법을 이해해야 합니다.

샘플 앱 및 Codelab

이 동영상에서는 Geospatial API를 사용하여 지리적 데이터를 표시하고 실제 위치에 콘텐츠를 배치하는 앱을 빌드하는 단계를 안내합니다.

지리정보 Codelab 문서도 동일한 단계를 진행할 수 있습니다. 동영상에서 만든 샘플 앱을 실행하려면 ARCore Geospatial 빠른 시작을 참고하세요.

Geospatial API에 관한 자세한 내용은 Geospatial API 소개를 참고하세요.

ARCore로 개발하는 것이 처음이라면 시작하기에서 소프트웨어 및 하드웨어 요구사항, 기본 요건, 사용 중인 플랫폼과 관련된 기타 정보를 확인하세요.

개발 환경이 빠른 시작에 설명된 ARCore SDK 요구사항을 충족하는지 확인합니다.

ARCore API 사용 설정

앱에서 VPS (Visual Positioning System)를 사용하려면 먼저 새 Google Cloud 프로젝트 또는 기존 Google Cloud 프로젝트에서 ARCore API를 사용 설정해야 합니다. 이 서비스는 지리정보 앵커를 호스팅, 저장, 확인합니다.

키 없는 승인을 사용하는 것이 좋지만 API 키 승인도 지원됩니다.

앱에 필요한 라이브러리 추가

앱이 ARCore API를 호출하도록 승인한 후에는 앱에서 지리정보 기능을 사용 설정할 라이브러리를 추가해야 합니다.

앱의 build.gradle 파일에서 Play 서비스 위치 라이브러리를 포함하도록 Google Play 서비스를 설정합니다.

dependencies {
  // Apps must declare play-services-location version >= 16.
  // In the following line, substitute `16 (or later)` with the latest version.
  implementation 'com.google.android.gms:play-services-location:16 (or later)'
}

세션 구성에서 지리정보 기능 사용 설정

세션을 만들기 전에 세션 구성에서 GeospatialModeENABLED로 변경합니다.

자바

Config config = session.getConfig();
config.setGeospatialMode(Config.GeospatialMode.ENABLED);
session.configure(config);

Kotlin

// Enable the Geospatial API.
session.configure(session.config.apply { geospatialMode = Config.GeospatialMode.ENABLED })

지리정보 모드가 ENABLED로 설정되어 있으면 애플리케이션이 VPS (Visual Positioning System)에서 지리 정보를 가져올 수 있습니다.

사용자에게 기기 데이터 사용을 허용하라는 메시지 표시

ARCore Geospatial API를 사용하는 앱은 사용자에게 기기의 데이터 사용을 확인하고 허용하라는 메시지를 표시해야 합니다. 자세한 내용은 사용자 개인 정보 보호 요구사항을 참고하세요.

기기 호환성 확인

빠른 시작에 설명된 대로 ARCore를 지원하는 모든 기기가 Geospatial API를 지원하는 것은 아닙니다.

사용자 기기의 호환성을 확인하려면 Session.checkGeospatialModeSupported()를 호출합니다. false가 반환되면 아래에서 세션을 구성하려고 시도하지 마세요. 이렇게 하면 UnsupportedConfigurationException이 발생합니다.

런타임 시 사용자에게 위치 정보 액세스 권한 요청

앱에서 런타임 시 위치 정보 액세스 권한을 요청해야 합니다.

ARCore Geospatial API를 사용하려면 앱에서 다음과 같은 추가 권한을 등록해야 합니다.

  • ACCESS_FINE_LOCATION를 사용하여 사용자의 위치를 정확하게 확인합니다.

  • ACCESS_COARSE_LOCATION: 사용자의 위치를 정확하게 파악하지 못하고 사용자 개인 정보 보호 요구사항을 준수하기 위해 그러나 대략적인 위치로 작동하도록 Geospatial API를 구성할 수는 없으며 사용자가 이 권한을 설정하면 API 요청이 실패합니다. 자세한 정보는 아래를 참고하세요.

  • ACCESS_INTERNET: ARCore Geospatial API 서비스에 연결

<manifest ... >
  <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
  <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
  <uses-permission android:name="android.permission.INTERNET" />
</manifest>

Android 버전 12 이상을 실행하는 기기에서는 앱이 대략적인 위치 정보에만 액세스하도록 사용자가 요청할 수 있습니다. 이 요청을 수용하려면 앱에 위와 같이 ACCESS_FINE_LOCATION와 함께 ACCESS_COARSE_LOCATION 권한이 구성되어 있어야 합니다. 두 위치 권한을 모두 구성해야 합니다.

그러나 사용자가 대략적인 위치를 지정하면 Geospatial API에서 필요한 정확한 위치를 가져올 수 없습니다. 앱에서 대략적인 위치만 제공하는 경우 Geospatial 서비스는 구성할 수 없습니다. 앱에서 대략적인 위치로 Geospatial API를 사용할 수 없습니다.

기기의 현재 위치에서 Geospatial 사용 가능 여부 확인

Geospatial API는 VPS 및 GPS의 조합을 사용하여 지리정보 포즈를 결정하므로 기기가 위치를 확인할 수 있는 한 API를 사용할 수 있습니다. 실내 공간 및 밀집한 도시 환경과 같이 GPS 정확도가 낮은 지역에서는 API가 VPS 범위를 사용하여 높은 정확성 포즈를 생성합니다. 일반적인 조건에서 VPS는 약 5m의 위치 정확도와 5도 이하의 회전 정확도를 제공할 수 있습니다. Session.checkVpsAvailabilityAsync()를 사용하여 지정된 위치에 VPS 적용 범위가 있는지 확인합니다.

Geospatial API는 VPS 적용 범위가 없는 지역에서도 사용할 수 있습니다. 상단에 장애물이 거의 없거나 없는 야외 환경에서는 GPS만으로도 높은 정확도로 포즈를 생성할 수 있습니다.

다음 단계