Подготовьте автомобиль

В этом разделе показано, как подготовить автомобиль к поездкам. Вам необходимо выполнить каждый из следующих шагов, прежде чем ваш сервер сможет сопоставить автомобиль с поездкой.

Настройка прослушивателей

После инициализации Driver SDK и создания экземпляра GMTDRidesharingDriverAPI вы можете настроить прослушиватели событий для отслеживания успешности или сбоя обновлений данных об автомобиле, отправляемых в Fleet Engine и ваш бэкенд. Эти прослушиватели могут активировать действия в вашем приложении для водителей, например, уведомлять водителя о сбоях связи с вашим бэкендом.

Следите за событиями обновления транспортного средства

Когда водитель включает обновления местоположения в приложении, Driver SDK регулярно отправляет обновления данных о транспортном средстве в Fleet Engine и клиентскую систему через класс GMTDVehicleReporter . Вы можете настроить приложение на реагирование на события обновления, настроив протокол GMTDVehicleReporterListener .

С помощью GMTDVehicleReporterListener вы можете обрабатывать следующие события:

  • vehicleReporter:didSucceedVehicleUpdate

    Информирует приложение водителя о том, что внутренние службы успешно получили обновление местоположения и состояния транспортного средства.

  • vehicleReporter:didFailVehicleUpdate:withError

    Сообщает слушателю о сбое обновления данных о транспортном средстве. Пока у водителя включены обновления местоположения, класс GMTDVehicleReporter продолжает отправлять актуальные данные в Fleet Engine.

В следующих примерах показано, как настроить GMTDVehicleReporterListener для обработки этих событий:

Быстрый

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.
    ridesharingDriverAPI.vehicleReporter.add(self)
  }

  func vehicleReporter(_ vehicleReporter: GMTDVehicleReporter, didSucceed vehicleUpdate: GMTDVehicleUpdate) {
    // Handle update succeeded.
  }

  func vehicleReporter(_ vehicleReporter: GMTDVehicleReporter, 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 have implemented the sample code up to this step.
  [ridesharingDriverAPI.vehicleReporter addListener:self];
}

- (void)vehicleReporter:(GMTDVehicleReporter *)vehicleReporter didSucceedVehicleUpdate:(GMTDVehicleUpdate *)vehicleUpdate {
  // Handle update succeeded.
}

- (void)vehicleReporter:(GMTDVehicleReporter *)vehicleReporter didFailVehicleUpdate:(GMTDVehicleUpdate *)vehicleUpdate withError:(NSError *)error {
  // Handle update failed.
}

@end

Следите за обновлениями местоположения транспортного средства

Navigation SDK предоставляет обновления местоположения Driver SDK через класс GMSRoadSnappedLocationProvider . Для получения этих обновлений необходимо настроить GMTDVehicleReporter в качестве прослушивателя.

Быстрый

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.
    if let roadSnappedLocationProvider = mapView.roadSnappedLocationProvider {
      roadSnappedLocationProvider.add(ridesharingDriverAPI.vehicleReporter)
      roadSnappedLocationProvider.startUpdatingLocation()
    }
  }
}

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 have implemented the sample code up to this step.
  [_mapView.roadSnappedLocationProvider addListener:ridesharingDriverAPI.vehicleReporter];
  [_mapView.roadSnappedLocationProvider startUpdatingLocation];
}

@end

Включить обновления местоположения

Чтобы включить обновления местоположения, установите true locationTrackingEnabled для GMTDVehicleReporter в приложении водителя. После этого класс GMTDVehicleReporter автоматически отправляет обновления местоположения в Fleet Engine. После того, как Fleet Engine и внутренние службы клиента сопоставляют данные и назначают автомобиль для поездки, класс GMTDVehicleReporter автоматически отправляет обновления маршрута, когда GMSNavigator находится в режиме навигации, то есть когда пункт назначения задан с помощью setDestinations .

Driver SDK прокладывает маршрут в соответствии с текущим маршрутом водителя. Для обеспечения точного обновления местоположения установите путевую точку в setDestinations так, чтобы она соответствовала пункту назначения в Fleet Engine.

В следующем примере показано, как включить обновление местоположения:

Быстрый

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.
    ridesharingDriverAPI.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.
  ridesharingDriverAPI.vehicleReporter.locationTrackingEnabled = YES;
}

@end

Установите интервал обновления

По умолчанию при установке locationTrackingEnabled в true , Driver SDK отправляет обновления данных о поездках и транспортных средствах в Fleet Engine с интервалом 10 секунд. С помощью locationUpdateInterval можно изменить интервал обновления, установив минимальный интервал обновления в 5 секунд или максимальный в 60 секунд. Более частые обновления могут привести к замедлению запросов и возникновению ошибок.

Установите состояние автомобиля на «онлайн»

После включения обновлений местоположения установите состояние транспортного средства на ONLINE , чтобы сделать транспортное средство доступным для поисковых запросов в Fleet Engine.

В следующих примерах показано, как установить состояние транспортного средства в ONLINE . Подробнее см. updateVehicleState .

Быстрый

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.
    ridesharingDriverAPI.vehicleReporter.update(.online)
  }
}

Objective-C

#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.
  [ridesharingDriverAPI.vehicleReporter
                                   updateVehicleState:GMTDVehicleStateOnline];
}

@end

Что дальше?

Установите детали поездки