Questa sezione mostra come preparare il veicolo per i viaggi. Devi completare ciascuno dei seguenti passaggi prima che il backend possa abbinare un veicolo a un viaggio.
Configurare gli ascoltatori
Dopo aver inizializzato Driver SDK e creato un'istanza di GMTDRidesharingDriverAPI
, puoi configurare i listener di eventi per monitorare l'esito positivo o negativo degli aggiornamenti del veicolo inviati a Fleet Engine e al tuo backend. Questi listener possono
attivare azioni all'interno dell'app per i conducenti, ad esempio inviare una notifica al conducente se
la comunicazione con il backend non va a buon fine.
Ascolta gli eventi di aggiornamento del veicolo
Quando l'autista attiva gli aggiornamenti della posizione nell'app per i conducenti, Driver SDK
invia aggiornamenti regolari del veicolo a Fleet Engine e al backend del cliente
tramite la classe GMTDVehicleReporter
. Puoi fare in modo che l'app risponda
agli eventi di aggiornamento configurando il protocollo GMTDVehicleReporterListener
.
Con GMTDVehicleReporterListener
, puoi gestire i seguenti eventi:
vehicleReporter:didSucceedVehicleUpdate
Comunica all'app Driver che i servizi di backend hanno ricevuto correttamente l'aggiornamento della posizione e dello stato del veicolo.
vehicleReporter:didFailVehicleUpdate:withError
Informa l'ascoltatore che l'aggiornamento del veicolo non è riuscito. Se gli aggiornamenti della posizione sono attivi, la classe
GMTDVehicleReporter
continua a inviare i dati più recenti a Fleet Engine.
Gli esempi riportati di seguito mostrano come configurare GMTDVehicleReporterListener
per
gestire questi eventi:
Swift
import GoogleRidesharingDriver
private let providerID = "INSERT_YOUR_PROVIDER_ID"
class SampleViewController: UIViewController, GMTDVehicleReporterListener {
private let mapView: GMSMapView
override func viewDidLoad() {
// Assumes you have implemented the sample code up to this step.
ridesharingDriverAPI.vehicleReporter.add(self)
}
func vehicleReporter(_ vehicleReporter: GMTDVehicleReporter, didSucceed vehicleUpdate: GMTDVehicleUpdate) {
// Handle update succeeded.
}
func vehicleReporter(_ vehicleReporter: GMTDVehicleReporter, didFail vehicleUpdate: GMTDVehicleUpdate, withError error: Error) {
// Handle update failed.
}
}
Objective-C
/**
* SampleViewController.h
*/
@interface SampleViewController : UIViewController<GMTDVehicleReporterListener>
@end
/**
* SampleViewController.m
*/
#import "SampleViewController.h"
#import "SampleAccessTokenProvider.h"
#import <GoogleRidesharingDriver/GoogleRidesharingDriver.h>
static NSString *const PROVIDER_ID = @"INSERT_YOUR_PROVIDER_ID";
@implementation SampleViewController {
GMSMapView *_mapView;
}
- (void)viewDidLoad {
// Assumes you have implemented the sample code up to this step.
[ridesharingDriverAPI.vehicleReporter addListener:self];
}
- (void)vehicleReporter:(GMTDVehicleReporter *)vehicleReporter didSucceedVehicleUpdate:(GMTDVehicleUpdate *)vehicleUpdate {
// Handle update succeeded.
}
- (void)vehicleReporter:(GMTDVehicleReporter *)vehicleReporter didFailVehicleUpdate:(GMTDVehicleUpdate *)vehicleUpdate withError:(NSError *)error {
// Handle update failed.
}
@end
Ascoltare gli aggiornamenti sulla posizione del veicolo
L'SDK Navigation fornisce aggiornamenti della posizione all'SDK Driver tramite la classe
GMSRoadSnappedLocationProvider
. Per ricevere questi aggiornamenti, devi configurare
GMTDVehicleReporter
come listener.
Swift
import GoogleRidesharingDriver
private let providerID = "INSERT_YOUR_PROVIDER_ID"
class SampleViewController: UIViewController, GMTDVehicleReporterListener {
private let mapView: GMSMapView
override func viewDidLoad() {
// Assumes you have implemented the sample code up to this step.
if let roadSnappedLocationProvider = mapView.roadSnappedLocationProvider {
roadSnappedLocationProvider.add(ridesharingDriverAPI.vehicleReporter)
roadSnappedLocationProvider.startUpdatingLocation()
}
}
}
Objective-C
/**
* SampleViewController.h
*/
@interface SampleViewController : UIViewController<GMTDVehicleReporterListener>
@end
/**
* SampleViewController.m
*/
#import "SampleViewController.h"
#import "SampleAccessTokenProvider.h"
#import <GoogleRidesharingDriver/GoogleRidesharingDriver.h>
static NSString *const PROVIDER_ID = @"INSERT_YOUR_PROVIDER_ID";
@implementation SampleViewController {
GMSMapView *_mapView;
}
- (void)viewDidLoad {
// Assumes you have implemented the sample code up to this step.
[_mapView.roadSnappedLocationProvider addListener:ridesharingDriverAPI.vehicleReporter];
[_mapView.roadSnappedLocationProvider startUpdatingLocation];
}
@end
Attivare gli aggiornamenti della posizione
Per attivare gli aggiornamenti della posizione, imposta locationTrackingEnabled
su true
in
GMTDVehicleReporter
nell'app per i conducenti. Dopodiché, la classe GMTDVehicleReporter
invia automaticamente gli aggiornamenti della posizione a Fleet Engine. Dopo che i servizi di backend di Fleet Engine e del cliente corrispondono e assegnano il veicolo a un viaggio, la classe GMTDVehicleReporter
invia automaticamente gli aggiornamenti del percorso quando GMSNavigator
è in modalità di navigazione, ovvero quando viene impostata una destinazione tramite setDestinations
.
L'SDK Driver imposta l'itinerario in modo che corrisponda al percorso di navigazione attuale del conducente. Per
garantire aggiornamenti precisi della posizione, imposta il waypoint in setDestinations
in modo che corrisponda
alla destinazione in Fleet Engine.
Il seguente esempio mostra come attivare gli aggiornamenti della posizione:
Swift
import GoogleRidesharingDriver
private let providerID = "INSERT_YOUR_PROVIDER_ID"
class SampleViewController: UIViewController, GMTDVehicleReporterListener {
private let mapView: GMSMapView
override func viewDidLoad() {
// Assumes you have implemented the sample code up to this step.
ridesharingDriverAPI.vehicleReporter.locationTrackingEnabled = true
}
}
Objective-C
/**
* SampleViewController.m
*/
#import "SampleViewController.h"
#import "SampleAccessTokenProvider.h"
#import <GoogleRidesharingDriver/GoogleRidesharingDriver.h>
static NSString *const PROVIDER_ID = @"INSERT_YOUR_PROVIDER_ID";
@implementation SampleViewController {
GMSMapView *_mapView;
}
- (void)viewDidLoad {
// Assumes you have implemented the sample code up to this step.
ridesharingDriverAPI.vehicleReporter.locationTrackingEnabled = YES;
}
@end
Impostare l'intervallo di aggiornamento
Per impostazione predefinita, quando imposti locationTrackingEnabled
su true
, l'SDK Driver
invia aggiornamenti di viaggi e veicoli a Fleet Engine a intervalli di 10 secondi. Puoi
modificare l'intervallo di aggiornamento con locationUpdateInterval
fino a un minimo di 5 secondi o un massimo di 60 secondi. Aggiornamenti più frequenti potrebbero
comportare richieste più lente ed errori.
Imposta lo stato del veicolo su online
Dopo aver attivato gli aggiornamenti della posizione, imposta lo stato del veicolo su ONLINE
per rendere il
veicolo disponibile per le query di ricerca in Fleet Engine.
Gli esempi seguenti mostrano come impostare lo stato del veicolo su ONLINE
. Per
maggiori dettagli, vedi updateVehicleState
.
Swift
import GoogleRidesharingDriver
private let providerID = "INSERT_YOUR_PROVIDER_ID"
class SampleViewController: UIViewController, GMTDVehicleReporterListener {
private let mapView: GMSMapView
override func viewDidLoad() {
// Assumes you have implemented the sample code up to this step.
ridesharingDriverAPI.vehicleReporter.update(.online)
}
}
Objective-C
#import "SampleViewController.h"
#import "SampleAccessTokenProvider.h"
#import <GoogleRidesharingDriver/GoogleRidesharingDriver.h>
static NSString *const PROVIDER_ID = @"INSERT_YOUR_PROVIDER_ID";
@implementation SampleViewController {
GMSMapView *_mapView;
}
- (void)viewDidLoad {
// Assumes you have implemented the sample code up to this step.
[ridesharingDriverAPI.vehicleReporter
updateVehicleState:GMTDVehicleStateOnline];
}
@end
Passaggi successivi
Impostare i dettagli del viaggio