כדי להשתמש בגרסה 4.0 של Driver SDK ל-Android, צריך לעדכן את הקוד עבור פעולות מסוימות. במדריך הזה מפורטים השינויים ומה צריך לעשות כדי להעביר את הקוד.
שינוי שם החבילה
שם החבילה השתנה מ-com.google.android.libraries.ridesharing.driver ל-com.google.android.libraries.mapsplatform.transportation.driver. צריך לעדכן את ההפניות בקוד.
אתחול ה-SDK
בגרסאות קודמות, הייתם מאתחלים את Navigation SDK ואז מקבלים הפניה למחלקה FleetEngine. ב-Driver SDK
גרסה 4, מאתחלים את ה-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. *VehicleReporterextendsNavigationVehicleReporter.
הפעלה והשבתה של עדכוני מיקום
בגרסאות קודמות, הייתם מפעילים עדכוני מיקום אחרי קבלת הפניה 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.
}
}