लिसनर सेट अप करना
Driver SDK को शुरू करने और GMTDDeliveryDriverAPI इंस्टेंस बनाने के बाद, इवेंट लिसनर सेट अप किए जा सकते हैं. इनकी मदद से, Fleet Engine और अपने बैकएंड को भेजे गए वाहन के अपडेट की सफलता या गड़बड़ी की निगरानी की जा सकती है. ये लिसनर, ड्राइवर ऐप्लिकेशन में कार्रवाइयां ट्रिगर कर सकते हैं. जैसे, अगर आपके बैकएंड से संपर्क नहीं हो पाता है, तो ड्राइवर को सूचना देना.
वाहन के अपडेट से जुड़े इवेंट की जानकारी पाने की सुविधा चालू करना
जब ड्राइवर, ड्राइवर ऐप्लिकेशन में जगह की जानकारी के अपडेट की सुविधा चालू करता है, तो Driver SDK, GMTDDeliveryVehicleReporter क्लास के ज़रिए Fleet Engine और ग्राहक के बैकएंड को वाहन के अपडेट नियमित तौर पर भेजता है. GMTDVehicleReporterListener प्रोटोकॉल सेट अप करके, ऐप्लिकेशन को अपडेट इवेंट के हिसाब से काम करने के लिए सेट किया जा सकता है.
GMTDVehicleReporterListener की मदद से, इन इवेंट को मैनेज किया जा सकता है:
vehicleReporter:didSucceedVehicleUpdateयह ड्राइवर ऐप्लिकेशन को बताता है कि बैकएंड सेवाओं को वाहन की जगह और स्थिति का अपडेट मिल गया है.
vehicleReporter:didFailVehicleUpdate:withErrorयह लिसनर को बताता है कि वाहन का अपडेट नहीं हो पाया. जब तक ड्राइवर ने जगह की जानकारी के अपडेट की सुविधा चालू रखी है, तब तक
GMTDDeliveryVehicleReporterक्लास, Fleet Engine को नया डेटा भेजती रहती है.
यहां दिए गए उदाहरण में, इन इवेंट को मैनेज करने के लिए GMTDVehicleReporterListener को सेट अप करने का तरीका बताया गया है:
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
जगह की जानकारी के अपडेट की सुविधा चालू करना
जगह की जानकारी के अपडेट की सुविधा चालू करने के लिए, ड्राइवर ऐप्लिकेशन में GMTDDeliveryVehicleReporter पर, locationTrackingEnabled को YES पर सेट करें. इसके बाद, GMTDDeliveryVehicleReporter क्लास, Fleet Engine को जगह की जानकारी के अपडेट अपने-आप भेजती है. इसके अलावा, जब GMSNavigator नेविगेशन मोड में होता है, तब setDestinations के ज़रिए डेस्टिनेशन सेट किया जाता है. इस दौरान, GMTDDeliveryVehicleReporter क्लास, रास्ते और ईटीए के अपडेट अपने-आप भेजती है.
Driver SDK, ड्राइवर के मौजूदा नेविगेशन पाथ से मैच करने के लिए, रास्ता सेट करता है. जगह की सटीक जानकारी के अपडेट पक्का करने के लिए, -setDestinations:callback: में वेपॉइंट को Fleet Engine में डेस्टिनेशन से मैच करने के लिए सेट करें.
यहां दिए गए उदाहरण में, जगह की जानकारी के अपडेट की सुविधा चालू करने का तरीका बताया गया है:
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
(ज़रूरी नहीं) अपडेट इंटरवल सेट करना
डिफ़ॉल्ट तौर पर, जब locationTrackingEnabled को YES पर सेट किया जाता है, तो Driver SDK, Fleet Engine को हर 10 सेकंड में जगह की जानकारी के अपडेट भेजता है. locationUpdateInterval की मदद से, अपडेट इंटरवल को बदला जा सकता है. इसे कम से कम 5 सेकंड या ज़्यादा से ज़्यादा 60 सेकंड पर सेट किया जा सकता है. बार-बार अपडेट करने से, अनुरोधों की प्रोसेस धीमी हो सकती है और गड़बड़ियां आ सकती हैं.