כדי להשתמש בגרסה 4.0 של Driver SDK ל-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
extendsNavigationVehicleReporter
.
הפעלה והשבתה של עדכוני מיקום
בגרסאות קודמות, הייתם מפעילים עדכוני מיקום אחרי קבלת הפניה 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.
}
}