Настроить маркеры

В этом документе описано, как настроить маркеры транспортных средств и местоположения на карте, используемой в вашем веб-приложении для отслеживания отправлений для потребителей.

С помощью JavaScript Consumer SDK вы можете настраивать внешний вид двух типов маркеров, добавляемых на карту:

Это можно сделать одним из двух способов:

  • Простейший вариант : укажите объект MarkerOptions , который будет применяться ко всем маркерам одного типа. Затем Consumer SDK применяет стили в двух ситуациях: перед добавлением маркеров на карту и при изменении данных, используемых для маркеров.
  • Более продвинутый вариант : укажите функцию настройки. Функции настройки позволяют изменять стиль маркеров на основе данных, а также добавлять интерактивность к маркерам, например, обработку кликов. В частности, 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();

Что дальше?