
Gli indicatori identificano le posizioni sulla mappa. L'indicatore predefinito utilizza un'icona standard, comune all'aspetto di Google Maps. È possibile modificare il colore, l'immagine o il punto di ancoraggio dell'icona tramite l'API. Gli indicatori sono oggetti di tipo
Marker e vengono aggiunti alla mappa con il metodo
GoogleMap.addMarker(markerOptions).
Gli indicatori sono progettati per essere interattivi. Per impostazione predefinita, ricevono eventi click e vengono spesso utilizzati con i listener di eventi per visualizzare le finestre
informative. Se imposti la proprietà draggable di un indicatore su true, l'utente può modificarne la posizione. Tieni premuto a lungo per attivare la possibilità di spostare l'indicatore.
Per impostazione predefinita, quando un utente tocca un indicatore, la barra degli strumenti della mappa viene visualizzata in basso a destra, consentendo all'utente di accedere rapidamente all'app mobile Google Maps. Puoi disattivare la barra degli strumenti. Per ulteriori informazioni, consulta la guida ai controlli.
Aggiungi un indicatore
L'esempio seguente mostra come aggiungere un indicatore a una mappa. L'indicatore viene creato alle coordinate -33.852,151.211 (Sydney, Australia) e visualizza la stringa "Indicatore a Sydney" in una finestra informativa quando viene selezionato.
Kotlin
override fun onMapReady(googleMap: GoogleMap) { // Add a marker in Sydney, Australia, // and move the map's camera to the same location. val sydney = LatLng(-33.852, 151.211) googleMap.addMarker( MarkerOptions() .position(sydney) .title("Marker in Sydney") ) googleMap.moveCamera(CameraUpdateFactory.newLatLng(sydney)) }
Java
@Override public void onMapReady(GoogleMap googleMap) { // Add a marker in Sydney, Australia, // and move the map's camera to the same location. LatLng sydney = new LatLng(-33.852, 151.211); googleMap.addMarker(new MarkerOptions() .position(sydney) .title("Marker in Sydney")); googleMap.moveCamera(CameraUpdateFactory.newLatLng(sydney)); }
Visualizza informazioni aggiuntive su un indicatore
Un requisito comune è mostrare informazioni aggiuntive su un luogo o una posizione quando l'utente tocca un indicatore sulla mappa. Consulta la guida alle finestre informative.
Associa i dati a un indicatore
Puoi archiviare un oggetto dati arbitrario con un indicatore utilizzando Marker.setTag() e recuperare l'oggetto dati utilizzando Marker.getTag(). L'esempio seguente mostra come contare il numero di volte in cui è stato fatto clic su un indicatore utilizzando i tag:
Kotlin
/** * A demo class that stores and retrieves data objects with each marker. */ class MarkerDemoActivity : AppCompatActivity(), OnMarkerClickListener, OnMapReadyCallback { private val PERTH = LatLng(-31.952854, 115.857342) private val SYDNEY = LatLng(-33.87365, 151.20689) private val BRISBANE = LatLng(-27.47093, 153.0235) private var markerPerth: Marker? = null private var markerSydney: Marker? = null private var markerBrisbane: Marker? = null override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_markers) val mapFragment = supportFragmentManager.findFragmentById(R.id.map) as SupportMapFragment? mapFragment!!.getMapAsync(this) } /** Called when the map is ready. */ override fun onMapReady(map: GoogleMap) { // Add some markers to the map, and add a data object to each marker. markerPerth = map.addMarker( MarkerOptions() .position(PERTH) .title("Perth") ) markerPerth?.tag = 0 markerSydney = map.addMarker( MarkerOptions() .position(SYDNEY) .title("Sydney") ) markerSydney?.tag = 0 markerBrisbane = map.addMarker( MarkerOptions() .position(BRISBANE) .title("Brisbane") ) markerBrisbane?.tag = 0 // Set a listener for marker click. map.setOnMarkerClickListener(this) } /** Called when the user clicks a marker. */ override fun onMarkerClick(marker: Marker): Boolean { // Retrieve the data from the marker. val clickCount = marker.tag as? Int // Check if a click count was set, then display the click count. clickCount?.let { val newClickCount = it + 1 marker.tag = newClickCount Toast.makeText( this, "${marker.title} has been clicked $newClickCount times.", Toast.LENGTH_SHORT ).show() } // Return false to indicate that we have not consumed the event and that we wish // for the default behavior to occur (which is for the camera to move such that the // marker is centered and for the marker's info window to open, if it has one). return false } }
Java
/** * A demo class that stores and retrieves data objects with each marker. */ public class MarkerDemoActivity extends AppCompatActivity implements GoogleMap.OnMarkerClickListener, OnMapReadyCallback { private final LatLng PERTH = new LatLng(-31.952854, 115.857342); private final LatLng SYDNEY = new LatLng(-33.87365, 151.20689); private final LatLng BRISBANE = new LatLng(-27.47093, 153.0235); private Marker markerPerth; private Marker markerSydney; private Marker markerBrisbane; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_markers); SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map); mapFragment.getMapAsync(this); } /** Called when the map is ready. */ @Override public void onMapReady(GoogleMap map) { // Add some markers to the map, and add a data object to each marker. markerPerth = map.addMarker(new MarkerOptions() .position(PERTH) .title("Perth")); markerPerth.setTag(0); markerSydney = map.addMarker(new MarkerOptions() .position(SYDNEY) .title("Sydney")); markerSydney.setTag(0); markerBrisbane = map.addMarker(new MarkerOptions() .position(BRISBANE) .title("Brisbane")); markerBrisbane.setTag(0); // Set a listener for marker click. map.setOnMarkerClickListener(this); } /** Called when the user clicks a marker. */ @Override public boolean onMarkerClick(final Marker marker) { // Retrieve the data from the marker. Integer clickCount = (Integer) marker.getTag(); // Check if a click count was set, then display the click count. if (clickCount != null) { clickCount = clickCount + 1; marker.setTag(clickCount); Toast.makeText(this, marker.getTitle() + " has been clicked " + clickCount + " times.", Toast.LENGTH_SHORT).show(); } // Return false to indicate that we have not consumed the event and that we wish // for the default behavior to occur (which is for the camera to move such that the // marker is centered and for the marker's info window to open, if it has one). return false; } }
Di seguito sono riportati alcuni esempi di scenari in cui è utile archiviare e recuperare i dati con gli indicatori:
- La tua app potrebbe supportare diversi tipi di indicatori e vuoi trattarli in modo diverso quando l'utente fa clic su di essi. Per farlo, puoi archiviare una
Stringcon l'indicatore che indica il tipo. - Potresti interfacciarti con un sistema che ha identificatori di record univoci, in cui gli indicatori rappresentano record specifici in quel sistema.
- I dati dell'indicatore possono indicare una priorità da utilizzare per decidere l'indice z di un indicatore.
Rendi trascinabile un indicatore
Puoi riposizionare un indicatore una volta aggiunto alla mappa, a condizione che la proprietà draggable sia impostata su true. Tieni premuto a lungo l'indicatore per attivare il trascinamento. Quando sollevi il dito dallo schermo, l'indicatore rimane in quella posizione.
Per impostazione predefinita, gli indicatori non sono trascinabili. Devi impostare esplicitamente l'indicatore come trascinabile con MarkerOptions.draggable(boolean) prima di aggiungerlo alla mappa o con Marker.setDraggable(boolean) una volta aggiunto alla mappa.
Puoi ascoltare gli eventi di trascinamento sull'indicatore, come descritto in Eventi di trascinamento dell'indicatore.
Lo snippet seguente aggiunge un indicatore trascinabile a Perth, in Australia.
Kotlin
val perthLocation = LatLng(-31.90, 115.86) val perth = map.addMarker( MarkerOptions() .position(perthLocation) .draggable(true) )
Java
final LatLng perthLocation = new LatLng(-31.90, 115.86); Marker perth = map.addMarker( new MarkerOptions() .position(perthLocation) .draggable(true));
Personalizza un indicatore
Questo video mostra i modi per utilizzare gli indicatori per visualizzare le posizioni su una mappa.
Gli indicatori possono definire un'immagine personalizzata da mostrare al posto dell'icona predefinita. La definizione di un'icona comporta l'impostazione di una serie di proprietà che influiscono sul comportamento visivo dell'indicatore.
Gli indicatori supportano la personalizzazione tramite le seguenti proprietà:
- Posizione (obbligatoria)
- Il
LatLngvalore per la posizione dell'indicatore sulla mappa. Questa è l'unica proprietà obbligatoria per un oggettoMarker. - Ancoraggio
- Il punto dell'immagine che verrà posizionato nella posizione LatLng dell' indicatore. Per impostazione predefinita, è il centro della parte inferiore dell'immagine.
- Alpha
- Imposta l'opacità dell'indicatore. Il valore predefinito è 1.0.
- Titolo
- Una stringa visualizzata nella finestra informativa quando l'utente tocca l' indicatore.
- Snippet
- Testo aggiuntivo visualizzato sotto il titolo.
- Icona
- Una bitmap visualizzata al posto dell'immagine dell'indicatore predefinita.
- Trascinabile
- Imposta su
truese vuoi consentire all'utente di spostare l'indicatore. Il valore predefinito èfalse. - Visibile
- Imposta su
falseper rendere invisibile l'indicatore. Il valore predefinito ètrue. - Orientamento piatto o cartellone
- Per impostazione predefinita, gli indicatori utilizzano un orientamento cartellone, il che significa che vengono disegnati orientati verso lo schermo del dispositivo anziché verso la superficie della mappa. La rotazione, l'inclinazione o lo zoom della mappa non modificano l'orientamento del indicatore. Puoi impostare l'orientamento di un indicatore in modo che sia piatto rispetto alla terra. Gli indicatori piatti ruotano quando la mappa viene ruotata e cambiano prospettiva quando la mappa viene inclinata. Come per gli indicatori cartellone, gli indicatori piatti mantengono le loro dimensioni quando la mappa viene ingrandita o rimpicciolita.
- Rotazione
- L'orientamento dell'indicatore, specificato in gradi in senso orario. La posizione predefinita cambia se l'indicatore è piatto. La posizione predefinita per un indicatore piatto è allineata a nord. Quando l'indicatore non è piatto, la posizione predefinita è verso l'alto e la rotazione è tale che l'indicatore sia sempre rivolto verso la videocamera.
Lo snippet seguente crea un indicatore semplice con l'icona predefinita.
Kotlin
val melbourneLocation = LatLng(-37.813, 144.962) val melbourne = map.addMarker( MarkerOptions() .position(melbourneLocation) )
Java
final LatLng melbourneLocation = new LatLng(-37.813, 144.962); Marker melbourne = map.addMarker( new MarkerOptions() .position(melbourneLocation));
Personalizza il colore dell'indicatore
È possibile personalizzare il colore dell'immagine dell'indicatore predefinita passando un oggetto BitmapDescriptor al metodo icon(). Puoi utilizzare un insieme di
colori predefiniti nell'BitmapDescriptorFactory
oggetto o impostare un colore dell'indicatore personalizzato con il
BitmapDescriptorFactory.defaultMarker(float hue) metodo. La tonalità è un valore compreso tra 0 e 360, che rappresenta i punti su una ruota dei colori.
Kotlin
val melbourneLocation = LatLng(-37.813, 144.962) val melbourne = map.addMarker( MarkerOptions() .position(melbourneLocation) .icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_AZURE)) )
Java
final LatLng melbourneLocation = new LatLng(-37.813, 144.962); Marker melbourne = map.addMarker( new MarkerOptions() .position(melbourneLocation) .icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_AZURE)));
Personalizza l'opacità dell'indicatore
Puoi controllare l'opacità di un indicatore con il metodo MarkerOptions.alpha(). Il valore alfa deve essere specificato come un valore float compreso tra 0.0 e 1.0, dove 0 è completamente trasparente e 1 è completamente opaco.
Kotlin
val melbourneLocation = LatLng(-37.813, 144.962) val melbourne = map.addMarker( MarkerOptions() .position(melbourneLocation) .alpha(0.7f) )
Java
final LatLng melbourneLocation = new LatLng(-37.813, 144.962); Marker melbourne = map.addMarker(new MarkerOptions() .position(melbourneLocation) .alpha(0.7f));
Personalizza l'immagine dell'indicatore
Puoi sostituire l'immagine dell'indicatore predefinita con un'immagine dell'indicatore personalizzata, spesso chiamata icona. Le icone personalizzate vengono sempre impostate come BitmapDescriptor e
definite utilizzando uno dei metodi della
BitmapDescriptorFactory classe.
fromAsset(String assetName)- Crea un indicatore personalizzato utilizzando il nome di un'immagine bitmap nella directory delle risorse.
fromBitmap(Bitmap image)- Crea un indicatore personalizzato da un'immagine bitmap.
fromFile(String fileName)- Crea un'icona personalizzata utilizzando il nome di un file di immagine bitmap memorizzato nella memoria interna.
fromPath(String absolutePath)- Crea un indicatore personalizzato da un percorso di file assoluto di un'immagine bitmap.
fromResource(int resourceId)- Crea un indicatore personalizzato utilizzando l'ID risorsa di un'immagine bitmap.
Lo snippet seguente crea un indicatore con un'icona personalizzata.
Kotlin
val melbourneLocation = LatLng(-37.813, 144.962) val melbourne = map.addMarker( MarkerOptions() .position(melbourneLocation) .title("Melbourne") .snippet("Population: 4,137,400") .icon(BitmapDescriptorFactory.fromResource(R.drawable.arrow)) )
Java
final LatLng melbourneLocation = new LatLng(-37.813, 144.962); Marker melbourne = map.addMarker( new MarkerOptions() .position(melbourneLocation) .title("Melbourne") .snippet("Population: 4,137,400") .icon(BitmapDescriptorFactory.fromResource(R.drawable.arrow)));
Appiattisci un indicatore
Le icone degli indicatori vengono normalmente disegnate rispetto allo schermo; la rotazione, l'inclinazione o lo zoom della mappa non modificano l'orientamento dell'indicatore. Puoi impostare l'orientamento di un indicatore in modo che sia piatto rispetto alla terra. Gli indicatori orientati in questo modo ruotano quando la mappa viene ruotata e cambiano prospettiva quando la mappa viene inclinata. Gli indicatori piatti mantengono le loro dimensioni quando la mappa viene ingrandita o rimpicciolita.
Per modificare l'orientamento dell'indicatore, imposta la proprietà flat dell'indicatore su true.
Kotlin
val perthLocation = LatLng(-31.90, 115.86) val perth = map.addMarker( MarkerOptions() .position(perthLocation) .flat(true) )
Java
final LatLng perthLocation = new LatLng(-31.90, 115.86); Marker perth = map.addMarker( new MarkerOptions() .position(perthLocation) .flat(true));
Ruota un indicatore
Puoi ruotare un indicatore attorno al suo punto di ancoraggio con il metodo Marker.setRotation(). La rotazione viene misurata in gradi in senso orario dalla posizione predefinita. Quando l'indicatore è piatto sulla mappa, la posizione predefinita è a nord. Quando l'indicatore non è piatto, la posizione predefinita è verso l'alto e la rotazione è tale che l'indicatore sia sempre rivolto verso la videocamera.
L'esempio seguente ruota l'indicatore di 90°. Se imposti il punto di ancoraggio su 0.5,0.5, l'indicatore viene ruotato attorno al suo centro anziché alla sua base.
Kotlin
val perthLocation = LatLng(-31.90, 115.86) val perth = map.addMarker( MarkerOptions() .position(perthLocation) .anchor(0.5f, 0.5f) .rotation(90.0f) )
Java
final LatLng perthLocation = new LatLng(-31.90, 115.86); Marker perth = map.addMarker( new MarkerOptions() .position(perthLocation) .anchor(0.5f,0.5f) .rotation(90.0f));
Indice z dell'indicatore
L'indice z specifica l'ordine di sovrapposizione di questo indicatore rispetto ad altri indicatori sulla mappa. Un indicatore con un indice z elevato viene disegnato sopra gli indicatori con indici z inferiori. Il valore predefinito dell'indice z è 0.
Imposta l'indice z sull'oggetto delle opzioni dell'indicatore chiamando MarkerOptions.zIndex(), come mostrato nello snippet di codice seguente:
Kotlin
map.addMarker( MarkerOptions() .position(LatLng(10.0, 10.0)) .title("Marker z1") .zIndex(1.0f) )
Java
map.addMarker(new MarkerOptions() .position(new LatLng(10, 10)) .title("Marker z1") .zIndex(1.0f));
Puoi accedere all'indice z dell'indicatore chiamando Marker.getZIndex() e modificarlo chiamando Marker.setZIndex().
Gli indicatori vengono sempre disegnati sopra i livelli di riquadri e altri overlay non indicatori (overlay a terra, polilinee, poligoni e altre forme) indipendentemente dall'indice z degli altri overlay. Gli indicatori sono effettivamente considerati in un gruppo di indici z separato rispetto ad altri overlay.
Scopri di più su l'effetto dell'indice z sugli eventi di clic di seguito.
Gestisci gli eventi degli indicatori
L'API di Google Maps ti consente di rimanere in ascolto e rispondere agli eventi degli indicatori. Per ascoltare questi eventi, devi impostare il listener corrispondente sull'oggetto GoogleMap a cui appartengono gli indicatori. Quando l'evento si verifica su uno degli indicatori sulla mappa, viene richiamato il callback del listener con l'oggetto Marker corrispondente passato come parametro. Per confrontare questo oggetto Marker con il tuo riferimento a un oggetto Marker, devi utilizzare equals() e non ==.
Puoi ascoltare i seguenti eventi:
- Eventi di clic sull'indicatore
- Eventi di trascinamento dell'indicatore
- Eventi di clic sulla finestra informativa
Eventi di clic sull'indicatore
Puoi utilizzare un OnMarkerClickListener per ascoltare
gli eventi di clic sull'indicatore. Per impostare questo listener sulla mappa, chiama GoogleMap.setOnMarkerClickListener(OnMarkerClickListener). Quando un utente fa clic su un indicatore, viene chiamato onMarkerClick(Marker) e l'indicatore viene passato come argomento. Questo metodo restituisce un valore booleano che indica se hai utilizzato l'evento (ovvero se vuoi sopprimere il comportamento predefinito). Se restituisce false, oltre al comportamento personalizzato si verificherà anche il comportamento predefinito. Il comportamento predefinito per un evento di clic sull'indicatore
è mostrare la relativa finestra informativa (se disponibile) e spostare la
videocamera in modo che l'indicatore sia centrato sulla mappa.
Effetto dell'indice z sugli eventi di clic:
- Quando un utente fa clic su un cluster di indicatori, l'evento di clic viene attivato per l'indicatore con l'indice z più elevato.
- Viene attivato al massimo un evento per clic. In altre parole, il clic non viene passato agli indicatori o ad altri overlay con valori di indice z inferiori.
- Se fai clic su un cluster di indicatori, i clic successivi scorrono il cluster, selezionando ogni indicatore a turno. L'ordine del ciclo assegna la priorità all'indice z, quindi alla prossimità al punto di clic.
- Se l'utente fa clic al di fuori della prossimità del cluster, l'API ricalcola il cluster e reimposta lo stato del ciclo di clic in modo che inizi dall'inizio.
- Gli indicatori sono effettivamente considerati in un gruppo di indici z separato rispetto ad altri overlay o forme (polilinee, poligoni, cerchi e/o overlay a terra), indipendentemente dall'indice z degli altri overlay. Se più indicatori, overlay o forme sono sovrapposti l'uno all'altro, l'evento di clic viene eseguito prima sul cluster di indicatori.
Eventi di trascinamento dell'indicatore
Puoi utilizzare un OnMarkerDragListener per ascoltare gli eventi di trascinamento su un indicatore. Per impostare questo listener sulla mappa, chiama GoogleMap.setOnMarkerDragListener. Per trascinare un indicatore, l'utente deve tenerlo premuto a lungo. Quando l'utente solleva il dito dallo schermo, l'indicatore rimane in quella posizione. Quando un indicatore viene trascinato, viene chiamato inizialmente onMarkerDragStart(Marker). Mentre l'indicatore viene trascinato, viene chiamato costantemente onMarkerDrag(Marker). Alla fine del trascinamento viene chiamato onMarkerDragEnd(Marker). Puoi ottenere la posizione dell'indicatore in qualsiasi momento chiamando Marker.getPosition().