Panduan Migrasi Android Driver SDK 3.0

Rilis Driver SDK for Android 3.0 mengharuskan Anda mengupdate kode untuk operasi tertentu. Panduan ini menguraikan perubahan dan tindakan yang perlu Anda lakukan untuk memigrasikan kode.

Perubahan nama paket

Nama paket telah berubah dari com.google.android.libraries.ridesharing.driver menjadi com.google.android.libraries.mapsplatform.transportation.driver. Harap update referensi dalam kode Anda.

Menginisialisasi SDK

Pada versi sebelumnya, Anda akan menginisialisasi Navigation SDK, lalu mendapatkan referensi ke class FleetEngine. Di Driver SDK v3, lakukan inisialisasi SDK sebagai berikut:

  1. Dapatkan objek Navigator dari NavigationApi.

    NavigationApi.getNavigator(
          this, // Activity
          new NavigationApi.NavigatorListener() {
            @Override
            public void onNavigatorReady(Navigator navigator) {
              // Keep a reference to the Navigator (used to configure and start nav)
              this.navigator = navigator;
            }
          }
    );
    
  2. Buat objek DriverContext, isi kolom yang diperlukan.

    DriverContext driverContext = DriverContext.builder(application)
                 .setProviderId(providerId)
                 .setVehicleId(vehicleId)
                 .setAuthTokenFactory(authTokenFactory)
                 .setNavigator(navigator)
                 .setRoadSnappedLocationProvider(
                     NavigationApi.getRoadSnappedLocationProvider(application))
                 .build()
    
  3. Gunakan objek DriverContext untuk melakukan inisialisasi *DriverApi.

  4. Dapatkan NavigationVehicleReporter dari objek API. *VehicleReporter memperluas NavigationVehicleReporter.

Mengaktifkan dan menonaktifkan pembaruan lokasi

Pada versi sebelumnya, Anda akan mengaktifkan pembaruan lokasi setelah mendapatkan referensi FleetEngine. Di Driver SDK v3, aktifkan update lokasi sebagai berikut:

Untuk memperbarui interval pelaporan, gunakan RidesharingVehicleReporter.setLocationReportingInterval(long, TimeUnit) atau DeliveryVehicleReporter.setLocationReportingInterval(long, TimeUnit).

Saat shift pengemudi selesai, nonaktifkan update lokasi dan tandai kendaraan sebagai offline dengan memanggil NavigationVehicleReporter.disableLocationTracking().

Pelaporan Error dengan StatusListener

ErrorListener telah dihapus dan digabungkan dengan StatusListener, yang dapat ditentukan seperti berikut:

class MyStatusListener implements StatusListener {
  /** Called when background status is updated, during actions such as location reporting. */
  @Override
  public void updateStatus(
    StatusLevel statusLevel,
    StatusCode statusCode,
    String statusMsg) {
    // Status handling stuff goes here.
    // StatusLevel may be DEBUG, INFO, WARNING, or ERROR.
    // StatusCode may be DEFAULT, UNKNOWN_ERROR, VEHICLE_NOT_FOUND, 
    // BACKEND_CONNECTIVITY_ERROR, or PERMISSION_DENIED.
  }
}