כדי להשתמש ב-Driver SDK לגרסה 4.0 של Android, צריך לעדכן את הקוד של פעולות מסוימות. במדריך הזה מפורטים השינויים ומה צריך לעשות כדי להעביר את הקוד.
שינוי שם החבילה
שם החבילה השתנה מ-com.google.android.libraries.ridesharing.driver
ל-com.google.android.libraries.mapsplatform.transportation.driver
. עליך לעדכן את ההפניות בקוד.
אתחול ה-SDK
בגרסאות קודמות, צריך להפעיל את Navigation SDK ואז לקבל הפניה לכיתה FleetEngine
. ב-Driver SDK v4, מפעילים את ה-SDK באופן הבא:
אחזור אובייקט
Navigator
מה-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; } } );
יוצרים אובייקט
DriverContext
וממלאים את השדות הנדרשים.DriverContext driverContext = DriverContext.builder(application) .setProviderId(providerId) .setVehicleId(vehicleId) .setAuthTokenFactory(authTokenFactory) .setNavigator(navigator) .setRoadSnappedLocationProvider( NavigationApi.getRoadSnappedLocationProvider(application)) .build();
משתמשים באובייקט
DriverContext
כדי לאתחל את*DriverApi
.מקבלים את
NavigationVehicleReporter
מאובייקט ה-API.*VehicleReporter
מרחיב אתNavigationVehicleReporter
.
הפעלה והשבתה של עדכוני מיקום
בגרסאות קודמות, צריך להפעיל את עדכוני המיקום אחרי שמקבלים הפניה מסוג FleetEngine
. כדי להפעיל את עדכוני המיקום ב-Driver SDK v4:
כשהמשמרת של הנהג מסתיימת, צריך להשבית את עדכוני המיקום ולסמן את הרכב כאופליין באמצעות הקריאה NavigationVehicleReporter.disableLocationTracking()
.
דיווח על שגיאות באמצעות StatusListener
ErrorListener
הוסר וצורף ל-StatusListener
, שאפשר להגדיר אותו כך:
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.
}
}