자주 묻는 질문(FAQ)

제품 세부정보

문제

네트워크

데이터

UI 맞춤설정

라우팅

시뮬레이터

워크플로

이동성 서비스

제품 세부정보

앱은 각 운전자가 수락해야 하는 Navigation SDK 서비스 약관 알림이 포함된 대화상자를 구현해야 합니다. 이 대화상자를 통해 운전자는 서비스 약관에 동의할 수 있습니다. 약관의 텍스트 파일은 Navigation SDK와 함께 제공됩니다.
Android에서는 NavigationApi.showTermsAndConditionsDialog 메서드를 사용하여 약관이 포함된 대화상자를 표시합니다.
iOS에서는 GMSNavigationServices.showTermsAndConditionsDialogIfNeededWithCompanyName를 호출합니다.
Google 지도 모바일에서 지원하는 모든 언어는 Navigation SDK에서 자동으로 사용할 수 있습니다. 기기에는 기본 시스템 언어가 있으며 앱은 이 설정을 변경할 수 없습니다. 하지만 앱은 70개가 넘는 언어에 액세스할 수 있습니다.

예. Android에서는 일단 시작되면 LocationListener가 백그라운드에서 계속 실행됩니다. 앱은 계속해서 도로에 맞춰 위치를 스냅하고 방향을 유지합니다.

iOS에서 백그라운드에서 위치 및 방향의 위치 업데이트를 계속 수신하려면 도로 스냅을 구현하고 allowsBackgroundLocationUpdatesYES로 설정합니다.

예. 경로가 생성되거나 변경되면 RouteChangeListener가 다중선을 제공합니다.

아니요. Navigation SDK를 사용하려면 기기에 Google 지도 모바일이 설치되어 있지 않아도 됩니다.
아니요. 현재 Navigation SDK는 이 기능을 제공하지 않습니다.
예. 기본적으로 트래픽 방향이 표시되며 사용할 수 있습니다.

문제

Xcode 12에서 앱은 시뮬레이터용으로 올바르게 빌드되지 않습니다. 이 문제를 해결하려면 어떻게 해야 하나요?

이 문제를 해결하려면 Xcode 프로젝트 빌드 설정을 열고 'iOS 시뮬레이터' 빌드의 경우에만 Excluded Architecturesarm64를 추가합니다.

자세한 내용은 다음 StackOverflow 스레드를 참고하세요.

GMSMapView가 로드되지 않습니다.

GMSMapView가 로드되지 않는 경우:

  • Cloud 콘솔에서 NavSDK가 사용 설정되어 있는지 확인합니다.
  • Nav SDK가 설치되어 있지만 프로젝트에서 Nav SDK API를 사용하지 않는 경우 바이너리에서 삭제합니다.

네트워크

Navigation SDK는 연결 상태가 좋지 않은 경우 어떻게 처리하나요?
Navigation SDK는 각 이동 경로의 경로를 미리 캐시합니다. 사전 캐시된 정보에는 15~20분 동안의 경로 정보와 운전자가 경로에서 벗어날 경우의 대체 경로가 포함됩니다. Navigation SDK는 기기 GPS 및 센서를 사용하여 위치를 대략적으로 추정합니다.
오프라인 모드를 사용할 수 있나요?
아니요. 현재 Navigation SDK는 오프라인 모드를 제공하지 않습니다. 하지만 SDK는 경로에 대해 사전 캐시된 정보를 제공합니다.

데이터

경로를 시작하기 전에 경로의 모든 정류장/도착지를 가져올 수 있나요?

예. Android에서 경로의 경로를 가져오려면 Navigator.getRouteSegments()를 호출합니다.

iOS에서는 GMSNavigator.routeLegs(read)를 호출합니다.

경로 시작 시 세부 경로 안내를 사용할 수 있나요?
예. Navigation SDK는 경로 세그먼트 목록을 제공합니다. 또한 운전자는 헤더의 경로 카드를 스와이프하여 각 조작을 확인할 수 있습니다.
ETA는 앱 사용자에게 어떻게 전달되나요?

Android에서 다음 단계에 따라 앱 사용자에게 도착 예정 시간 정보를 제공합니다.

  1. Navigator.getTimeAndDistanceList()를 사용하여 모든 웨이포인트의 시간과 거리를 가져옵니다.
  2. 현재 운전자 도착 예정 시간에 대해 수행하는 것처럼 이 정보를 클라이언트 애플리케이션에 전달합니다.

iOS에서는 다음 단계에 따라 앱 사용자에게 도착 예정 시간 정보를 제공합니다.

  1. Navigator.getRouteSegments()를 사용하여 여정의 구간을 검색합니다.
  2. 각 여정 구간에 대해 GMSNavigator.timeToNextDestination를 호출합니다.
  3. 현재 운전자 도착 예정 시간에 대해 수행하는 것처럼 시간 정보를 클라이언트 애플리케이션에 전달합니다.
내비게이션이 포그라운드에 있지 않은 경우 RoadSnappedLocationProvider를 사용하여 운전자의 현재 스냅 위치를 가져올 수 있나요?

예. Android에서 RoadSnappedLocationProvider는 기본적으로 백그라운드에서 실행됩니다.

iOS에서 백그라운드에서 탐색을 계속 실행하려면 GMSRoadSnappedLocationProviderListener의 리스너를 구현하고 allowsBackgroundLocationUpdates 속성을 TRUE로 설정합니다.

Navigation SDK는 지오펜싱을 지원하나요?

아니요. 탐색 컨텍스트에서 remainingTimeOrdistanceChangeListener는 단순한 지오펜스에 비해 유리합니다. 경계 지역은 도로 도형을 고려하지 않을 수 있으며 운전자가 이동하는 정확한 지점에 중심을 두지 않을 수 있습니다.

remainingTimeOrdistanceChangeListener를 사용하여 이 기능을 근사할 수 있습니다.

  1. 콜백 빈도를 결정하는 기준점을 설정합니다.
  2. 목적지까지의 남은 거리를 확인합니다.

예를 들어 임곗값을 100m로 설정하면 목적지까지의 거리가 100m 변경될 때 콜백이 수신됩니다. 거리가 줄어들면 이 임곗값을 더 작은 값으로 업데이트하고 콜백을 더 자주 수신할 수 있습니다. 그런 다음 남은 거리를 확인하여 픽업/반납 장소에 충분히 가까운지 확인합니다.

iOS에서 리스너 GMSNavigatorListener.didUpdateRemainingDistance를 구현하여 알림 간 거리를 관리합니다.

내비게이션 앱이 백그라운드에 있을 때 알림을 사용 중지할 수 있나요?

예. Android에서는 Navigator.setHeadsUpNotificationEnabled를 사용하여 알림을 제어합니다. 이 메서드에는 불리언 인수가 있습니다. FALSE는 알림을 사용 중지하고 TRUE는 알림을 사용 설정합니다.

iOS에서 GMSRoadSnappedLocationProvider.allowsBackgroundLocationUpdates를 NO로 설정하여 도로 스냅 위치의 백그라운드 알림을 사용 중지합니다.

다른 위치 알림의 백그라운드 처리를 사용 중지하려면 GMSNavigator.sendsBackgroundNotifications(NO)를 호출합니다.

UI 맞춤설정

가장 좋은 경로 옵션을 색상으로 구분할 수 있나요?
아니요. 현재 특정 경로 옵션에 색상 코딩을 적용하는 기능은 지원되지 않습니다.
Navigation SDK에서 최종 목적지의 도착 예정 시간을 표시할 수 있나요?

예. Android에서는 다음 메서드를 사용합니다.

  1. Navigator.getTimeAndDistanceList()를 사용하여 모든 웨이포인트의 시간과 거리를 가져옵니다.
  2. NavigationFragment.setEtaCardEnabled(false)를 사용하여 현재 중간 지점의 도착 예정 시간을 숨깁니다.
  3. 최종 도착 시간(ETA)을 렌더링합니다.

iOS에서는 다음을 사용하세요.

  1. GMSNavigator.routeLegs(read)를 호출합니다.
  2. 마지막 단계에서 GMSNavigator.timeToNextDestination를 호출합니다.
  3. MSMapView.settings.navigationFooterEnabled=NO를 FALSE로 사용하여 현재 중간 지점의 도착 예정 시간을 숨깁니다.
  4. 최종 도착 시간(ETA)을 렌더링합니다.
ETA 업데이트를 숨기려면 어떻게 해야 하나요?

다음 방법으로 ETA 카드를 사용 중지할 수 있습니다.

  • Android에서는 navigationView.setEtaCardEnabled(false)를 사용합니다.
  • iOS에서는 GMSMapView.settings.navigationFooterEnabled=NO를 사용합니다.
헤더 및 바닥글 카드에 어떤 UI 맞춤설정을 사용할 수 있나요?

Android에서는 StylingOptions를 사용하여 배경 색상 스타일을 설정합니다. 헤더와 바닥글을 숨기거나 표시하려면 NavigationFragmentsetHeaderEnabledsetFooterEnabled 멤버 함수를 사용합니다.

iOS에서는 GMSMapView.settings.navigationHeaderPrimaryBackgroundColor를 사용하여 배경 색상 스타일을 설정합니다. 헤더와 바닥글을 숨기거나 표시하려면 GMSUISettingsnavigationFooterEnablednavigationHeaderEnabled 속성을 사용합니다.

라우팅

운전자에게 특정 경로를 제공하거나 대체 경로를 삭제할 수 있나요?
아니요. 기본적으로 여러 경로가 제공되며 가장 빠른 경로가 우선 적용됩니다. 요청에 '고속도로 및 통행료 회피'와 같은 환경설정을 추가하여 기본 경로에 영향을 줄 수 있습니다. 웨이포인트를 추가하면 경로에도 영향을 미칩니다.
앱 사용자에게 기본 대상 위치와 다른 대상 라벨을 표시할 수 있나요?

예. Android에서 대상의 맞춤 제목과 위도/경도를 사용하여 Marker를 만듭니다. Navigation SDK는 NavigationMap에 맞춤 제목과 좌표를 표시합니다.

iOS에서는 대상의 GMSMarker를 만들고 표시합니다.

Navigation SDK를 사용하여 정의된 경로에서의 이탈을 추적할 수 있나요?

예. Android에서는 Navigator.setRouteChangedListener를 사용하여 경로가 변경되거나 새로운 경로가 추천될 때 알림을 수신합니다.

  1. Navigator.setRouteChangedListener 메서드를 사용하여 경로를 따라 기기 위치를 확인하는 리스너를 등록합니다.
  2. 콜백 이벤트 핸들러 onRouteChanged에 코드를 추가합니다.
    • 업데이트된 도착 예정 시간 및 거리 정보가 포함된 메시지를 앱 사용자에게 전송합니다.
    • 기기 위치 추적
    • [선택사항] 운전자가 지정된 경로를 벗어날 때 처리하는 데 앱에 필요한 다른 기능을 추가합니다.

iOS에서는 GMSNavigator 및 리스너를 사용하여 경로가 변경되거나 새 경로가 권장될 때 알림을 수신합니다.

  1. 지도의 뷰 컨트롤러에서 GMSNavigatorListener 프로토콜과 GMSRoadSnappedLocationProviderListener 프로토콜을 구현합니다.
  2. GMSNavigatorListener.navigatorDidChangeRoute를 구현합니다.
  3. GMSNavigatorrouteLegscurrentRouteLeg 속성을 사용하여 새 경로에 액세스합니다.
운전자가 경로를 완료하지 않고 탐색을 종료할 수 있나요?

예. Android에서 Navigator.stopGuidance() 메서드를 호출하여 내비게이션을 중지합니다.

iOS에서는 GMSNavigator.clearDestinations를 호출합니다.

시뮬레이터

시뮬레이터는 경로 변경을 지원하나요?

예. Android에서 simulateLocationsAlongNewRoute를 호출하여 경로 변경이 포함된 이동을 시뮬레이션합니다. simulateLocationsAlongExistingRoute 메서드는 기존 경로의 변경사항을 무시합니다.

iOS에서는 GMSLocationSimulator.simulateAlongNewRouteToDestinations를 사용하여 경로 변경이 포함된 이동 경로를 시뮬레이션합니다. 경로 변경이 예상되지 않으면 GMSLocationSimulator.simulateLocationsAlongExistingRoute 또는 GMSLocationSimulator.simulateAlongNewRouteToDestinations를 사용할 수 있습니다.

워크플로

탐색 프래그먼트가 포함된 활동을 닫은 후 알림을 닫으려면 어떻게 해야 하나요?

탐색 알림은 탐색 중, 활동이 닫혔을 때 계속 표시됩니다. 차량이 목적지에 도착하면 내비게이션이 중지되고 알림이 사라집니다.

알림 클릭을 처리하려면 Navigator.startGuidance(intent resumeIntent)를 사용하세요. resume intent는 앱 사용자가 알림을 클릭하면 실행됩니다. 일반적으로 Navigator.startguidance(getIntent())는 앱 사용자가 알림을 클릭할 때 Activity를 호출하는 기본 Activity에서 호출됩니다.

이동성 서비스

모빌리티 서비스 고객의 Navigation SDK 사용은 어떻게 다른가요?

Google Maps Platform Mobility Services는 운송 및 물류 비즈니스의 엔터프라이즈 요구사항을 지원하는 API 및 SDK 모음을 제공합니다. 이동성 서비스 고객의 경우 Navigation SDK는 일반적으로 경로 최적화, 전달, 작업 추적, 차량 분석 등을 위한 관련 서비스와 함께 사용됩니다. 또한 Mobility Services 고객의 경우 Navigation SDK에 별도의 요금이 청구됩니다. 자세한 내용은 모빌리티 서비스 문서를 참고하세요.

이동성 제품은 현재 일부 고객에게만 제공됩니다. 자세한 내용은 영업 담당자에게 문의하세요.

이동통신 서비스 고객인지 어떻게 알 수 있나요?
현재 내비게이션 SDK를 모빌리티 서비스 고객으로 구현하고 있는지 확실하지 않다면 코드에서 ReportBillableEvent 호출을 찾습니다. 이동성 서비스 고객만 ReportBillableEvent 메서드를 호출해야 합니다.

이동성 서비스 고객의 Navigation SDK 요금은 어떻게 청구되나요?
모빌리티 서비스 고객의 경우 내비게이션 SDK의 결제 및 가격은 Google Maps Platform과의 서비스 계약에 따라 다릅니다. 이동성 서비스 구현에 대해 올바르게 청구되는지 확인하는 방법에 관한 자세한 내용은 결제 유효성 검사를 참고하세요. 이동성 서비스 결제에 대한 자세한 내용은 영업 담당자에게 문의하세요.

이동성 서비스 고객만 사용해야 하는 내비게이션 SDK API는 무엇인가요?

Navigation SDK에는 Google에서 거래별로 요금을 청구하는 Mobility Services 고객만 사용할 수 있는 여러 API가 있습니다. Mobility Services 고객이 아닌 경우 다음 메서드는 작동하지 않습니다.

이동성 서비스 고객인 경우 이동성 서비스가 아닌 구현의 내비게이션 SDK를 사용할 수도 있나요?

예. 이동성 서비스 고객은 이동성 서비스와 이동성 서비스가 아닌 내비게이션 SDK 구현을 모두 사용할 수 있습니다. 그러나 앱에서는 한 번에 하나의 구현 유형만 사용할 수 있습니다. 또한 이동성 서비스 구현에 사용하는 것과 별도로 새 Google Cloud 프로젝트, 결제 계정, API 키를 만들어야 합니다. 자세한 내용은 Navigation SDK 설정 개요를 참고하세요.

앱을 한 구현 유형에서 다른 구현 유형으로 이전하는 등 Navigation SDK의 이동성 서비스가 아닌 구현 사용에 관한 자세한 내용은 Google 계정 담당자에게 문의하세요.

참고: 현재 Mobility Services 고객이 아니지만 Mobility Services API 및 SDK 모음에 대해 자세히 알아보려면 Google Maps Platform 영업팀에 문의하세요.