Los marcadores en 3D usan dos clases para definir marcadores: la clase 3DMarkerElement
proporciona los parámetros básicos (position
, label
y map
), y la clase PinElement
contiene opciones para una mayor personalización.
Para agregar marcadores a un mapa, primero debes cargar la biblioteca de marcadores, que proporciona las clases 3DMarkerElement
y PinElement
.
En el siguiente fragmento, se muestra el código para crear un PinElement
nuevo y, luego, aplicarlo a un marcador:
const pinScaled = new PinElement({
scale: 1.5,
});
const markerWithLabel = new Marker3DElement({
position: { lat: 37.419, lng: -122.03 },
label: 'Simple label'
});
En los mapas creados con HTML, los parámetros básicos de un marcador se declaran con el elemento HTML gmp-marker-3d
. Cualquier personalización que use la clase PinElement
se debe aplicar de forma programática. Para ello, tu código debe recuperar los elementos gmp-marker-3d
de la página HTML. En el siguiente fragmento, se muestra código para consultar una colección de elementos gmp-marker-3d
y, luego, iterar por los resultados para aplicar la personalización que se declaró en 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);
}
En esta página, se muestra cómo personalizar los marcadores de las siguientes maneras:
- Cómo cambiar el tamaño del marcador
- Cómo cambiar el color de fondo
- Cómo cambiar el color del borde
- Cómo cambiar el color del glifo
- Cómo agregar texto a un glifo
- Cómo cambiar la altitud
- Cómo quitar marcadores
Cómo aumentar la escala del marcador
Para escalar un marcador, usa la opción 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);
Cómo cambiar el color del fondo
Usa la opción PinElement.background
para cambiar el color de fondo de un marcador:
// 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);
Cómo cambiar el color del borde
Usa la opción PinElement.borderColor
para cambiar el color del borde de un marcador:
// 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);
Cómo cambiar el color del glifo
Usa la opción PinElement.glyphColor
para cambiar el color del glifo de un marcador:
// 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);
Cómo agregar texto a un glifo
Usa la opción PinElement.glyph
para reemplazar el glifo predeterminado por un carácter de texto. El glifo de texto de PinElement
se ajusta con PinElement
y su color predeterminado coincide con el glyphColor
predeterminado de PinElement:
const pinTextGlyph = new PinElement({
glyph: "T",
glyphColor: "white",
});
const markerGlyphText = new Marker3DElement({
map,
position: { lat: 37.415, lng: -122.015 },
});
markerGlyphText.appendChild(pinTextGlyph);
Cambia la altitud
Usa la opción Marker3DElement.position.altitude
combinada con Marker3DElement.altitudeMode
y Marker3DElement.extruded
para cambiar la altitud del marcador y agregar una línea extruida entre el suelo y el marcador:
const marker = new Marker3DElement({
position: { lat: 37.4239163, lng: -122.0947209, altitude: 100 },
altitudeMode: 'RELATIVE_TO_GROUND',
extruded: true,
});
Cómo quitar marcadores
Usa Marker3DElement.remove()
para quitar marcadores del mapa:
const marker = document.querySelector('gmp-marker-3d');
marker.remove();