이 가이드에 따라 iOS용 Navigation SDK를 사용하여 앱 내에서 단일 목적지까지의 경로를 표시합니다.
개요
- 프로젝트 설정 섹션에 설명된 대로 Navigation SDK를 앱에 통합합니다.
-
GMSMapView를 구성합니다. - 사용자에게 이용약관에 동의하고 위치 서비스 및 백그라운드 알림을 승인하라는 메시지를 표시합니다.
- 하나 이상의 목적지가 포함된 배열을 만듭니다.
GMSNavigator를 정의하여 세부 경로 안내 내비게이션을 제어합니다.setDestinations를 사용하여 목적지를 추가합니다.- 내비게이션을 시작하려면
isGuidanceActive를true로 설정합니다. simulateLocationsAlongExistingRoute를 사용하여 테스트, 디버깅, 앱 시연을 위해 경로를 따라 차량의 진행 상황을 시뮬레이션합니다.
코드 보기
사용자에게 필요한 승인 요청
Navigation SDK를 사용하기 전에 사용자는 이용약관에 동의하고 내비게이션에 필요한 위치 서비스 사용을 승인해야 합니다. 앱이 백그라운드에서 실행되는 경우 사용자에게 안내 알림을 승인하라는 메시지도 표시해야 합니다. 이 섹션에서는 필요한 승인 메시지를 표시하는 방법을 보여줍니다.
위치 서비스 승인
Navigation SDK는 사용자 승인이 필요한 위치 서비스를 사용합니다. 위치 서비스를 사용 설정하고 승인 대화상자를 표시하려면 다음 단계를 따르세요.
Xcode에서 위치 및 백그라운드 기능을 사용 설정합니다.
- Xcode에서 대상을 열고 서명 및 기능 탭을 선택합니다. 자세한 내용은 앱에 기능 추가에 관한 Apple 가이드를 참고하세요.
- 위치 (항상) 및 위치 (사용 중) 기능을 추가합니다. 각 텍스트 필드에 앱에 위치 서비스가 필요한 이유에 관한 간단한 설명을 추가합니다 (예: '이 앱에는 턴바이턴 내비게이션을 위해 위치 서비스를 사용할 수 있는 권한이 필요합니다.').
- 백그라운드 모드 기능을 추가한 후 위치 업데이트 체크박스를 선택합니다. 이 기능이 없으면 내비게이션을 시작할 때 앱이 비정상 종료됩니다. 자세한 내용은 백그라운드에서 위치 업데이트 처리에 관한 Apple 가이드를 참고하세요.
승인 대화상자를 표시하려면 위치 관리자 인스턴스의
requestAlwaysAuthorization()메서드를 호출합니다.
Swift
self.locationManager.requestAlwaysAuthorization()
Objective-C
[_locationManager requestAlwaysAuthorization];
위치 서비스 승인에 관한 전체 Apple 문서를 참고하세요.
백그라운드 안내에 관한 알림 승인
Navigation SDK는 앱이 백그라운드에서 실행 중일 때 알림을 제공하기 위해 사용자 권한이 필요합니다. 사용자에게 이러한 알림을 표시할 수 있는 권한을 요청하는 메시지를 표시하려면 다음 코드를 추가하세요.
Swift
UNUserNotificationCenter.current().requestAuthorization(options: [.alert]) {
granted, error in
// Handle denied authorization to display notifications.
if !granted || error != nil {
print("User rejected request to display notifications.")
}
}
Objective-C
// Request authorization for alert notifications.
UNUserNotificationCenter *center = [UNUserNotificationCenter currentNotificationCenter];
UNAuthorizationOptions options = UNAuthorizationOptionAlert;
[center requestAuthorizationWithOptions:options
completionHandler:
^(
BOOL granted,
NSError *_Nullable error) {
if (!error && granted) {
NSLog(@"iOS Notification Permission: newly Granted");
} else {
NSLog(@"iOS Notification Permission: Failed or Denied");
}
}];
이용약관에 동의하세요.
다음 코드를 사용하여 이용약관 대화상자를 표시하고 사용자가 약관에 동의하면 내비게이션을 사용 설정합니다. 이 예에는 위치 서비스 및 안내 알림 (이전에 표시됨)에 관한 코드가 포함되어 있습니다.
Swift
let termsAndConditionsOptions = GMSNavigationTermsAndConditionsOptions(companyName: "Ride Sharing Co.")
GMSNavigationServices.showTermsAndConditionsDialogIfNeeded(
with: termsAndConditionsOptions) { termsAccepted in
if termsAccepted {
// Enable navigation if the user accepts the terms.
self.mapView.isNavigationEnabled = true
self.mapView.settings.compassButton = true
// Request authorization to use location services.
self.locationManager.requestAlwaysAuthorization()
// Request authorization for alert notifications which deliver guidance instructions
// in the background.
UNUserNotificationCenter.current().requestAuthorization(options: [.alert]) {
granted, error in
// Handle rejection of notification authorization.
if !granted || error != nil {
print("Authorization to deliver notifications was rejected.")
}
}
} else {
// Handle rejection of terms and conditions.
}
}
Objective-C
GMSNavigationTermsAndConditionsOptions *termsAndConditionsOptions = [[GMSNavigationTermsAndConditionsOptions alloc] initWithCompanyName:@"Ride Sharing Co."];
[GMSNavigationServices
showTermsAndConditionsDialogIfNeededWithOptions:termsAndConditionsOptions
callback:^(BOOL termsAccepted) {
if (termsAccepted) {
// Enable navigation if the user accepts the terms.
_mapView.navigationEnabled = YES;
_mapView.settings.compassButton = YES;
// Request authorization to use the current device location.
[_locationManager requestAlwaysAuthorization];
// Request authorization for alert notifications which deliver guidance instructions
// in the background.
UNUserNotificationCenter *center = [UNUserNotificationCenter currentNotificationCenter];
UNAuthorizationOptions options = UNAuthorizationOptionAlert;
[center requestAuthorizationWithOptions:options
completionHandler:
^(
BOOL granted,
NSError *_Nullable error) {
if (!error && granted) {
NSLog(@"iOS Notification Permission: newly Granted");
} else {
NSLog(@"iOS Notification Permission: Failed or Denied");
}
}];
} else {
// Handle rejection of the terms and conditions.
}
}];
경로 만들기 및 안내 시작
경로를 표시하려면 방문할 하나 이상의 목적지 배열을 사용하여 내비게이터의 setDestinations 메서드를 호출합니다.GMSNavigationWaypoint 경로가 성공적으로 계산되면 지도에 표시됩니다. 경로를 따라 안내를 시작하려면 콜백에서 isGuidanceActive를 true로 설정합니다.
다음 예시는 다음과 같은 기능을 보여줍니다.
- 목적지가 하나인 새 경로 만들기
- 안내 시작
- 백그라운드 안내 알림 사용 설정
- 경로를 따라 이동 시뮬레이션 (선택사항)
- 카메라 모드를 '따라가기'로 설정(선택사항)
Swift
func startNav() {
var destinations = [GMSNavigationWaypoint]()
destinations.append(GMSNavigationWaypoint.init(placeID: "ChIJnUYTpNASkFQR_gSty5kyoUk",
title: "PCC Natural Market")!)
mapView.navigator?.setDestinations(destinations) { routeStatus in
self.mapView.navigator?.isGuidanceActive = true
self.mapView.locationSimulator?.simulateLocationsAlongExistingRoute()
self.mapView.cameraMode = .following
}
}
Objective-C
- (void)startNav {
NSArray<GMSNavigationWaypoint *> *destinations =
@[[[GMSNavigationWaypoint alloc] initWithPlaceID:@"ChIJnUYTpNASkFQR_gSty5kyoUk"
title:@"PCC Natural Market"]];
[_mapView.navigator setDestinations:destinations
callback:^(GMSRouteStatus routeStatus){
[_mapView.locationSimulator simulateLocationsAlongExistingRoute];
_mapView.navigator.guidanceActive = YES;
_mapView.cameraMode = GMSNavigationCameraModeFollowing;
}];
}
장소 ID에 관해 알아보려면 장소 ID를 참고하세요.
다중 경유지 시나리오
최대 25개의 경유지를 구성할 수 있습니다.
setDestinations 메서드는 다중 경유지 여정을 지원하지 않습니다.
continueToNextDestinationWithCompletion()
을 사용하여 경유지를 여정의 다음 구간으로 이동합니다.
이동수단 설정
이동수단은 가져올 경로 유형과 사용자의 경로를 결정하는 방법을 모두 정의합니다. 경로에 관해 운전, 사이클링, 도보, 택시의 네 가지 이동 수단 중 하나를 설정할 수 있습니다. 운전 및 택시 모드에서 사용자의 경로는 이동 방향을 기반으로 합니다. 자전거 및 도보 모드에서 경로는 기기가 향하는 방향 (가로 모드에서 기기 상단 방향)으로 표시됩니다.
다음 예와 같이 지도 뷰의
travelMode
속성을 설정합니다.
Swift
self.mapView.travelMode = .cycling
Objective-C
_mapView.travelMode = GMSNavigationTravelModeCycling;
피할 도로 설정
avoidsHighways 및 avoidsTolls BOOL 속성을 사용하여 경로를 따라 고속도로, 유료 도로 또는 둘 다 피합니다.
Swift
self.mapView.navigator?.avoidsTolls = true
Objective-C
_mapView.navigator.avoidsTolls = YES;
PlaceID 찾기
PlaceID 찾기
를 사용하여 경로 목적지에 사용할 장소 ID를 찾을 수 있습니다. GMSNavigationWaypoint를 사용하여
placeID에서 목적지를 추가합니다.
떠 있는 텍스트
Google 저작자 표시가 가려지지 않는 한 앱의 어느 곳에나 떠 있는 텍스트를 추가할 수 있습니다. Navigation SDK는 지도 또는 라벨의 특정 좌표 (위도, 경도)에 텍스트를 고정하는 것을 지원하지 않습니다. 자세한 내용은 정보 창을 참고하세요.