탐색 이벤트 리슨

이 가이드를 사용하여 사용자가 경로를 따라 이동할 때 변경되는 다양한 이벤트를 앱에서 리슨하고 응답할 수 있습니다. 이 가이드에서는 경로 정의는 다루지 않고 경로상의 이벤트에 응답하는 방법만 다룹니다.

개요

iOS용 Navigation SDK는 경로 및 중요한 시간 및 거리 데이터를 따라 사용자의 위치 및 조건과 연결된 리스너를 제공합니다. 지도의 뷰 컨트롤러에서 앱은 GMSRoadSnappedLocationProviderListenerGMSNavigatorListener 리스너의 프로토콜을 채택해야 합니다.

다음 목록은 탐색 이벤트에 사용할 수 있는 리스너 메서드를 보여줍니다.

코드 보기

필수 프로토콜에 대한 적합성 선언

탐색 메서드를 구현하기 전에 뷰 컨트롤러는 다음과 같이 프로토콜을 채택해야 합니다.

Swift

class ViewController: UIViewController, GMSNavigatorListener, GMSRoadSnappedLocationProviderListener {

Objective-C

@interface ViewController () <gmsnavigatorlistener, gmsroadsnappedlocationproviderlistener=""></gmsnavigatorlistener,

@end

탐색 프로토콜을 채택한 후 리스너를 뷰 컨트롤러로 설정합니다. 예를 들어 다음 코드를 viewDidLoad() 메서드에 추가할 수 있습니다.

Swift

mapView.navigator?.add(self) mapView.roadSnappedLocationProvider?.add(self)

Objective-C

[_mapView.navigator addListener:self]; [_mapView.roadSnappedLocationProvider addListener:self];

위치 업데이트 수신 또는 중지

사용자의 진행 상황을 지도에 표시하려면 위치 업데이트가 필요합니다.

location 인스턴스는 다음 속성을 노출합니다.

위치 속성 설명
고도 현재 고도입니다.
coordinate.latitude 현재 도로에 맞춰진 위도 좌표입니다.
coordinate.longitude 현재 도로에 맞춰진 경도 좌표입니다.
과정 현재 방위(도)입니다.
속도 현재 속도입니다.
타임스탬프 현재 측정 날짜/시간입니다.

계속해서 위치 업데이트를 수신하려면 mapView.roadSnappedLocationProvider.startUpdatingLocation를 호출하고 GMSRoadSnappedLocationProviderListener를 사용하여 didUpdateLocation 이벤트를 처리합니다.

다음은 startUpdatingLocation를 호출하는 예를 보여줍니다.

Swift

mapView.roadSnappedLocationProvider.startUpdatingLocation()

Objective-C

[_mapView.roadSnappedLocationProvider startupdatesLocation];

다음 코드는 didUpdateLocation 이벤트를 처리하는 GMSRoadSnappedLocationProviderListener를 만듭니다.

Swift

Func locationProvider(_ locationProvider: GMSRoadSnappedLocationProvider, didUpdate location: CLLocation) { print("Location: (location.description)") }

Objective-C

  • (void)locationProvider:(GMSRoadSnappedLocationProvider *)locationProvider didUpdateLocation:(CLLocation *)location { NSLog(@"Location: %@", location.description); }

앱이 백그라운드에 있을 때 위치 업데이트를 수신하려면 allowsBackgroundLocationUpdates를 true로 설정하세요.

Swift

mapView.roadSnappedLocationProvider.allowsBackgroundLocationUpdates = true

Objective-C

_mapView.roadSnappedLocationProvider.allowsBackgroundLocationUpdates = YES;

도착 이벤트 감지

앱은 didArriveAtWaypoint 이벤트를 사용하여 대상에 도달했는지 감지합니다. continueToNextDestination()를 호출한 후 안내를 다시 사용 설정하여 안내를 재개하고 다음 경유지로 진행할 수 있습니다. 앱은 continueToNextDestination()를 호출한 후에 안내를 다시 사용 설정해야 합니다.

앱이 continueToNextDestination를 호출하면 탐색기에는 더 이상 이전 대상에 관한 데이터가 없습니다. 경로 구간에 대한 정보를 분석하려면 continueToNextDestination()를 호출하기 전에 탐색기에서 이를 검색해야 합니다.

다음 코드 예에서는 didArriveAtWaypoint 이벤트를 처리하는 메서드를 보여줍니다.

Swift

functionc navigator(_ navigator: GMSNavigator, doArriveAt Waypoint: GMSNavigationWaypoint) { print("도착함: (wait.title)") mapView.navigator?.continueToNextDestination() mapView.navigator?.isGuidanceActive = true }

Objective-C

  • {0}

경로 변경 업데이트 수신

경로가 변경될 때마다 알림을 받으려면 navigatorDidChangeRoute 이벤트를 처리하는 메서드를 만듭니다. GMSNavigatorrouteLegscurrentRouteLeg 속성을 사용하여 새 경로에 액세스할 수 있습니다.

Swift

functionc navigatorDidChangeRoute(_ navigator: GMSNavigator) { print("경로가 변경되었습니다.") }

Objective-C

  • (void)navigatorDidChangeRoute:(GMSNavigator *)navigator { NSLog(@"The route has changed."); }

목적지까지의 시간 업데이트 수신

대상에 이르는 시간 업데이트를 지속적으로 수신하려면 didUpdateRemainingTime 이벤트를 처리하는 메서드를 만듭니다. time 매개변수는 다음 목적지에 도달할 때까지의 예상 시간을 초 단위로 제공합니다.

Swift

functionc navigator(_ navigator: GMSNavigator, doUpdateRemainingTime time: TimeInterval) { print("다음 목적지까지 남은 시간: (time)") }

Objective-C

  • (void)navigator:(GMSNavigator *)navigator didUpdateRemainingTime:(NSTimeInterval)time { NSLog(@"다음 목적지까지의 시간: %f", time); }

다음 목적지까지의 예상 시간의 최소 변경을 설정하려면 GMSNavigator에서 timeUpdateThreshold 속성을 설정합니다. 값은 초 단위로 지정됩니다. 이 속성을 설정하지 않으면 서비스에서 기본값 1초를 사용합니다.

Swift

navgator?.timeUpdateThreshold = 10

Objective-C

navgator.timeUpdateThreshold = 10;

목적지까지의 거리 업데이트 수신

목적지까지의 연속 거리 업데이트를 수신하려면 didUpdateRemainingDistance 이벤트를 처리하는 메서드를 만듭니다. distance 매개변수는 다음 목적지까지의 예상 거리를 미터 단위로 제공합니다.

Swift

함수 navigator(_ navigator: GMSNavigator, doUpdateRemainingDistancedistance: CLLocationDistance) { let miles = distance * 0.00062137 print("Distance to 다음 목적지: (miles)miles.") }

Objective-C

  • (void)navigator:(GMSNavigator *)navigator didUpdateRemainingDistance:(CLLocationDistance)distance { double마일 = distance * 0.00062137; NSLog(@"%@", [NSString stringWithFormat:@"Distance 다음 목적지까지의 거리: %.2f.", mile]); }

다음 목적지까지의 예상 거리의 최소 변경을 설정하려면 GMSNavigator에서 distanceUpdateThreshold 속성을 설정합니다 (값이 미터 단위로 지정됨). 이 속성을 설정하지 않으면 서비스는 기본값 1미터를 사용합니다.

Swift

navgator?.distanceUpdateThreshold = 100

Objective-C

navgator.distanceUpdateThreshold = 100;

교통정보 업데이트 받기

나머지 경로의 트래픽 흐름에 관한 지속적인 업데이트를 수신하려면 didUpdateDelayCategory 이벤트를 처리하는 메서드를 만듭니다. delayCategoryToNextDestination를 호출하면 0~3의 값을 제공하는 GMSNavigationDelayCategory가 반환됩니다. 카테고리 업데이트는 앱 사용자의 현재 위치를 기반으로 합니다. 트래픽 데이터를 사용할 수 없는 경우 GMSNavigationDelayCategory는 0을 반환합니다. 숫자 1~3은 흐름이 약함에서 심함으로 증가하는 것을 나타냅니다.

Swift

functionc navigator(_ navigator: GMSNavigator, doUpdate모든 지연 카테고리: GMSNavigationDelayCategory) { print("Traffic flow to next destination: (delayCategory)") }

Objective-C

  • (void)navigator:(GMSNavigator *)navigator didUpdateDelayCategory:(GMSNavigationDelayCategory)delayCategory { NSLog(@"다음 목적지로 가는 교통량 흐름: %ld", (long)delayCategory); }

GMSNavigationDelayCategory 속성은 다음과 같은 지연 수준을 나타냅니다.

지연 카테고리 설명
GMSNavigationDelayCategoryNoData 0 - 사용할 수 없음, 교통정보 데이터 없음 또는 :
있습니다.
GMSNavigationDelayCategoryHeavy 1 - 무거움.
GMSNavigationDelayCategoryMedium 2 - 중간
GMSNavigationDelayCategoryLight 3 - 밝음.

속도 업데이트 수신 중

운전자가 속도 제한을 초과할 때 업데이트를 수신하려면 didUpdateSpeedingPercentage 이벤트를 처리하는 메서드를 만듭니다.

Swift

// 속도 이벤트를 처리하기 위한 리스너입니다. functionc navigator( _ navigator: GMSNavigator, doUpdateSpeedingPercentage percentageAboveLimit: CGFloat ) { print("Speed is (percentageAboveLimit) above the limit.") }

Objective-C

// 속도 이벤트를 처리하는 리스너입니다. - (void)navigator:(GMSNavigator *)navigator doUpdateSpeedingPercentage:(CGFloat)percentageAboveLimit { NSLog(@"속도가 한도보다 %f퍼센트입니다.", percentageAboveLimit); }

추천 조명 모드 변경

추정된 조명 변경에 관한 업데이트를 수신하려면 didChangeSuggestedLightingMode 이벤트를 처리하는 메서드를 만듭니다.

Swift

// 추천된 조명 모드 변경사항에 대한 리스너를 정의합니다. goodc navigator(_ navigator: GMSNavigator, doChangeSuggestedLightingMode lightsMode: GMSNavigationLightingMode) { print("Suggested Lighting mode has changed: (String(describing: LightMode))")

// 제안된 변경사항을 적용합니다. mapView.lightingMode = lightsMode }

Objective-C

// 조명 모드에 제안된 변경 사항에 관한 리스너를 정의합니다. -(void)navigator:(GMSNavigator *)navigator doesChangeSuggestedLightingMode: (GMSNavigationLightingMode)lightingMode { NSLog(@"Suggested Lighting mode has changed: %ld", (long)lightingMode);

// 제안된 변경사항을 적용합니다. _mapView.lightingMode = lightsMode; }