WebGL

Classe WebGLOverlayView

Classe google.maps.WebGLOverlayView

A visualização de sobreposição do WebGL fornece acesso direto ao mesmo contexto de renderização WebGL usado pela Plataforma Google Maps para renderizar o mapa básico vetorial. Esse uso de um contexto de renderização compartilhada oferece benefícios, como a oclusão de profundidade com geometria de construção em 3D e a capacidade de sincronizar conteúdo 2D/3D com a renderização do mapa básico.

Com a visualização de sobreposição do WebGL, você pode adicionar conteúdo aos mapas usando diretamente o WebGL ou bibliotecas de gráficos conhecidas, como a Three.js ou a deck.gl. Para usar a sobreposição, é possível estender google.maps.WebGLOverlayView e fornecer uma implementação para cada um dos seguintes hooks de ciclo de vida: WebGLOverlayView.onAdd, WebGLOverlayView.onContextRestored, WebGLOverlayView.onDraw, WebGLOverlayView.onContextLost e WebGLOverlayView.onRemove.

Chame WebGLOverlayView.setMap com um objeto Map válido para acionar a chamada para o método onAdd() e setMap(null) para acionar o método onRemove(). O método setMap() pode ser chamado no momento da construção ou em qualquer momento depois, quando a sobreposição precisa ser mostrada novamente após a remoção. O método onDraw() é chamado sempre que uma propriedade do mapa muda e pode alterar a posição do elemento, como zoom, centralização ou tipo de mapa. A WebGLOverlayView só pode ser adicionada a um mapa vetorial com um MapOptions.mapId (incluindo mapas definidos como RenderingType.VECTOR MapOptions.renderingType e usando Map.DEMO_MAP_ID como MapOptions.mapId).

Essa classe estende MVCObject.

Acesse chamando const {WebGLOverlayView} = await google.maps.importLibrary("maps"). Consulte Bibliotecas na API Maps JavaScript.

WebGLOverlayView
WebGLOverlayView()
Parâmetros:nenhum
Cria uma WebGLOverlayView.
getMap
getMap()
Parâmetros:nenhum
Valor de retorno:Map|null|undefined
onAdd
onAdd()
Parâmetros:nenhum
Valor de retorno:nenhum
Implemente esse método para buscar ou criar estruturas de dados intermediárias antes de desenhar a sobreposição sem necessidade de acesso imediato ao contexto de renderização do WebGL. Esse método precisa ser implementado para renderização.
onContextLost
onContextLost()
Parâmetros:nenhum
Valor de retorno:nenhum
Esse método é chamado quando o contexto de renderização é perdido por algum motivo e é onde você precisa limpar qualquer estado GL preexistente, já que ele não é mais necessário.
onContextRestored
onContextRestored(options)
Parâmetros:
  • optionsWebGLStateOptions que permitem que os desenvolvedores restaurem o contexto GL.
Valor de retorno:nenhum
Esse método é chamado quando o contexto de renderização está disponível. Use esse hook para inicializar ou vincular qualquer estado WebGL, como sombreadores ou objetos de buffer.
onDraw
onDraw(options)
Parâmetros:
  • optionsWebGLDrawOptions que permitem que os desenvolvedores renderizem conteúdo em um mapa base associado do Google.
Valor de retorno:nenhum
Implemente esse método para desenhar conteúdo do WebGL diretamente no mapa. Se a sobreposição precisar de um novo frame desenhado, chame WebGLOverlayView.requestRedraw.
onRemove
onRemove()
Parâmetros:nenhum
Valor de retorno:nenhum
Esse método é chamado quando a sobreposição é removida do mapa com WebGLOverlayView.setMap(null), e é de onde você precisa remover todos os objetos intermediários. Esse método precisa ser implementado para renderização.
onStateUpdate
onStateUpdate(options)
Parâmetros:
  • optionsWebGLStateOptions que permite que os desenvolvedores restaurem o contexto GL.
Valor de retorno:nenhum
Implemente esse método para processar qualquer atualização de estado do GL fora do frame de animação de renderização.
requestRedraw
requestRedraw()
Parâmetros:nenhum
Valor de retorno:nenhum
Aciona o mapa para redesenhar um frame.
requestStateUpdate
requestStateUpdate()
Parâmetros:nenhum
Valor de retorno:nenhum
Aciona o mapa para atualizar o estado do GL.
setMap
setMap([map])
Parâmetros:
  • mapMap optional O mapa para acessar o estado de div, modelo e visualização.
Valor de retorno:nenhum
Adiciona a sobreposição ao mapa.
Herdado: addListener, bindTo, get, notify, set, setValues, unbind, unbindAll

Interface WebGLDrawOptions

Interface google.maps.WebGLDrawOptions

Opções de desenho.

gl
O WebGLRenderingContext em que renderizar essa WebGLOverlayView.
transformer
A transformação de matriz do espaço da câmera para coordenadas de latitude/longitude.

Interface WebGLStateOptions

Interface google.maps.WebGLStateOptions

Opções de estado do GL.

gl
O WebGLRenderingContext em que renderizar essa WebGLOverlayView.

Interface CoordinateTransformer

Interface google.maps.CoordinateTransformer

Essa interface oferece métodos práticos para gerar matrizes a serem usadas na renderização de cenas do WebGL sobre o mapa básico do Google.

Observação: uma referência a esse objeto não pode ser mantida fora do escopo da chamada WebGLOverlayView.onDraw encapsulante.

fromLatLngAltitude
fromLatLngAltitude(latLngAltitude[, rotations, scale])
Parâmetros:
  • latLngAltitudeLatLngAltitude|LatLngAltitudeLiteral Latitude, longitude e altitude.
  • rotationsFloat32Array optional Uma matriz que contém um ângulo de rotação de Euler em graus, na convenção XYZ.
  • scale:  matriz Float32Array optional que contém uma matriz escalar XYZ para aplicar ao eixo cardinal.
Valor de retorno:Float64Array matriz MVP a ser usada com o WebGL.
getCameraParams
getCameraParams()
Parâmetros:nenhum
Valor de retorno:parâmetros da câmera CameraParams

Interface CameraParams

Interface google.maps.CameraParams

Usado para recuperar parâmetros da câmera, como a câmera GL usada para o WebGLOverlayView.

Essa interface estende CameraOptions.

center
Tipo:LatLng
heading
Tipo:number
tilt
Tipo:number
zoom
Tipo:number