En esta guía, se proporciona una descripción detallada de los componentes web de Maps 3D y las consideraciones que debes tener en cuenta cuando los integras a tu aplicación.
Consideraciones de rendimiento
Para garantizar una experiencia fluida y responsiva para la interactividad y los elementos visuales, considera los siguientes enfoques.
Carga el mapa
La carga inicial y la configuración de renderización de Maps 3D combinan técnicas de configuración del navegador y prácticas recomendadas de la IU para lograr una experiencia del usuario óptima.
- Carga de la API: Usa la carga dinámica asíncrona de Maps 3D para cargar la API de Maps JavaScript en la carga inicial de la página.
- Bibliotecas: Carga bibliotecas de forma programática cuando sea necesario, como
google.maps.importLibrary("maps3d"). Como alternativa, si usas componentes web como<gmp-map-3d>directamente en tu página HTML con carga directa de, las bibliotecas se cargarán automáticamente en el momento adecuado. - Administra las funciones del mapa base: Usa un mapId personalizado para filtrar los POI del mapa base (modo HYBRID) y controlar su densidad, en especial si la aplicación tiene su propio conjunto de elementos personalizados, como marcadores o polilíneas. Esto evita el desorden visual y la posible superposición. Como alternativa, puedes inhabilitar las funciones de mosaicos vectoriales del mapa base, como los POI, las polilíneas de carreteras, los nombres de carreteras y los nombres de calles (modo SATELLITE).
- Eventos: Escucha los eventos gmp-steadystate o gmp-error para compilar tu lógica posterior, como cargar marcadores y animar la cámara.
Interacción del usuario: Espera el evento gmp-steadystate antes de realizar cambios en el contenido del mapa. Si un usuario comienza a interactuar (paneo, zoom) con el mapa antes del evento gmp-steadystate inicial, el evento solo se activará después de que el usuario deje de interactuar. Evita mostrar o actualizar el contenido superpuesto (como marcadores o polígonos) mientras el usuario hace un paneo o zoom en el mapa. Para ello, escucha gmp-centerchange, gmp-headingchange gmp-rangechange gmp-rollchange gmp-tiltchange.
Usa
requestAnimationFrame()(rAF) para obtener actualizaciones continuas y separa estrictamente los cálculos intensivos de las llamadas de dibujo.- Usa rAF: Sincroniza las actualizaciones con la frecuencia de actualización del navegador para obtener una animación fluida de 60 FPS y reducir el consumo de energía.
- Evita el trabajo de dibujo intensivo: No realices tareas pesadas que no sean de dibujo durante la actualización final.
- Separa la lógica: Realiza toda la lógica intensiva antes de las llamadas de actualización mínimas de componentes web dentro del bucle rAF.
Configuración inicial de la escena:
<gmp-map-3d>La configuración de la cámara, como la inclinación, afectará la velocidad de carga. Cuanto más se acerque o incline la escena, más polígonos detallados se mostrarán y requerirán carga. El nivel de detalle también dependerá de la ubicación (p.ej., una ciudad con muchos edificios en comparación con el campo con solo elementos naturales).Visualización del precargador: Si bien
<gmp-map-3d>se carga muy rápido, es posible que tarde un tiempo en mostrarse en resolución completa para los usuarios con dispositivos de gama baja (GPU baja) o ancho de banda (4G lento). En este caso, puedes crear un precargador con imagen, animación o texto con la escena 3D que se carga en segundo plano. Consulta el evento clave que se usará a continuación:
// create the map in the background and wait for gmp-steadystate event async function initMap() { await google.maps.importLibrary("maps3d"); const map = document.querySelector('gmp-map-3d'); const div = document.querySelector('div'); // preloader " map.addEventListener('gmp-steadystate', ({isSteady}) => { if (isSteady) { div.style.display = 'none'; } }); } initMap();
- Mapa 2D:
- Se puede entregar un mapa 2D alternativo (SATELLITE) a estos usuarios y, al mismo tiempo, incluir tus datos geográficos, como marcadores.
- Como alternativa, se puede mostrar un mapa estático 2D complementario en modo SATELLITE para que los usuarios visualicen un lugar determinado mientras se carga.
Rendimiento y administración de elementos visuales
Maps 3D ofrece varias formas de mostrar elementos visuales, como marcadores, polilíneas, polilíneas y modelos 3D con un rendimiento óptimo y un tiempo mínimo de renderización, incluso para imágenes de mayor volumen.
Marcadores
- PinElement: Para cambios básicos de marcadores (color, escala, borde, glifo de texto
), usa el elemento
<gmp-pin>o la clasePinElement. Este es el método de personalización que ofrece el mejor rendimiento. - Usa HTMLImageElement o SVGElement Markers con moderación: Úsalos para obtener más
personalización, como agregar transparencia o insertar una imagen, como un
ícono, en un SVGElement (requiere codificación
base64). Se rasterizarán en la carga y generarán una sobrecarga de rendimiento. HTMLImageElement
y SVGElement deben incluirse en el elemento
<template>antes de asignarlos a la ranura predeterminada de Marker3DElement. - Por ahora, no está disponible la opción para agregar HTML o CSS sin formato.
Polígonos y polilíneas
- Simplifica la geometría: Antes de la renderización, aplica un algoritmo de simplificación a tus datos de ruta. Esto reduce la cantidad de vértices y, al mismo tiempo, conserva la forma general, lo que mejora drásticamente la velocidad de renderización, en especial para límites o rutas complejos.
- Diezmación por nivel de zoom: Para conjuntos de datos muy grandes, considera cargar una geometría más detallada solo cuando el usuario acerque el área. En un nivel de zoom bajo, solo es necesaria una versión muy simplificada de la polilínea o el polígono.
- Cálculo previo para polígonos extruidos: Si tus polígonos están extruidos
(
extruded: true), los datos de ruta definen un volumen 3D (una malla). El procesamiento de polígonos complejos de alta vértice es costoso desde el punto de vista computacional. Asegúrate de que los datos de origen de tus polígonos sean lo más simples posible. - Prueba el rendimiento de polilíneas y polígonos: Cuando agregues polilíneas o polígonos complejos o numerosos, en especial cuando se extruyen para 3D, asegúrate de que no provoquen caídas en la velocidad de fotogramas. Limita la cantidad de vértices o usa algoritmos de simplificación si es necesario.
- Cuando actualices una forma, modifica todo el array de ruta en una sola operación en lugar de iterar y modificar elementos individuales. Una sola operación de asignación (p.ej., polyline.path = newPathArray;) es mucho más eficiente que varias actualizaciones iterativas.
- Evita las polilíneas extruidas (si es posible): Si bien las polilíneas pueden usar un valor de altitud para colocarse en el espacio 3D, la extrusión de una polilínea (p.ej., darle un ancho de trazo y un gran intervalo de altitud) puede ser intensiva desde el punto de vista gráfico. Siempre que sea posible, usa polilíneas 2D en el suelo (RELATIVE_TO_GROUND) o un ancho de trazo mínimo para obtener un mejor rendimiento.
- Usa drawsOccludedSegments solo para elementos de enrutamiento críticos. Para formas de fondo o contextuales, permite que la geometría 3D del mapa las ocluya de forma natural. Mostrar geometría oculta no crítica agrega una complejidad de renderización innecesaria.
Modelos 3D
La renderización y la interactividad de modelos 3D .glb, como el evento gmp-click, son muy rápidas en <gmp-map-3d>.
- Minimiza el tamaño del archivo con la compresión: Para garantizar una carga rápida, en especial en redes móviles, mantén los archivos de modelos .glb complejos por debajo de 5 MB (lo ideal es que sean menos). El método principal para lograr esto es aplicar la compresión de Draco en los datos de malla dentro de tus archivos .glb, lo que puede reducir significativamente el tamaño del archivo (a menudo, en más del 50%) con una pérdida mínima de calidad visual.
- Centra el origen del modelo: Asegúrate de que el software de modelado 3D exporte el modelo con su origen (punto 0, 0, 0) centrado en la base del modelo. Esto simplifica el posicionamiento y la rotación en el mapa, lo que garantiza que el modelo se ancle correctamente a las coordenadas de latitud y longitud.
- Administra CORS: Si tus archivos de modelos están alojados en un dominio o CDN diferente al de tu aplicación web, debes configurar el servidor de hosting para que incluya los encabezados necesarios de Uso compartido de recursos entre dominios (CORS) (p.ej., Access-Control-Allow-Origin: *). De lo contrario, el mapa no podrá cargar el modelo.