Personalização básica de marcadores

Os marcadores 3D usam duas classes para definir marcadores: a classe 3DMarkerElement, que oferece os parâmetros básicos (position, label e map), e a classe PinElement, que contém opções para mais personalização.

Para adicionar marcadores a um mapa, primeiro carregue a biblioteca de marcadores, que fornece as classes 3DMarkerElement e PinElement.

O snippet a seguir mostra o código para criar um novo PinElement e aplicá-lo a um marcador:

const pinScaled = new PinElement({
  scale: 1.5,
});

const markerWithLabel = new Marker3DElement({
  position: { lat: 37.419, lng: -122.03 },
  label: 'Simple label'
});

Em mapas criados usando HTML, os parâmetros básicos de um marcador são declarados usando o elemento HTML gmp-marker-3d. Qualquer personalização que use a classe PinElement precisa ser aplicada de forma programática. Para fazer isso, o código precisa recuperar os elementos gmp-marker-3d da página HTML. O snippet a seguir mostra o código para consultar uma coleção de elementos gmp-marker-3d e iterar pelos resultados para aplicar a personalização declarada no 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);
}

Nesta página, mostramos como personalizar marcadores da seguinte forma:

Ajustar a escala do marcador

Para dimensionar um marcador, use a opção 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);

Mudar a cor do plano de fundo

Use a opção PinElement.background para mudar a cor de fundo de um 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);

Mudar a cor da borda

Use a opção PinElement.borderColor para mudar a cor da borda de um 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);

Mudar a cor do glifo

Use a opção PinElement.glyphColor para mudar a cor do glifo de um 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);

Adicionar texto a um glifo

Use a opção PinElement.glyph para substituir o glifo padrão por um caractere de texto. O glifo de texto do PinElement é dimensionado com o PinElement e a cor padrão dele corresponde ao glyphColor padrão do PinElement:

const pinTextGlyph = new PinElement({
  glyph: "T",
  glyphColor: "white",
});
const markerGlyphText = new Marker3DElement({
  map,
  position: { lat: 37.415, lng: -122.015 },
});

markerGlyphText.appendChild(pinTextGlyph);

Mudar a altitude

Use a opção Marker3DElement.position.altitude combinada com Marker3DElement.altitudeMode e Marker3DElement.extruded para mudar a altitude do marcador e adicionar uma linha extrudida entre o solo e o marcador:

const marker = new Marker3DElement({
  position: { lat: 37.4239163, lng: -122.0947209, altitude: 100 },
  altitudeMode: 'RELATIVE_TO_GROUND',
  extruded: true,
});

Remover marcadores

Use Marker3DElement.remove() para remover marcadores do mapa:

const marker = document.querySelector('gmp-marker-3d');
marker.remove();

Próximas etapas