- Introduzione
- Aggiunta di più livelli di cluster, KML e GeoJSON
- Aggiungere le tue funzionalità
- Gestire gli eventi di clic
- Guarda l'app demo
Introduzione
Nei tutorial precedenti, hai imparato ad aggiungere funzionalità alla mappa da KML e GeoJSON, nonché cluster di indicatori. E se volessi aggiungere molti di questi livelli sulla stessa mappa e ottenere eventi di clic indipendenti per ciascuno?
Aggiunta di più livelli di cluster, KML e GeoJSON
La libreria include Manager
oggetti che aiutano a gestire gli eventi di clic per più tipi di livelli. Quindi, prima di configurare i tuoi livelli, dovrai prima creare un'istanza e passare
nel tuo GoogleMap
:
Kotlin
val markerManager = MarkerManager(map) val groundOverlayManager = GroundOverlayManager(map!!) val polygonManager = PolygonManager(map) val polylineManager = PolylineManager(map)
Java
MarkerManager markerManager = new MarkerManager(map); GroundOverlayManager groundOverlayManager = new GroundOverlayManager(map); PolygonManager polygonManager = new PolygonManager(map); PolylineManager polylineManager = new PolylineManager(map);
Successivamente, puoi passare queste classi gestore nei costruttori degli altri livelli al momento della loro configurazione:
Kotlin
val clusterManager = ClusterManager<MyItem>(context, map, markerManager) val geoJsonLineLayer = GeoJsonLayer( map, R.raw.geojson_file, context, markerManager, polygonManager, polylineManager, groundOverlayManager ) val kmlPolylineLayer = KmlLayer( map, R.raw.kml_file, context, markerManager, polygonManager, polylineManager, groundOverlayManager, null )
Java
ClusterManager<MyItem> clusterManager = new ClusterManager<>(context, map, markerManager); GeoJsonLayer geoJsonLineLayer = new GeoJsonLayer(map, R.raw.geojson_file, context, markerManager, polygonManager, polylineManager, groundOverlayManager); KmlLayer kmlPolylineLayer = new KmlLayer(map, R.raw.kml_file, context, markerManager, polygonManager, polylineManager, groundOverlayManager, null);
Aggiunta di funzionalità personalizzate
Se vuoi aggiungere indicatori, overlay al suolo, polilinee o poligoni personalizzati accanto a questi livelli, crea il tuo Collection
e utilizza Managers
per aggiungere l'elemento invece di aggiungerli direttamente all'oggetto GoogleMap
.
Ad esempio, se vuoi aggiungere un nuovo indicatore:
Kotlin
val markerCollection = markerManager.newCollection() markerCollection.addMarker( MarkerOptions() .position(LatLng(51.150000, -0.150032)) .icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_AZURE)) .title("Unclustered marker") )
Java
MarkerManager.Collection markerCollection = markerManager.newCollection(); markerCollection.addMarker(new MarkerOptions() .position(new LatLng(51.150000, -0.150032)) .icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_AZURE)) .title("Unclustered marker"));
Gestione degli eventi di clic
Per cluster, KML e GeoJSON, i listener dei clic funzionano normalmente, a patto che passi le classi Manager
nel costruttore del livello che stai impostando.
Ad esempio, ecco come impostare un listener di clic per il livello KML:
Kotlin
kmlPolylineLayer.addLayerToMap() kmlPolylineLayer.setOnFeatureClickListener { feature: Feature -> Toast.makeText(context, "KML polyline clicked: ${feature.getProperty("name")}", Toast.LENGTH_SHORT ).show() }
Java
kmlPolylineLayer.addLayerToMap(); kmlPolylineLayer.setOnFeatureClickListener(feature -> Toast.makeText(context, "KML polyline clicked: " + feature.getProperty("name"), Toast.LENGTH_SHORT).show());
Quando aggiungi indicatori, overlay al suolo, polilinee o poligoni, devi solo assicurarti di aggiungere listener dei clic a questi Collection
oggetti. Ad esempio, ecco come impostare il listener dei clic sull'indicatore su markerCollection
:
Kotlin
markerCollection.setOnMarkerClickListener { marker: Marker -> Toast.makeText( context, "Marker clicked: ${marker.title}", Toast.LENGTH_SHORT ).show() false }
Java
markerCollection.setOnMarkerClickListener(marker -> { Toast.makeText(context, "Marker clicked: " + marker.getTitle(), Toast.LENGTH_SHORT).show(); return false; });
Guarda l'app demo
Per un esempio di aggiunta di più livelli, dai un'occhiata a MultiLayerDemoActivity
nell'app demo fornita con la libreria di utilità. La guida alla configurazione mostra come eseguire
l'app demo.