En este documento, se explica cómo personalizar los marcadores de vehículos y ubicaciones en el mapa que usas para tu app de seguimiento de envíos basada en la Web para consumidores.
Con el SDK de Consumer para JavaScript, puedes personalizar la apariencia de dos tipos de marcadores que se agregan al mapa:
- Marcadores de vehículos de entrega: usa
deliveryVehicleMarkerCustomization - Marcadores de destino: usa
destinationMarkerCustomization
Puedes hacerlo de dos maneras:
- Más simple: Especifica un objeto
MarkerOptionspara aplicar a todos los marcadores del mismo tipo. Luego, el SDK de Consumer aplica el diseño en dos situaciones: antes de agregar los marcadores al mapa y cuando cambian los datos que se usan para los marcadores. - Más avanzado: Especifica una función de personalización. Las funciones de personalización permiten diseñar los marcadores en función de los datos, así como agregar interactividad a los marcadores, como el control de clics. En particular, el SDK de Consumer pasa datos a la función de personalización sobre el tipo de objeto que representa el marcador: vehículo o destino. Esto permite que el diseño del marcador cambie según el estado actual del elemento del marcador; por ejemplo, la cantidad de paradas planificadas restantes hasta el destino. Incluso puedes unir datos de fuentes externas a Fleet Engine y diseñar el marcador en función de esa información.
Ejemplo simple: usa MarkerOptions
En el siguiente ejemplo, se muestra cómo configurar el diseño de un marcador de vehículo con un objeto MarkerOptions. En este ejemplo, se establece la opacidad del marcador en un 50%.
JavaScript
deliveryVehicleMarkerCustomization = {
opacity: 0.5
};
TypeScript
deliveryVehicleMarkerCustomization = {
opacity: 0.5
};
Ejemplo avanzado: usa una función de personalización
En el siguiente ejemplo, se muestra cómo configurar el diseño de un marcador de vehículo para mostrar la cantidad de paradas restantes del vehículo antes de llegar a la parada de la tarea programada.
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}`);
};
Agrega el control de clics a los marcadores
Puedes agregar el control de clics a cualquier marcador, como en el siguiente ejemplo para un marcador de vehículo.
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.
});
}
};
Muestra información adicional para los marcadores
Puedes usar un InfoWindow para mostrar información adicional sobre un
marcador de vehículo o ubicación. En el siguiente ejemplo, se crea un InfoWindow y se adjunta a un marcador de vehículo:
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();