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

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

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

वाहन के अपडेट से जुड़े इवेंट सुनें

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

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

  • vehicleReporter:didSucceedVehicleUpdate

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

  • vehicleReporter:didFailVehicleUpdate:withError

    लिसनर को सूचना दी जाती है कि गाड़ी को अपडेट नहीं किया जा सका. जब तक ड्राइवर के पास जगह की जानकारी के अपडेट चालू किए गए, GMTDDeliveryVehicleReporter क्लास जारी है का इस्तेमाल करें.

यहां दिए गए उदाहरण में, 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 क्लास, जगह की जानकारी के अपडेट अपने-आप इन्हें भेजती है फ़्लीट इंजन. इसके अलावा, जब GMSNavigator नेविगेशन मोड में हो, तो तब होता है जब गंतव्य setDestinations के ज़रिए सेट किया जाता है, GMTDDeliveryVehicleReporter क्लास रास्ते और ETA के अपडेट अपने-आप भेजती है.

ड्राइवर SDK टूल, ड्राइवर के मौजूदा नेविगेशन पाथ से मैच करने के लिए रूट सेट करता है. यहां की यात्रा पर हूं यह पक्का करने के लिए कि जगह की सटीक जानकारी अपडेट हो, वेपॉइंट Fleet Engine में डेस्टिनेशन से मिलान करने के लिए -setDestinations:callback:.

यहां दिए गए उदाहरण में, जगह की जानकारी के अपडेट चालू करने का तरीका बताया गया है:

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 पर सेट किया जाता है, तो ड्राइवर SDK फ़्लीट इंजन को 10 सेकंड के इंटरवल पर जगह की जानकारी के अपडेट भेजता है. इसे बदला जा सकता है locationUpdateInterval के साथ अपडेट का अंतराल 5 सेकंड या ज़्यादा से ज़्यादा 60 सेकंड तक का हो सकता है. ज़्यादा बार अपडेट करने की वजह से धीमे अनुरोध और गड़बड़ियां.