ナビゲーション イベントをリッスンする

このガイドでは、ユーザーがルートに沿って移動する際に変化するさまざまなイベントをリッスンして応答できるようにアプリを有効にする方法について説明します。このガイドでは、ルートの定義については説明しません。ルートに沿ったイベントへの応答についてのみ説明します。

概要

Navigation SDK for iOS には、ユーザーの位置情報、ルート沿いの条件、重要な時間と距離のデータに関連付けられたリスナーが用意されています。マップのビュー コントローラで、アプリはこれらのリスナーのプロトコル(GMSRoadSnappedLocationProviderListenerGMSNavigatorListener)を採用する必要があります。

このリストは、ナビゲーション イベントで使用できるリスナー メソッドを示しています。

コードの確認

必要なプロトコルへの準拠を宣言する

ナビゲーション メソッドを実装する前に、ビュー コントローラは次のプロトコルを採用する必要があります。

Swift

class ViewController:
  UIViewController,
  GMSNavigatorListener,
  GMSRoadSnappedLocationProviderListener
{
}

Objective-C

@interface ViewController () <GMSNavigatorListener, GMSRoadSnappedLocationProviderListener>
@end

ナビゲーション プロトコルを採用したら、リスナーをビュー コントローラに設定します。たとえば、次のコードを viewDidLoad() メソッドに追加できます。

Swift

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

Objective-C

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

位置情報の更新を受け取るか停止する

地図上にユーザーの進行状況を表示するには、位置情報の更新が必要です。

location インスタンスは次のプロパティを公開します。

Location プロパティ 説明
標高 現在の標高。
coordinate.latitude 現在の道路にスナップされた緯度座標。
coordinate.longitude 現在の道路にスナップされた経度座標。
コース 現在の方位(度単位)。
速度 現在の速度。
timestamp 現在の読み取りの日時。

位置情報の更新を継続的に受け取るには、mapView.roadSnappedLocationProvider.startUpdatingLocation を呼び出し、GMSRoadSnappedLocationProviderListener を使用して didUpdateLocation イベントを処理します。

次の例では、startUpdatingLocation を呼び出しています。

Swift

mapView.roadSnappedLocationProvider.startUpdatingLocation()

Objective-C

[_mapView.roadSnappedLocationProvider startUpdatingLocation];

次のコードは、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 イベントを使用して、目的地に到着したことを検出します。continueToNextDestinationWithCompletion() を呼び出してガイダンスを再開し、次の経由地に移動してから、ガイダンスを再度有効にできます。アプリは、continueToNextDestinationWithCompletion() を呼び出した後で、ガイダンスを再度有効にする必要があります。

アプリが continueToNextDestinationWithCompletion を呼び出すと、ナビゲーターは以前の目的地に関するデータを持たなくなります。ルート区間に関する情報を分析する場合は、continueToNextDestinationWithCompletion() を呼び出す前にナビゲーターから取得する必要があります。

次のコード例は、didArriveAtWaypoint イベントを処理する方法を示しています。

Swift

func navigator(_ navigator: GMSNavigator, didArriveAt waypoint: GMSNavigationWaypoint) {
  print("You have arrived at: \(waypoint.title)")
  mapView.navigator?.continueToNextDestinationWithCompletion { _, _ in }
  mapView.navigator?.isGuidanceActive = true
}

Objective-C

- (void)navigator:(GMSNavigator *)navigator didArriveAtWaypoint:(GMSNavigationWaypoint *)waypoint {
  NSLog(@"You have arrived at: %@", waypoint.title);
  [_mapView.navigator continueToNextDestinationWithCompletion:^(GMSNavigationWaypoint *waypoint,
                                                                GMSRouteStatus status){
  }];
  _mapView.navigator.guidanceActive = YES;
}

ルート変更の更新情報を受け取る

ルートが変更されるたびに通知を受け取るには、navigatorDidChangeRoute イベントを処理するメソッドを作成します。GMSNavigatorrouteLegs プロパティと currentRouteLeg プロパティを使用して、新しいルートにアクセスできます。

Swift

func navigatorDidChangeRoute(_ navigator: GMSNavigator) {
  print("The route has changed.")
}

Objective-C

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

目的地までの時間の更新情報を受け取る

目的地までの時間の更新を継続的に受け取るには、didUpdateRemainingTime イベントを処理するメソッドを作成します。time パラメータは、次の目的地に到着するまでの推定時間を秒単位で提供します。

Swift

func navigator(_ navigator: GMSNavigator, didUpdateRemainingTime time: TimeInterval) {
  print("Time to next destination: \(time)")
}

Objective-C

- (void)navigator:(GMSNavigator *)navigator didUpdateRemainingTime:(NSTimeInterval)time {
  NSLog(@"Time to next destination: %f", time);
}

次の目的地までの推定時間の最小変更を設定するには、GMSNavigatortimeUpdateThreshold プロパティを設定します。値は秒単位で指定します。このプロパティが設定されていない場合、サービスはデフォルト値の 1 秒を使用します。

Swift

navigator?.timeUpdateThreshold = 10

Objective-C

navigator.timeUpdateThreshold = 10;

目的地までの距離の更新情報を受け取る

目的地までの距離の更新を継続的に受け取るには、didUpdateRemainingDistance イベントを処理するメソッドを作成します。distance パラメータは、次の目的地までの推定距離をメートル単位で提供します。

Swift

func navigator(_ navigator: GMSNavigator, didUpdateRemainingDistance distance: CLLocationDistance)
{
  let miles = distance * 0.00062137
  print("Distance to next destination: \(miles) miles.")
}

Objective-C

- (void)navigator:(GMSNavigator *)navigator
    didUpdateRemainingDistance:(CLLocationDistance)distance {
  double miles = distance * 0.00062137;
  NSLog(@"%@", [NSString stringWithFormat:@"Distance to next destination: %.2f.", miles]);
}

次の目的地までの推定距離の最小変更を設定するには、GMSNavigatordistanceUpdateThreshold プロパティを設定します(値はメートル単位で指定します)。このプロパティが設定されていない場合、サービスはデフォルト値の 1 メートルを使用します。

Swift

navigator?.distanceUpdateThreshold = 100

Objective-C

navigator.distanceUpdateThreshold = 100;

交通状況の更新情報を受け取る

残りのルートの交通状況の更新を継続的に受け取るには、didUpdateDelayCategory イベントを処理するメソッドを作成します。delayCategoryToNextDestination を呼び出すと、0 ~ 3 の値を提供する GMSNavigationDelayCategory が返されます。カテゴリの更新は、アプリ ユーザーの現在地に基づいています。交通データが利用できない場合、GMSNavigationDelayCategory は 0 を返します。数値 1 ~ 3 は、交通量が少ないから多いに増加することを示します。

Swift

func navigator(_ navigator: GMSNavigator,
               didUpdate delayCategory: GMSNavigationDelayCategory)
{
  print("Traffic flow to next destination: \(delayCategory)")
}

Objective-C

- (void)navigator:(GMSNavigator *)navigator
    didUpdateDelayCategory:(GMSNavigationDelayCategory)delayCategory {
  NSLog(@"Traffic flow to next destination: %ld", (long)delayCategory);
}

GMSNavigationDelayCategory プロパティは、次の遅延レベルを公開します。

遅延カテゴリ 説明
GMSNavigationDelayCategoryNoData 0 - 利用不可。交通状況または のデータがありません。
ルート。
GMSNavigationDelayCategoryHeavy 1 - 多い。
GMSNavigationDelayCategoryMedium 2 - 普通。
GMSNavigationDelayCategoryLight 3 - ライト。

速度超過の更新情報を受け取る

ドライバーが制限速度を超えているときに更新情報を受け取るには、didUpdateSpeedingPercentage イベントを処理するメソッドを作成します。

Swift

// Listener to handle speeding events.
func navigator(_ navigator: GMSNavigator,
               didUpdateSpeedingPercentage percentageAboveLimit: CGFloat)
{
  print("Speed is \(percentageAboveLimit) above the limit.")
}

Objective-C

// Listener to handle speeding events.
- (void)navigator:(GMSNavigator *)navigator
    didUpdateSpeedingPercentage:(CGFloat)percentageAboveLimit {
  NSLog(@"Speed is %f percent above the limit.", percentageAboveLimit);
}

推奨される照明モードを変更する

照明の推定変更の更新情報を受け取るには、didChangeSuggestedLightingMode イベントを処理するメソッドを作成します。

Swift

// Define a listener for suggested changes to lighting mode.
func navigator(_ navigator: GMSNavigator,
               didChangeSuggestedLightingMode lightingMode: GMSNavigationLightingMode)
{
  print("Suggested lighting mode has changed: \(String(describing: lightingMode))")

  // Make the suggested change.
  mapView.lightingMode = lightingMode
 }

Objective-C

// Define a listener for suggested changes to lighting mode.
- (void)navigator:(GMSNavigator *)navigator
    didChangeSuggestedLightingMode:(GMSNavigationLightingMode)lightingMode {
  NSLog(@"Suggested lighting mode has changed: %ld", (long)lightingMode);

  // Make the suggested change.
  _mapView.lightingMode = lightingMode;
}