Z tego dokumentu dowiesz się, jak dostosować na mapie znaczniki pojazdów i lokalizacji w internetowej aplikacji do śledzenia przesyłek dla klientów.
Dzięki pakietowi JavaScript Consumer SDK możesz dostosowywać wygląd i styl 2 typów znaczników dodawanych do mapy:
- Znaki dostawczego pojazdu: użyj
deliveryVehicleMarkerCustomization
. - Oznaczenia miejsc docelowych: użyj
destinationMarkerCustomization
.
Możesz to zrobić na 2 sposoby:
- Najprostsze: określ obiekt
MarkerOptions
, który ma być stosowany do wszystkich znaczników tego samego typu. Pakiet Consumer SDK stosuje stylizację w 2 sytuacjach: przed dodaniem znaczników do mapy i gdy zmienią się dane używane do znaczników. - Bardziej zaawansowane: określ funkcję dostosowywania. Funkcje dostosowywania umożliwiają stylizowanie znaczników na podstawie danych, a także dodawanie do nich interakcji, takich jak obsługa kliknięć. W szczególności pakiet SDK dla konsumentów przekazuje funkcji personalizacji dane o typie obiektu reprezentowanego przez znacznik: pojazd lub miejsce docelowe. Dzięki temu styl znacznika może się zmieniać w zależności od bieżącego stanu samego elementu znacznika, np. liczby zaplanowanych przystanków do miejsca docelowego. Możesz nawet złączać dane ze źródeł spoza Fleet Engine i stylizować znacznik na podstawie tych informacji.
Prosty przykład: użycie MarkerOptions
Ten przykład pokazuje, jak skonfigurować styl markera pojazdu za pomocą obiektu MarkerOptions
. W tym przykładzie ustawiamy przezroczystość znacznika na 50%.
JavaScript
deliveryVehicleMarkerCustomization = {
opacity: 0.5
};
TypeScript
deliveryVehicleMarkerCustomization = {
opacity: 0.5
};
Przykład zaawansowany: korzystanie z funkcji dostosowywania
W tym przykładzie pokazujemy, jak skonfigurować styl znacznika pojazdu, aby wyświetlał liczbę pozostałych przystanków pojazdu przed dotarciem do przystanku w ramach zaplanowanego zadania.
JavaScript
deliveryVehicleMarkerCustomization =
(params) => {
var stopsLeft = params.taskTrackingInfo.remainingStopCount;
params.marker.setLabel(`${stopsLeft}`);
};
TypeScript
deliveryVehicleMarkerCustomization =
(params: ShipmentMarkerCustomizationFunctionParams) => {
const stopsLeft = params.taskTrackingInfo.remainingStopCount;
params.marker.setLabel(`${stopsLeft}`);
};
Dodawanie obsługi kliknięć do znaczników
Obsługę kliknięć możesz dodać do dowolnego znacznika, na przykład w przypadku znacznika pojazdu w tym przykładzie.
JavaScript
deliveryVehicleMarkerCustomization =
(params) => {
if (params.isNew) {
params.marker.addListener('click', () => {
// Perform desired action.
});
}
};
TypeScript
deliveryVehicleMarkerCustomization =
(params: ShipmentMarkerCustomizationFunctionParams) => {
if (params.isNew) {
params.marker.addListener('click', () => {
// Perform desired action.
});
}
};
Wyświetlanie dodatkowych informacji o znacznikach
Możesz użyć InfoWindow
, aby wyświetlić dodatkowe informacje o pojazdach lub znacznikach lokalizacji. W tym przykładzie tworzymy element InfoWindow
i dołączamy go do znacznika pojazdu:
JavaScript
// 1. Create an info window.
const infoWindow = new google.maps.InfoWindow(
{disableAutoPan: true});
locationProvider.addListener('update', e => {
const stopsCount =
e.taskTrackingInfo.remainingStopCount;
infoWindow.setContent(
`Your vehicle is ${stopsCount} stops away.`);
// 2. Attach the info window to a vehicle marker.
// This property can return multiple markers.
const marker = mapView.vehicleMarkers[0];
infoWindow.open(mapView.map, marker);
});
// 3. Close the info window.
infoWindow.close();
TypeScript
// 1. Create an info window.
const infoWindow = new google.maps.InfoWindow(
{disableAutoPan: true});
locationProvider.addListener('update', (e: google.maps.journeySharing.FleetEngineShipmentLocationProviderUpdateEvent) => {
const stopsCount =
e.taskTrackingInfo.remainingStopCount;
infoWindow.setContent(
`Your vehicle is ${stopsCount} stops away.`);
// 2. Attach the info window to a vehicle marker.
// This property can return multiple markers.
const marker = mapView.vehicleMarkers[0];
infoWindow.open(mapView.map, marker);
});
// 3. Close the info window.
infoWindow.close();