Konfigurowanie słuchaczy
Po zainicjowaniu pakietu Driver SDK i utworzeniu instancji GMTDDeliveryDriverAPI
możesz skonfigurować odbiorców zdarzeń, aby monitorować powodzenie lub niepowodzenie aktualizacji pojazdu wysyłanych do Fleet Engine i Twojego backendu. Te odbiorcy mogą wywoływać działania w aplikacji kierowcy, np. informować kierowcę, jeśli komunikacja z backendem się nie powiedzie.
Odbieranie zdarzeń aktualizacji pojazdu
Gdy kierowca włączy aktualizacje lokalizacji w aplikacji dla kierowcy, pakiet Driver SDK będzie wysyłać regularne aktualizacje pojazdu do Fleet Engine i do backendu klienta za pomocą klasy GMTDDeliveryVehicleReporter
. Aby aplikacja reagowała na zdarzenia aktualizacji, skonfiguruj protokół GMTDVehicleReporterListener
.
Za pomocą GMTDVehicleReporterListener
możesz obsługiwać te zdarzenia:
vehicleReporter:didSucceedVehicleUpdate
Informuje aplikację Kierowca, że usługi backendowe otrzymały zaktualizowane informacje o lokalizacji i stanie pojazdu.
vehicleReporter:didFailVehicleUpdate:withError
Informuje słuchacza, że nie udało się zaktualizować pojazdu. Dopóki kierowca ma włączone aktualizacje lokalizacji, klasa
GMTDDeliveryVehicleReporter
będzie nadal wysyłać najnowsze dane do Fleet Engine.
W tym przykładzie pokazujemy, jak skonfigurować usługę GMTDVehicleReporterListener
do obsługi tych zdarzeń:
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
Włączanie aktualizacji lokalizacji
Aby włączyć aktualizacje lokalizacji, w aplikacji dla kierowcy w GMTDDeliveryVehicleReporter
ustaw locationTrackingEnabled
na YES
. Następnie klasa GMTDDeliveryVehicleReporter
automatycznie wysyła aktualizacje lokalizacji do Fleet Engine. Dodatkowo, gdy GMSNavigator
jest w trybie nawigacji, czyli gdy miejsce docelowe jest ustawiane za pomocą setDestinations
, klasa GMTDDeliveryVehicleReporter
automatycznie wysyła aktualizacje trasy i przewidywanego czasu przybycia.
Pakiet Driver SDK ustawia trasę tak, aby odpowiadała bieżącej ścieżce nawigacji kierowcy. Aby zapewnić dokładne aktualizacje lokalizacji, ustaw punkt kontrolny w -setDestinations:callback:
, aby pasował do miejsca docelowego w Fleet Engine.
Ten przykład pokazuje, jak włączyć aktualizacje lokalizacji:
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
(Opcjonalnie) Ustaw interwał aktualizacji
Domyślnie, gdy ustawisz locationTrackingEnabled
na YES
, pakiet Driver SDK będzie wysyłać aktualizacje lokalizacji do Fleet Engine co 10 sekund. Możesz zmienić interwał aktualizacji za pomocą parametru locationUpdateInterval
do minimalnego interwału aktualizacji wynoszącego 5 sekund lub maksymalnie 60 sekund. Częstsze aktualizacje mogą powodować wolniejsze żądania i błędy.