Nesta página, mostramos um exemplo de como adicionar um mapa 3D básico a um app Android usando o SDK do Maps 3D para Android. As instruções nesta página pressupõem que você já concluiu as etapas na página Configuração e tem o seguinte:
- Um projeto do Google Cloud com o SDK do Maps 3D para Android ativado
- Uma chave de API configurada para uso com o SDK do Maps 3D para Android
- Um projeto do Android Studio configurado para uso com o SDK do Maps 3D para Android
Para mais informações sobre esses pré-requisitos, consulte Configuração.
Parte 1: atualizar o arquivo de layout (activity_main.xml
) para adicionar o componente Map3DView
O componente Map3DView
é a visualização que renderiza o mapa 3D no app.
As etapas a seguir adicionam o componente e configuram o estado inicial do
mapa, incluindo a posição da câmera e atributos relacionados:
Abra o arquivo de layout da sua atividade principal, que geralmente está localizado em
app/src/main/res/layout/activity_main.xml
.No
ConstraintLayout
raiz (ou elemento de layout raiz), adicione o namespace XMLmap3d
:xmlns:map3d="http://schemas.android.com/apk/res-auto"
Exclua o
<TextView>
padrão que mostra "Hello World!".Adicione o componente
Map3DView
ao layout. É possível personalizar a posição da câmera e outros atributos:<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:map3d="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/main" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity"> <com.google.android.gms.maps3d.Map3DView android:id="@+id/map3dView" android:layout_width="match_parent" android:layout_height="match_parent" map3d:mode="hybrid" map3d:centerLat="38.544012" map3d:centerLng="-107.670428" map3d:centerAlt="2427.6" map3d:heading="310" map3d:tilt="63" map3d:range="8266" map3d:roll="0" map3d:minAltitude="0" map3d:maxAltitude="1000000" map3d:minHeading="0" map3d:maxHeading="360" map3d:minTilt="0" map3d:maxTilt="90" app:layout_constraintBottom_toBottomOf="parent" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toTopOf="parent" /> </androidx.constraintlayout.widget.ConstraintLayout>
Parte 2: atualizar MainActivity.kt
As etapas a seguir inicializam o componente Map3DView
adicionado ao
arquivo activity_main.xml
na Parte 1 e gerenciam eventos do ciclo de vida do componente:
Abra o arquivo
MainActivity.kt
, que geralmente está localizado emapp/src/main/java/com/example/yourpackagename/MainActivity.kt
.Adicione as importações necessárias para o SDK do Maps 3D para Android:
import com.google.android.gms.maps3d.GoogleMap3D import com.google.android.gms.maps3d.Map3DView import com.google.android.gms.maps3d.OnMap3DViewReadyCallback
Modifique a classe
MainActivity
para implementarOnMap3DViewReadyCallback
:class MainActivity : AppCompatActivity(), OnMap3DViewReadyCallback {
Declare variáveis para
Map3DView
eGoogleMap3D
:private lateinit var map3DView: Map3DView private var googleMap3D: GoogleMap3D? = null
No método
onCreate
, depois desetContentView(...)
e do blocoViewCompat.setOnApplyWindowInsetsListener
, inicialize omap3DView
, chame o método de ciclo de vidaonCreate
e solicite o mapa de forma assíncrona:override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) enableEdgeToEdge() setContentView(R.layout.activity_main) ViewCompat.setOnApplyWindowInsetsListener(findViewById(R.id.main)) { v, insets -> val systemBars = insets.getInsets(WindowInsetsCompat.Type.systemBars()) v.setPadding(systemBars.left, systemBars.top, systemBars.right, systemBars.bottom) insets } map3DView = findViewById(R.id.map3dView) map3DView.onCreate(savedInstanceState) map3DView.getMap3DViewAsync(this) }
Modifique o método
onMap3DViewReady
. Esse callback é acionado quando o mapa está pronto para ser usado:override fun onMap3DViewReady(googleMap3D: GoogleMap3D) { // Interact with the googleMap3D object here this.googleMap3D = googleMap3D // You can now make calls to the googleMap3D object, e.g., // googleMap3D.cameraController.flyTo(camera { ... }) }
Encaminhe os eventos de ciclo de vida da sua atividade para o
Map3DView
adicionando as seguintes substituições aoMainActivity
:override fun onStart() { super.onStart() map3DView.onStart() } override fun onResume() { super.onResume() map3DView.onResume() } override fun onPause() { map3DView.onPause() super.onPause() } override fun onStop() { map3DView.onStop() super.onStop() } override fun onDestroy() { map3DView.onDestroy() super.onDestroy() } override fun onSaveInstanceState(outState: Bundle) { super.onSaveInstanceState(outState) map3DView.onSaveInstanceState(outState) } override fun onLowMemory() { super.onLowMemory() map3DView.onLowMemory() }
Parte 3: sincronizar o Gradle e executar
Agora que você atualizou o layout e a atividade do app, crie e execute o app para ver a visualização do mapa em 3D.
Para sincronizar seu projeto com o Gradle, selecione File > Sync Project with Gradle Files.
Para criar e executar o app em um emulador ou dispositivo físico, selecione Run > Run.
Se tudo estiver configurado corretamente, um mapa 3D vai aparecer no app, centralizado perto das coordenadas especificadas no activity_main.xml
.
Próximas etapas
Agora que você adicionou um mapa 3D básico ao seu app, pode explorar recursos mais avançados do SDK do Maps 3D para Android, como animações de trajetória da câmera, marcadores 3D ou polígonos.