En esta sección, se documenta cómo establecer el destino del vehículo después de que el servidor hace coincidir un viaje con un vehículo.
Antes de comenzar
Para completar esta sección, debes haber completado lo siguiente:
Cómo establecer el destino en la app del conductor
Después de vincular un consumidor con un conductor, debes configurar el destino del viaje en la app del conductor. Para ello, sigue estos pasos:
Recupera el destino del vehículo de su colección de puntos de referencia en Fleet Engine, que muestran
GetTrip()
,UpdateTrip()
yGetVehicle()
.Para establecer el destino, llama al método
setDestinations()
del SDK de Navigation para iOS.
En los siguientes ejemplos, se muestra cómo establecer el destino en la app del conductor.
Swift
private func startNavigation() {
let destinations = [
GMSNavigationWaypoint(
placeID: "ChIJnUYTpNASkFQR_gSty5kyoUk", title: "PCC Natural Market"),
GMSNavigationWaypoint(
placeID: "ChIJJ326ROcSkFQRBfUzOL2DSbo", title: "Marina Park"),
]
mapView.navigator?.setDestinations(destinations, callback: { routeStatus in
guard routeStatus == .OK else {
// Error starting navigation.
return
}
mapView.locationSimulator?.simulateLocationsAlongExistingRoute()
mapView.navigator?.isGuidanceActive = true
mapView.navigator?.sendsBackgroundNotifications = true
mapView.cameraMode = .following
})
}
Objective-C
- (void)startNavigation {
NSArray<GMSNavigationWaypoint *> *destinations =
@[[[GMSNavigationWaypoint alloc] initWithPlaceID:@"ChIJnUYTpNASkFQR_gSty5kyoUk"
title:@"PCC Natural Market"],
[[GMSNavigationWaypoint alloc] initWithPlaceID:@"ChIJJ326ROcSkFQRBfUzOL2DSbo"
title:@"Marina Park"]];
[_mapView.navigator setDestinations:destinations
callback:^(GMSRouteStatus routeStatus) {
if (routeStatus != GMSRouteStatusOK) {
// Error starting navigation.
return;
}
[_mapView.locationSimulator simulateLocationsAlongExistingRoute];
_mapView.navigator.guidanceActive = YES;
_mapView.navigator.sendsBackgroundNotifications = YES;
_mapView.cameraMode = GMSNavigationCameraModeFollowing;
}];
}