Libreria di Maps

Jetpack Compose è un toolkit UI nativo e dichiarativo che semplifica e accelera lo sviluppo dell'UI. Con Jetpack Compose, descrivi l'aspetto che vuoi dare alla tua app e poi lascia che Jetpack Compose si occupi del resto.

La libreria Maps Compose per Maps SDK for Android è un insieme di funzioni componibili open source e tipi di dati che puoi utilizzare con Jetpack Compose per creare la tua app.

La libreria Maps Compose contiene funzioni componibili e tipi di dati che ti consentono di eseguire molte attività comuni. Ecco alcune delle funzioni componibili e dei tipi di dati di uso comune:

Componibile Descrizione
Cerchia Funzione componibile per aggiungere un cerchio a una mappa.
GoogleMap Funzione componibile per aggiungere una mappa.
GroundOverlay Funzione componibile per aggiungere una sovrapposizione a terra a una mappa.
MapProperties Tipo di dati per le proprietà che possono essere modificate su una mappa.
MapUISettings Tipo di dati per le impostazioni relative all'UI su una mappa.
Indicatore Funzione componibile per aggiungere un indicatore a una mappa.
Poligono Funzione componibile per aggiungere un poligono a una mappa.
Polyline Funzione componibile per aggiungere una polilinea a una mappa.
TileOverlay Funzione componibile per aggiungere un overlay riquadri a una mappa.

Per un elenco completo di tutte le funzioni componibili e i tipi di dati, consulta la documentazione di riferimento della libreria Maps Compose.

Requisiti

Per utilizzare la libreria Maps Compose con Maps SDK for Android, devi:

  • Scarica e installa Android Studio Arctic Fox.
  • Creare un progetto di Google Maps in Android Studio con:

    • Un tipo di modello Empty Compose Activity. Questo modello aggiunge le dipendenze necessarie richieste da Jetpack Compose.
    • SDK minimo impostato su API 21: Android 5.0 (Lollipop) o versioni successive.
    • Lingua impostata su Kotlin.
  • Ottenere una chiave API e aggiungerla al progetto.

  • Installare la libreria Maps Compose nel progetto come descritto nella sezione successiva.

Installazione

Per installare la libreria Maps Compose nel tuo progetto di Google Maps:

  1. Aggiungi le seguenti dipendenze al file build.gradle.kts a livello di modulo:

      dependencies {
    
        // Android Maps Compose composables for the Maps SDK for Android
        implementation("com.google.maps.android:maps-compose:6.12.0")
    }

  2. Ricompila il progetto in Android Studio per sincronizzare queste modifiche.

Aggiungere una mappa all'app

L'esempio seguente mostra come utilizzare il GoogleMap componibile per aggiungere una mappa.

val singapore = LatLng(1.35, 103.87)
val singaporeMarkerState = rememberUpdatedMarkerState(position = singapore)
val cameraPositionState = rememberCameraPositionState {
  position = CameraPosition.fromLatLngZoom(singapore, 10f)
}
GoogleMap(
  modifier = Modifier.fillMaxSize(),
  cameraPositionState = cameraPositionState
) {
  Marker(
    state = singaporeMarkerState,
    title = "Singapore",
    snippet = "Marker in Singapore"
  )
}

In questo esempio, la mappa occupa lo spazio massimo consentito e la videocamera è centrata su Singapore. Viene creato e fornito anche un CameraPositionState in cameraPositionState per impostare la posizione della videocamera.

L'esempio chiama quindi il Marker componibile nel contenuto della mappa per aggiungere un indicatore alla mappa.

Per confrontare questo esempio con un esempio che aggiunge una mappa utilizzando le visualizzazioni, consulta la QuickStart. Tieni presente che le funzioni componibili richiedono meno codice e non devi preoccuparti del ciclo di vita della mappa.

Impostare le proprietà su una mappa

Puoi impostare le proprietà sulla mappa fornendo un oggetto MapProperties o un oggetto MapUiSettings per le proprietà relative all'UI. Puoi modificare questi oggetti per attivare la ricomposizione del la mappa.

Nell'esempio seguente, utilizza un componente Switch di Material Design per attivare o disattivare i controlli dello zoom sulla mappa.

var uiSettings by remember { mutableStateOf(MapUiSettings()) }
var properties by remember {
  mutableStateOf(MapProperties(mapType = MapType.SATELLITE))
}

Box(Modifier.fillMaxSize()) {
  GoogleMap(
    modifier = Modifier.matchParentSize(),
    properties = properties,
    uiSettings = uiSettings
  )
  Switch(
    checked = uiSettings.zoomControlsEnabled,
    onCheckedChange = {
      uiSettings = uiSettings.copy(zoomControlsEnabled = it)
    }
  )
}

Passaggi successivi