Символы (векторные значки)

  1. Введение
  2. Свойства символа
  3. Предварительно определенные символы
  4. Добавление символа к маркеру
  5. Добавление символа к ломаной линии
  6. Анимация символа

Введение

Symbol – это векторный значок, который можно показывать в объектах Marker и Polyline. Форма символа определяется с помощью разметки SVG. Объект path содержит единственное обязательное свойство Symbol, а также ряд свойств для персонализации внешнего вида символа, в том числе цвета заливки, типа и толщины штриха. Список свойств

В классе SymbolPath реализовано несколько предопределенных символов (см. список ниже).

Свойства символа

Следует отметить, что поведение объекта Symbol по умолчанию может различаться в зависимости от того, отображается символ на маркере или ломаной линии. Эти различия описаны в списке свойств ниже.

Symbol поддерживает следующие свойства:

  • path (обязательный параметр) – это путь, определяющий форму символа. Можно использовать один из предварительно определенных путей google.maps.SymbolPath или задать собственный с помощью разметки SVG. Отметим, что размер векторного пути на ломаной линии ограничен квадратом 22 x 22 пикселя. Если путь содержит точки вне этого квадрата, следует указать дробное значение масштаба символа scale (например, 0.2), чтобы результат масштабирования не выходил за пределы этого квадрата.
  • anchor – положение символа относительно маркера или ломаной линии. Координаты пути символа переносятся влево и вверх на соответствующие значения координат X и Y точки привязки. По умолчанию символ прикрепляется к точке (0, 0). Позиция выражается в той же системе координат, что и путь символа.
  • fillColor – цвет заливки символа. Поддерживаются все цвета CSS3, кроме цветов с расширенными именами. Для символьных маркеров по умолчанию используется значение "black". Для символов на ломаных линиях по умолчанию используется цвет соответствующей ломаной линии.
  • fillOpacity – относительная непрозрачность заливки символа. Значения варьируются от 0.0 (полная прозрачность) до 1.0 (полная непрозрачность). По умолчанию используется значение 0.0.
  • rotation – угол поворота символа, выраженный в градусах, отсчитываемых по часовой стрелке. По умолчанию свойство rotation имеет значение 0, а символ на ломаной линии поворачивается на тот же угол, что и сегмент линии, на котором он лежит. Установка значения rotation для символа на ломаной линии фиксирует поворот символа, и он больше не следует за направлением линии.
  • scale – величина, определяющая масштабирование символа. Для символьных маркеров по умолчанию используется значение 1. После масштабирования размер символа может быть любым. Для символов на ломаных линиях по умолчанию используется масштаб, соответствующий весу штриха ломаной линии. После масштабирования символ должен находиться внутри квадрата 22 x 22 пикс. и быть отцентрирован относительно точки его привязки.
  • strokeColor – цвет штриха символа. Поддерживаются все цвета CSS3, кроме цветов с расширенными именами. Для символов на маркерах по умолчанию используется черный цвет. Для символов на ломаных линиях по умолчанию используется цвет штриха ломаной линии.
  • strokeOpacity – относительная непрозрачность штриха символа. Значения варьируются от 0.0 (полная прозрачность) до 1.0 (полная непрозрачность). Для символьных маркеров по умолчанию используется значение 1.0. Для символов на ломаной линии по умолчанию применяется непрозрачность ее штриха.
  • strokeWeight – толщина штриха символа. По умолчанию равна значению scale для этого символа.

Предварительно определенные символы

В Maps JavaScript API предусмотрен ряд встроенных символов, которые можно добавлять к маркерам или ломаным линиям с помощью класса SymbolPath.

Стандартный набор символов включает окружность и стрелки двух типов (вперед и назад). Это особенно полезно для ломаных линий, поскольку символ на ломаной линии имеет фиксированную ориентацию. Направлением вперед считается направление в сторону конца ломаной линии.

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

Доступны следующие предварительно определенные символы.

Имя Описание Пример
google.maps.SymbolPath.CIRCLE Окружность.
google.maps.SymbolPath.BACKWARD_CLOSED_ARROW Замкнутая со всех сторон стрелка, указывающая назад.
google.maps.SymbolPath.FORWARD_CLOSED_ARROW Замкнутая со всех сторон стрелка, указывающая вперед.
google.maps.SymbolPath.BACKWARD_OPEN_ARROW Разомкнутая с одной стороны стрелка, указывающая назад.
google.maps.SymbolPath.FORWARD_OPEN_ARROW Разомкнутая с одной стороны стрелка, указывающая вперед.

Добавление символа к маркеру

Для показа векторного значка на маркере передайте литерал объекта Symbol, указав в нём путь до свойства маркера icon. В примере ниже для создания персонализированного значка используется нотация SVG для пути.

TypeScript

// This example uses SVG path notation to add a vector-based symbol
// as the icon for a marker. The resulting icon is a marker-shaped
// symbol with a blue fill and no border.

function initMap(): void {
  const center = new google.maps.LatLng(-33.712451, 150.311823);
  const map = new google.maps.Map(
    document.getElementById("map") as HTMLElement,
    {
      zoom: 9,
      center: center,
    }
  );

  const svgMarker = {
    path: "M-1.547 12l6.563-6.609-1.406-1.406-5.156 5.203-2.063-2.109-1.406 1.406zM0 0q2.906 0 4.945 2.039t2.039 4.945q0 1.453-0.727 3.328t-1.758 3.516-2.039 3.070-1.711 2.273l-0.75 0.797q-0.281-0.328-0.75-0.867t-1.688-2.156-2.133-3.141-1.664-3.445-0.75-3.375q0-2.906 2.039-4.945t4.945-2.039z",
    fillColor: "blue",
    fillOpacity: 0.6,
    strokeWeight: 0,
    rotation: 0,
    scale: 2,
    anchor: new google.maps.Point(0, 20),
  };

  new google.maps.Marker({
    position: map.getCenter(),
    icon: svgMarker,
    map: map,
  });
}

declare global {
  interface Window {
    initMap: () => void;
  }
}
window.initMap = initMap;

JavaScript

// This example uses SVG path notation to add a vector-based symbol
// as the icon for a marker. The resulting icon is a marker-shaped
// symbol with a blue fill and no border.
function initMap() {
  const center = new google.maps.LatLng(-33.712451, 150.311823);
  const map = new google.maps.Map(document.getElementById("map"), {
    zoom: 9,
    center: center,
  });
  const svgMarker = {
    path: "M-1.547 12l6.563-6.609-1.406-1.406-5.156 5.203-2.063-2.109-1.406 1.406zM0 0q2.906 0 4.945 2.039t2.039 4.945q0 1.453-0.727 3.328t-1.758 3.516-2.039 3.070-1.711 2.273l-0.75 0.797q-0.281-0.328-0.75-0.867t-1.688-2.156-2.133-3.141-1.664-3.445-0.75-3.375q0-2.906 2.039-4.945t4.945-2.039z",
    fillColor: "blue",
    fillOpacity: 0.6,
    strokeWeight: 0,
    rotation: 0,
    scale: 2,
    anchor: new google.maps.Point(0, 20),
  };

  new google.maps.Marker({
    position: map.getCenter(),
    icon: svgMarker,
    map: map,
  });
}

window.initMap = initMap;
Посмотреть пример

Примеры кода

Добавление символа к ломаной линии

Для отображения символов на ломаной линии установите свойство icons[] объекта PolylineOptions. Массив icons[] может принимать один или несколько литералов объекта IconSequence со следующими свойствами:

  • icon (обязательный параметр) – отображаемый на линии значок.
  • offset – расстояние от начальной точки линии, на которой отображается значок. Это значение можно указать как в процентах от длины линии (например, "50%"), так и в пикселях (например, "50px"). Значение по умолчанию – "100%".
  • repeat – расстояние между соседними значками на линии. Это значение можно указать как в процентах от длины линии (например, "50%"), так и в пикселях (например, "50px"). Чтобы отключить повторение значков, укажите "0". Значение по умолчанию – "0".

Применение символов и класса PolylineOptions дает широкие возможности для настройки внешнего вида полилиний на карте. Ниже приведены несколько примеров доступных настроек.

Стрелки

Добавить стрелки в начало или конец ломаной линии можно с помощью свойства IconSequence.offset.

// Define a symbol using a predefined path (an arrow)
// supplied by the Google Maps JavaScript API.
var lineSymbol = {
  path: google.maps.SymbolPath.FORWARD_CLOSED_ARROW
};

// Create the polyline and add the symbol via the 'icons' property.
var line = new google.maps.Polyline({
  path: [{lat: 22.291, lng: 153.027}, {lat: 18.291, lng: 153.027}],
  icons: [{
    icon: lineSymbol,
    offset: '100%'
  }],
  map: map
});

Посмотреть пример

Пунктирные линии

Для получения пунктирной линии можно установить для ломаной линии непрозрачность 0 и поместить над ней наложение с непрозрачным символом через регулярные интервалы.

// Define a symbol using SVG path notation, with an opacity of 1.
var lineSymbol = {
  path: 'M 0,-1 0,1',
  strokeOpacity: 1,
  scale: 4
};

// Create the polyline, passing the symbol in the 'icons' property.
// Give the line an opacity of 0.
// Repeat the symbol at intervals of 20 pixels to create the dashed effect.
var line = new google.maps.Polyline({
  path: [{lat: 22.291, lng: 153.027}, {lat: 18.291, lng: 153.027}],
  strokeOpacity: 0,
  icons: [{
    icon: lineSymbol,
    offset: '0',
    repeat: '20px'
  }],
  map: map
});

Посмотреть пример

Собственные пути

Настраиваемые символы позволяют добавлять к ломаной линии различные фигуры.

// Define the custom symbols. All symbols are defined via SVG path notation.
// They have varying stroke color, fill color, stroke weight,
// opacity and rotation properties.
  var symbolOne = {
    path: 'M -2,0 0,-2 2,0 0,2 z',
    strokeColor: '#F00',
    fillColor: '#F00',
    fillOpacity: 1
  };

  var symbolTwo = {
    path: 'M -1,0 A 1,1 0 0 0 -3,0 1,1 0 0 0 -1,0M 1,0 A 1,1 0 0 0 3,0 1,1 0 0 0 1,0M -3,3 Q 0,5 3,3',
    strokeColor: '#00F',
    rotation: 45
  };

  var symbolThree = {
    path: 'M -2,-2 2,2 M 2,-2 -2,2',
    strokeColor: '#292',
    strokeWeight: 4
  };

  // Create the polyline and add the symbols via the 'icons' property.
  var line = new google.maps.Polyline({
    path: [{lat: 22.291, lng: 153.027}, {lat: 18.291, lng: 153.027}],
    icons: [
      {
        icon: symbolOne,
        offset: '0%'
      }, {
        icon: symbolTwo,
        offset: '50%'
      }, {
        icon: symbolThree,
        offset: '100%'
      }
    ],
    map: map
  });

Посмотреть пример

Анимация символа

С помощью функции window.setInterval(), указывающей смещение символа с заданными интервалами, можно реализовать его анимацию вдоль пути.

TypeScript

// This example adds an animated symbol to a polyline.

function initMap(): void {
  const map = new google.maps.Map(
    document.getElementById("map") as HTMLElement,
    {
      center: { lat: 20.291, lng: 153.027 },
      zoom: 6,
      mapTypeId: "terrain",
    }
  );

  // Define the symbol, using one of the predefined paths ('CIRCLE')
  // supplied by the Google Maps JavaScript API.
  const lineSymbol = {
    path: google.maps.SymbolPath.CIRCLE,
    scale: 8,
    strokeColor: "#393",
  };

  // Create the polyline and add the symbol to it via the 'icons' property.
  const line = new google.maps.Polyline({
    path: [
      { lat: 22.291, lng: 153.027 },
      { lat: 18.291, lng: 153.027 },
    ],
    icons: [
      {
        icon: lineSymbol,
        offset: "100%",
      },
    ],
    map: map,
  });

  animateCircle(line);
}

// Use the DOM setInterval() function to change the offset of the symbol
// at fixed intervals.
function animateCircle(line: google.maps.Polyline) {
  let count = 0;

  window.setInterval(() => {
    count = (count + 1) % 200;

    const icons = line.get("icons");

    icons[0].offset = count / 2 + "%";
    line.set("icons", icons);
  }, 20);
}

declare global {
  interface Window {
    initMap: () => void;
  }
}
window.initMap = initMap;

JavaScript

// This example adds an animated symbol to a polyline.
function initMap() {
  const map = new google.maps.Map(document.getElementById("map"), {
    center: { lat: 20.291, lng: 153.027 },
    zoom: 6,
    mapTypeId: "terrain",
  });
  // Define the symbol, using one of the predefined paths ('CIRCLE')
  // supplied by the Google Maps JavaScript API.
  const lineSymbol = {
    path: google.maps.SymbolPath.CIRCLE,
    scale: 8,
    strokeColor: "#393",
  };
  // Create the polyline and add the symbol to it via the 'icons' property.
  const line = new google.maps.Polyline({
    path: [
      { lat: 22.291, lng: 153.027 },
      { lat: 18.291, lng: 153.027 },
    ],
    icons: [
      {
        icon: lineSymbol,
        offset: "100%",
      },
    ],
    map: map,
  });

  animateCircle(line);
}

// Use the DOM setInterval() function to change the offset of the symbol
// at fixed intervals.
function animateCircle(line) {
  let count = 0;

  window.setInterval(() => {
    count = (count + 1) % 200;

    const icons = line.get("icons");

    icons[0].offset = count / 2 + "%";
    line.set("icons", icons);
  }, 20);
}

window.initMap = initMap;
Посмотреть пример

Примеры кода