गाड़ी तैयार रखें

लिसनर सेट अप करना

Driver SDK को शुरू करने और GMTDDeliveryDriverAPI इंस्टेंस बनाने के बाद, इवेंट लिसनर सेट अप किए जा सकते हैं. इनसे यह मॉनिटर किया जा सकता है कि Fleet Engine और आपके बैकएंड को भेजे गए वाहन के अपडेट पूरे हुए या नहीं. ये लिसनर, ड्राइवर ऐप्लिकेशन में कार्रवाइयां ट्रिगर कर सकते हैं. जैसे, अगर आपके बैकएंड से कम्यूनिकेशन नहीं हो पाता है, तो ड्राइवर को सूचना देना.

वाहन के अपडेट से जुड़े इवेंट को मॉनिटर करने की अनुमति

जब ड्राइवर, ड्राइवर ऐप्लिकेशन में जगह की जानकारी के अपडेट चालू करता है, तब Driver SDK, Fleet Engine और ग्राहक के बैकएंड को वाहन के अपडेट भेजता है. ऐसा GMTDDeliveryVehicleReporter क्लास के ज़रिए किया जाता है. GMTDVehicleReporterListener प्रोटोकॉल सेट अप करके, ऐप्लिकेशन को अपडेट इवेंट के बारे में सूचनाएं पाने की सुविधा दी जा सकती है.

GMTDVehicleReporterListener की मदद से, इन इवेंट को मैनेज किया जा सकता है:

  • vehicleReporter:didSucceedVehicleUpdate

    यह कुकी, Driver ऐप्लिकेशन को सूचना देती है कि बैकएंड सेवाओं को वाहन की जगह की जानकारी और स्थिति का अपडेट मिल गया है.

  • 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 क्लास रास्ते और ETA के अपडेट अपने-आप भेजती है.

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 सेकंड हो सकता है. बार-बार अपडेट करने से, अनुरोधों को प्रोसेस करने में ज़्यादा समय लग सकता है और गड़बड़ियां हो सकती हैं.