В 3D-маркерах для определения маркеров используются два класса: класс 3DMarkerElement
предоставляет базовые параметры ( position
, label
и map
), а класс PinElement
содержит параметры для дальнейшей настройки.
Чтобы добавить маркеры на карту, необходимо сначала загрузить библиотеку маркеров, которая предоставляет классы 3DMarkerElement
и PinElement
.
В следующем фрагменте показан код для создания нового PinElement
и последующего применения его к маркеру:
const pinScaled = new PinElement({
scale: 1.5,
});
const markerWithLabel = new Marker3DElement({
position: { lat: 37.419, lng: -122.03 },
label: 'Simple label'
});
В картах, созданных с использованием HTML, основные параметры маркера объявляются с помощью HTML-элемента gmp-marker-3d
; любая настройка, использующая класс PinElement
, должна применяться программно. Для этого ваш код должен получить элементы gmp-marker-3d
со страницы HTML. В следующем фрагменте показан код для запроса коллекции элементов gmp-marker-3d
, а затем перебор результатов для применения настроек, объявленных в gmp-marker-3d.
// Return an array of markers.
const markers = [...document.querySelectorAll('gmp-marker-3d')];
// Loop through the markers
for (let i = 0; i < markers.length; i++) {
const pin = new PinElement({
scale: 2.0,
});
markers[i].appendChild(pin.element);
}
На этой странице показано, как настроить маркеры следующими способами:
- Масштабировать маркер
- Изменить цвет фона
- Изменить цвет границы
- Изменить цвет глифа
- Добавление текста в глиф
- Изменить высоту
- Удалить маркеры
Масштабировать маркер
Чтобы масштабировать маркер, используйте опцию scale
:
// Adjust the scale.
const pinScaled = new PinElement({
scale: 1.5,
});
const markerScaled = new Marker3DElement({
map,
position: { lat: 37.419, lng: -122.02 },
});
markerScaled.appendChild(pinScaled);
Изменить цвет фона
Используйте параметр PinElement.background
, чтобы изменить цвет фона маркера:
// Change the background color.
const pinBackground = new PinElement({
background: '#FBBC04',
});
const markerBackground = new Marker3DElement({
map,
position: { lat: 37.419, lng: -122.01 },
});
markerBackground.appendChild(pinBackground);
Изменить цвет границы
Используйте параметр PinElement.borderColor
, чтобы изменить цвет границы маркера:
// Change the border color.
const pinBorder = new PinElement({
borderColor: "#137333",
});
const markerBorder = new Marker3DElement({
map,
position: { lat: 37.415, lng: -122.035 },
});
markerBorder.appendChild(pinBorder);
Изменить цвет глифа
Используйте параметр PinElement.glyphColor
, чтобы изменить цвет глифа маркера:
// Change the glyph color.
const pinGlyph = new PinElement({
glyphColor: "white",
});
const markerGlyph = new Marker3DElement({
map,
position: { lat: 37.415, lng: -122.025 },
});
markerGlyph.appendChild(pinGlyph);
Добавление текста в глиф
Используйте параметр PinElement.glyph
, чтобы заменить глиф по умолчанию текстовым символом. Текстовый глиф PinElement
масштабируется вместе с PinElement
, а его цвет по умолчанию соответствует glyphColor
по умолчанию PinElement:
const pinTextGlyph = new PinElement({
glyph: "T",
glyphColor: "white",
});
const markerGlyphText = new Marker3DElement({
map,
position: { lat: 37.415, lng: -122.015 },
});
markerGlyphText.appendChild(pinTextGlyph);
Изменить высоту
Используйте параметр Marker3DElement.position.altitude
в сочетании с Marker3DElement.altitudeMode
и Marker3DElement.extruded
, чтобы изменить высоту маркера и добавить вытянутую линию между землей и маркером:
const marker = new Marker3DElement({
position: { lat: 37.4239163, lng: -122.0947209, altitude: 100 },
altitudeMode: 'RELATIVE_TO_GROUND',
extruded: true,
});
Удалить маркеры
Используйте Marker3DElement.remove()
, чтобы удалить маркеры с карты:
const marker = document.querySelector('gmp-marker-3d');
marker.remove();