Nachdem Sie das JavaScript Consumer SDK für geplante Aufgaben eingerichtet haben, können Sie mit Ihrer Verbraucher-App den Versand verfolgen. In diesem Dokument werden die folgenden wichtigen Schritte dieses Prozesses beschrieben:
- Karte initialisieren und geteilte Fahrt anzeigen
- Aktualisieren und den Fortschritt des Kaufprozesses verfolgen
- Sendung nicht mehr verfolgen
- Fehler bei der Sendungsverfolgung beheben
Karte einrichten
Wenn Sie den Transport einer Sendung in Ihrer Webanwendung verfolgen möchten, müssen Sie eine Karte laden und das Consumer SDK instanziieren, um die Sendung zu verfolgen. Sie können entweder eine neue Karte laden oder eine vorhandene verwenden. Anschließend verwenden Sie die Initialisierungsfunktion, um das Consumer SDK zu instanziieren, damit die Kartenansicht dem Standort des zu verfolgenden Artikels entspricht.
Neue Karte mit der Google Maps JavaScript API laden
Wenn Sie eine neue Karte erstellen möchten, laden Sie die Google Maps JavaScript API in Ihre Webanwendung. Im folgenden Beispiel wird gezeigt, wie Sie die Google Maps JavaScript API laden, das SDK aktivieren und die Initialisierungsprüfung auslösen.
- Der Parameter
callback
führt die FunktioninitMap
aus, nachdem die API geladen wurde. - Mit dem Attribut
defer
kann der Browser den Rest Ihrer Seite weiter rendern, während die API geladen wird.
Verwenden Sie die Funktion initMap
, um das Consumer SDK zu instanziieren. Beispiel:
<script src="https://maps.googleapis.com/maps/api/js?key=YOUR_API_KEY&callback=initMap&libraries=journeySharing" defer></script>
Vorhandene Karte laden
Sie können auch eine vorhandene Karte laden, die mit der Google Maps JavaScript API erstellt wurde, z. B. eine, die Sie bereits verwenden.
Angenommen, Sie haben eine Webseite mit einem standardmäßigen google.maps.Map
-Element, auf dem eine Markierung angezeigt wird, wie im folgenden HTML-Code definiert. Hier sehen Sie Ihre Karte mit derselben initMap
-Funktion im Callback am Ende:
<!DOCTYPE html>
<html>
<head>
<style>
/* Set the size of the div element that contains the map */
#map {
height: 400px; /* The height is 400 pixels */
width: 100%; /* The width is the width of the web page */
}
</style>
</head>
<body>
<h3>My Google Maps Demo</h3>
<!--The div element for the map -->
<div id="map"></div>
<script>
// Initialize and add the map
function initMap() {
// The location of Pier 39 in San Francisco
var pier39 = {lat: 37.809326, lng: -122.409981};
// The map, initially centered at Mountain View, CA.
var map = new google.maps.Map(document.getElementById('map'));
map.setOptions({center: {lat: 37.424069, lng: -122.0916944}, zoom: 14});
// The marker, now positioned at Pier 39
var marker = new google.maps.Marker({position: pier39, map: map});
}
</script>
<!-- Load the API from the specified URL.
* The defer attribute allows the browser to render the page while the API loads.
* The key parameter contains your own API key.
* The callback parameter executes the initMap() function.
-->
<script defer src="https://maps.googleapis.com/maps/api/js?key=YOUR_API_KEY&callback=initMap">
</script>
</body>
</html>
Anbieter für den Standort der Sendung erstellen
Verwenden Sie den Anbieter des Versandorts zusammen mit dem zuvor definierten Abrufprogramm für Autorisierungstokens, um Daten von Fleet Engine zu erhalten.
Diese Beispiele zeigen, wie der Standortanbieter instanziiert wird.
JavaScript
const locationProvider =
new google.maps.journeySharing.FleetEngineShipmentLocationProvider({
projectId: 'your-project-id',
authTokenFetcher: authTokenFetcher, // the fetcher defined previously
});
TypeScript
const locationProvider =
new google.maps.journeySharing.FleetEngineShipmentLocationProvider({
projectId: 'your-project-id',
authTokenFetcher: authTokenFetcher, // the fetcher defined previously
});
Geteilte Route anzeigen
Wenn Sie den Fortschritt einer geplanten Aufgabe anzeigen möchten, müssen Sie die Ansicht initialisieren. Dadurch wird der Frame für die Karte so festgelegt, dass er dem Standort der erfassten Fahrt entspricht. Der Fortschritt wird dann vom Consumer SDK bereitgestellt, nachdem es die Informationen von der Fleet Engine erhalten hat.
Tipps:
Ihre Seite muss das Element <div> enthalten, das die Kartenansicht enthält. Im folgenden Beispiel heißt das Element <div>
map_canvas
.Beachten Sie die Standardsichtbarkeitsregeln, die die Fleet Engine auf aufgezeichnete Fahrten anwendet. Sie können auch Sichtbarkeitsregeln für aktive Fahrzeuglieferungen und geplante Haltestellenaufgaben konfigurieren. Weitere Informationen finden Sie im Leitfaden Aufgaben konfigurieren unter Sichtbarkeit von Aufgaben anpassen.
Diese Beispiele zeigen, wie eine Kartenansicht initialisiert wird.
JavaScript
function initMap() {
const mapView = new
google.maps.journeySharing.JourneySharingMapView({
element: document.getElementById('map_canvas'),
// Any undefined styling options use defaults.
});
// If you did not specify a tracking ID in the location
// provider constructor, you may do so here.
// Location tracking starts as soon as this is set.
locationProvider.trackingId = 'your-tracking-id';
// Give the map an initial viewport to allow it to
// initialize; otherwise the 'ready' event above may
// not fire. The user also has access to the mapView
// object to customize as they wish.
mapView.map.setCenter({lat: 37.2, lng: -121.9});
mapView.map.setZoom(14);
}
TypeScript
function initMap() {
const mapView = new
google.maps.journeySharing.JourneySharingMapView({
element: document.getElementById('map_canvas'),
// Any undefined styling options will use defaults.
});
// If you did not specify a tracking ID in the location
// provider constructor, you may do so here.
// Location tracking starts as soon as this is set.
locationProvider.trackingId = 'your-tracking-id';
// Give the map an initial viewport to allow it to
// initialize; otherwise the 'ready' event above may
// not fire. The user also has access to the mapView
// object to customize as they wish.
mapView.map.setCenter({lat: 37.2, lng: -121.9});
mapView.map.setZoom(14);
}
Versandfortschritt aktualisieren
Sie können auf Ereignisse warten und den Versandfortschritt während des Bestellvorgangs aktualisieren. Verwenden Sie den Standortanbieter, um Metainformationen aus dem taskTrackingInfo
-Objekt abzurufen. Änderungen an den Metainformationen lösen ein Update-Ereignis aus. Das taskTrackingInfo
-Objekt bietet Folgendes:
- ETA
- Anzahl der verbleibenden Haltestellen
- Verbleibende Entfernung bis zur Abholung oder Lieferung
Das folgende Beispiel zeigt, wie Sie auf diese Änderungsereignisse reagieren.
JavaScript
locationProvider.addListener('update', e => {
// e.taskTrackingInfo contains data that may be useful
// to the rest of the UI.
console.log(e.taskTrackingInfo.remainingStopCount);
});
TypeScript
locationProvider.addListener('update',
(e: google.maps.journeySharing.FleetEngineShipmentLocationProviderUpdateEvent) => {
// e.taskTrackingInfo contains data that may be useful
// to the rest of the UI.
console.log(e.taskTrackingInfo.remainingStopCount);
});
Kriterien für mehrere Aufgaben anzeigen
Das Consumer SDK für geplante Aufgaben zeigt auf der Karte nur eine Aufgabe pro Tracking-ID an. In der Regel weisen Sie jedoch auch einer bestimmten Sendung eine Tracking-ID zu, die ihr während des gesamten Transports in Ihrem System zugeordnet bleibt. Das bedeutet, dass einer einzelnen Tracking-ID mehrere Aufgaben zugeordnet werden können, z. B. eine Abholaufgabe, gefolgt von einer Zustellaufgabe für dasselbe Paket, oder mehrere fehlgeschlagene Versandaufgaben für ein Paket.
In diesem Fall werden in der Fleet Engine die in der folgenden Tabelle aufgeführten Kriterien für die Anzeige von Aufgaben angewendet.
Aufgabenkriterien | Ergebnis |
---|---|
Aufgaben zum Abholen öffnen | |
Es gibt genau eine. | Aufgabe anzeigen |
Es gibt mehrere | Fehler generieren |
Abgeschlossene Abholaufgaben | |
Es gibt genau eine. | Aufgabe anzeigen |
Es gibt mehrere (einige mit Ergebniszeiten) | Aufgabe mit dem letzten Ergebniszeitpunkt anzeigen |
Es gibt mehrere (keine mit Ergebniszeiten) | Fehler generieren |
Lieferungsaufgaben öffnen | |
Es gibt genau eine. | Aufgabe anzeigen |
Es gibt mehrere | Fehler generieren |
Abgeschlossene Übermittlungsaufgaben | |
Es gibt genau eine. | Aufgabe anzeigen |
Es gibt mehrere (einige mit Ergebniszeiten) | Aufgabe mit dem letzten Ergebniszeitpunkt anzeigen |
Es gibt mehrere (keine mit Ergebniszeiten) | Fehler generieren |
Sendung nicht mehr verfolgen
Wenn ein Versandvorgang abgeschlossen oder storniert wurde, sollte Ihre Verbraucher-App die Sendung nicht mehr verfolgen. Entfernen Sie dazu die Tracking-ID und den Standortanbieter aus der Kartenansicht. Details zu diesen Schritten finden Sie in den folgenden Abschnitten.
Tracking-ID entfernen
Wenn Sie nicht mehr möchten, dass der Standortanbieter die Sendung verfolgt, entfernen Sie die Tracking-ID vom Standortanbieter. Die folgenden Beispiele zeigen, wie das geht.
JavaScript
locationProvider.trackingId = '';
TypeScript
locationProvider.trackingId = '';
Standortanbieter aus der Kartenansicht entfernen
Im folgenden Beispiel wird gezeigt, wie ein Standortanbieter aus der Kartenansicht entfernt wird.
JavaScript
mapView.removeLocationProvider(locationProvider);
TypeScript
mapView.removeLocationProvider(locationProvider);
Fehler bei der Sendungsverfolgung beheben
Fehler, die asynchron beim Anfordern von Versandinformationen auftreten, lösen Fehlerereignisse aus. Im folgenden Beispiel wird gezeigt, wie Sie auf diese Ereignisse warten, um Fehler zu verarbeiten.
JavaScript
locationProvider.addListener('error', e => {
// e.error is the error that triggered the event.
console.error(e.error);
});
TypeScript
locationProvider.addListener('error', (e: google.maps.ErrorEvent) => {
// e.error is the error that triggered the event.
console.error(e.error);
});
Hinweis:Um unerwartete Fehler zu behandeln, müssen Bibliotheksaufrufe in try...catch
-Blöcke eingeschlossen werden.