Listener einrichten
Nachdem Sie das Driver SDK initialisiert und eine GMTDDeliveryDriverAPI
-Instanz erstellt haben, können Sie Event-Listener einrichten, um den Erfolg oder Misserfolg von Fahrzeugaktualisierungen zu überwachen, die an Fleet Engine und Ihr Backend gesendet werden. Diese Listener können Aktionen in Ihrer Fahrer-App auslösen, z. B. den Fahrer benachrichtigen, wenn die Kommunikation mit Ihrem Backend fehlschlägt.
Auf Fahrzeugaktualisierungsereignisse warten
Wenn der Fahrer Standortaktualisierungen in der Fahrer-App aktiviert, sendet das Driver SDK über die Klasse GMTDDeliveryVehicleReporter
regelmäßige Fahrzeugaktualisierungen an Fleet Engine und das Kunden-Backend. Sie können die App so einrichten, dass sie auf Aktualisierungsereignisse reagiert, indem Sie das GMTDVehicleReporterListener
-Protokoll einrichten.
Mit GMTDVehicleReporterListener
können Sie die folgenden Ereignisse verarbeiten:
vehicleReporter:didSucceedVehicleUpdate
Informiert die Fahrer-App darüber, dass die Backend-Dienste die Aktualisierung des Fahrzeugstandorts und -status erfolgreich empfangen haben.
vehicleReporter:didFailVehicleUpdate:withError
Informiert den Listener darüber, dass ein Fahrzeugupdate fehlgeschlagen ist. Solange der Fahrer Standortaktualisierungen aktiviert hat, sendet die
GMTDDeliveryVehicleReporter
-Klasse weiterhin die neuesten Daten an Fleet Engine.
Das folgende Beispiel zeigt, wie Sie GMTDVehicleReporterListener
einrichten, um diese Ereignisse zu verarbeiten:
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.
deliveryDriverAPI.vehicleReporter.add(self)
}
func vehicleReporter(_ vehicleReporter: GMTDDeliveryVehicleReporter, didSucceed vehicleUpdate: GMTDVehicleUpdate) {
// Handle update succeeded.
}
func vehicleReporter(_ vehicleReporter: GMTDDeliveryVehicleReporter, 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 IMPLEMENTED HAVE THE SAMPLE CODE UP TO THIS STEP.
[delivervehicleReporter addListener:self];
}
- (void)vehicleReporter:(GMTDDeliveryVehicleReporter *)vehicleReporter didSucceedVehicleUpdate:(GMTDVehicleUpdate *)vehicleUpdate {
// Handle update succeeded.
}
- (void)vehicleReporter:(GMTDDeliveryVehicleReporter *)vehicleReporter didFailVehicleUpdate:(GMTDVehicleUpdate *)vehicleUpdate withError:(NSError *)error {
// Handle update failed.
}
@end
Standortaktualisierungen aktivieren
Wenn Sie Standortaktualisierungen aktivieren möchten, legen Sie in der Fahrer-App auf GMTDDeliveryVehicleReporter
die Option locationTrackingEnabled
auf YES
fest. Die Klasse GMTDDeliveryVehicleReporter
sendet dann automatisch Standortaktualisierungen an Fleet Engine. Wenn sich das GMSNavigator
im Navigationsmodus befindet, d. h. wenn ein Ziel über setDestinations
festgelegt wird, sendet die GMTDDeliveryVehicleReporter
-Klasse automatisch Routen- und ETA-Updates.
Mit dem Driver SDK wird die Route so festgelegt, dass sie dem aktuellen Navigationspfad des Fahrers entspricht. Damit Standortaktualisierungen genau sind, muss der Wegpunkt in -setDestinations:callback:
mit dem Ziel in Fleet Engine übereinstimmen.
Das folgende Beispiel zeigt, wie Sie Standortaktualisierungen aktivieren:
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.
deliveryDriverAPI.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.
deliveryDriverAPI.vehicleReporter.locationTrackingEnabled = YES;
}
@end
Optional: Aktualisierungsintervall festlegen
Wenn Sie locationTrackingEnabled
auf YES
festlegen, sendet das Driver SDK standardmäßig alle 10 Sekunden Standortaktualisierungen an Fleet Engine. Mit locationUpdateInterval
können Sie das Aktualisierungsintervall auf ein Minimum von 5 Sekunden oder ein Maximum von 60 Sekunden ändern. Häufigere Aktualisierungen können zu langsameren Anfragen und Fehlern führen.