地点の管理

このドキュメントでは、次の 2 つの機能を使用して、アプリの経由地の設定を管理する方法について説明します。

  • 道路の側道のルーティング設定
  • 経由地

道路の側道のルーティング設定を行う

デフォルトでは、Navigation SDK for iOS は経由地への最短ルートを検索しますが、ユーザーが道路の希望する側道に到着するとは限りません。たとえば、相乗りサービスの運転手の顧客が待っている側道などです。道路の側道のルーティング設定 機能を使用すると、車両が道路の正しい側道に到着するようにできます。

仕組み

特定の側道に到着する設定は、その停車地の経由地を作成するときに設定します。設定は次の 2 つの方法で指定できます。

道路の同じ側道を優先する

経由地の地理座標を指定し、最も近い歩道にスナップされた経由地と同じ側道に到着することを優先することを示すフラグ preferSameSideOfRoad を設定します。

(nullable instancetype)initWithLocation:(CLLocationCoordinate2D)location
                                  title:(NSString *)title
                   preferSameSideOfRoad:(BOOL)preferSameSideOfRoad;

到着方向を設定する

経由地の地理座標を指定し、 到着方向 preferredSegmentHeading 目的地と同じ側道の交通の流れの方向と一致する を指定します。

(nullable instancetype)initWithLocation:(CLLocationCoordinate2D)location
                                  title:(NSString *)title
                preferredSegmentHeading:(int32_t)preferredSegmentHeading;

Navigation SDK は、経由地に最も近い道路セグメントを選択します。この道路セグメントは、経由地がある側道と(+/- 55 度以内で)一致する車線方向を持っています。

経由地の設定を行う

場所によっては、ユーザーが安全に停車できない場合があります(高架、フェリー、地下、その他のアクセスが制限されている場所など)。経由地 機能は、ユーザーが停車するのに適していない場所に経由地がある場合、経由地を近くの場所に移動します。代替の場所がある場合、vehicleStopoverYES に設定すると、ルートの計算時に経由地が自動的に移動します。

仕組み

停車地の経由地を作成するときに、経由地の設定を行います。 これを行うには、次の例に示すように、GMSNavigationMutableWaypoint で経由地の設定を行います。

Swift

let location = CLLocationCoordinate2D(latitude: 47.67, longitude: -122.20)
let waypoint = GMSNavigationMutableWaypoint(location: location, title: "waypoint from location")!
waypoint.vehicleStopover = true
mapView.navigator?.setDestinations([waypoint], routingOptions: routingOptions, callback: {...})

Objective-C

CLLocationCoordinate2D location = CLLocationCoordinate2DMake(47.67, -122.20);
GMSNavigationMutableWaypoint *waypoint =
    [[GMSNavigationMutableWaypoint alloc] initWithLocation:location
                                                     title:@"waypoint from location"];
waypoint.vehicleStopover = YES;
[_mapView.navigator setDestinations:@[waypoint1]
                     routingOptions:routingOptions
                           callback:^(GMSRouteStatus routeStatus){...}];