В этом документе описывается, как настраивать маркеры транспортных средств и местоположений на карте, которую вы используете для своего веб-приложения для отслеживания отправлений для потребителей.
С помощью JavaScript Consumer SDK вы можете настраивать внешний вид двух типов маркеров, добавляемых на карту:
- Маркеры для транспортных средств доставки : используйте
deliveryVehicleMarkerCustomization
- Маркеры назначения : используйте
destinationMarkerCustomization
Это можно сделать двумя способами:
- Простейший вариант : укажите объект
MarkerOptions
, который будет применяться ко всем маркерам одного типа. Затем Consumer SDK применяет стиль в двух ситуациях: перед добавлением маркеров на карту и при изменении данных, используемых для маркеров. - Более продвинутый вариант : укажите функцию настройки. Функции настройки позволяют стилизовать маркеры на основе данных, а также добавлять к ним интерактивность, например, обработку нажатий. В частности, Consumer SDK передаёт функции настройки данные о типе объекта, который представляет маркер: транспортное средство или пункт назначения. Это позволяет изменять стиль маркера в зависимости от текущего состояния самого элемента маркера, например, количества запланированных остановок до пункта назначения. Вы даже можете объединить данные из внешних источников Fleet Engine и стилизовать маркер на основе этой информации.
Простой пример: использование MarkerOptions
В следующем примере показано, как настроить стиль маркера транспортного средства с помощью объекта MarkerOptions
. В этом примере непрозрачность маркера устанавливается равной 50%.
JavaScript
deliveryVehicleMarkerCustomization = {
opacity: 0.5
};
Машинопись
deliveryVehicleMarkerCustomization = {
opacity: 0.5
};
Расширенный пример: использование функции настройки
В следующем примере показано, как настроить стиль маркера транспортного средства для отображения оставшегося количества остановок транспортного средства до достижения остановки для запланированной задачи.
JavaScript
deliveryVehicleMarkerCustomization =
(params) => {
var stopsLeft = params.taskTrackingInfo.remainingStopCount;
params.marker.setLabel(`${stopsLeft}`);
};
Машинопись
deliveryVehicleMarkerCustomization =
(params: ShipmentMarkerCustomizationFunctionParams) => {
const stopsLeft = params.taskTrackingInfo.remainingStopCount;
params.marker.setLabel(`${stopsLeft}`);
};
Добавить обработку кликов к маркерам
Вы можете добавить обработку щелчков к любому маркеру, как в следующем примере для маркера транспортного средства.
JavaScript
deliveryVehicleMarkerCustomization =
(params) => {
if (params.isNew) {
params.marker.addListener('click', () => {
// Perform desired action.
});
}
};
Машинопись
deliveryVehicleMarkerCustomization =
(params: ShipmentMarkerCustomizationFunctionParams) => {
if (params.isNew) {
params.marker.addListener('click', () => {
// Perform desired action.
});
}
};
Отображать дополнительную информацию для маркеров
Вы можете использовать InfoWindow
для отображения дополнительной информации о транспортном средстве или маркере местоположения. В следующем примере создается InfoWindow
и прикрепляется к маркеру транспортного средства:
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();
Машинопись
// 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();