- Введение
- Как добавить несколько слоев кластеров, KML и GeoJSON
- Как добавить собственные объекты на карту
- Как обрабатывать события кликов
- Демонстрационное приложение
Введение
В предыдущих разделах руководства мы рассказали, как добавлять на карту объекты из данных KML и GeoJSON, а также кластеры маркеров. Но что, если вам нужно добавить несколько таких слоев на одну карту и отслеживать события кликов отдельно для каждого слоя?
Как добавить несколько слоев кластеров, KML и GeoJSON
Библиотека содержит объекты Manager
, позволяющие обрабатывать события кликов для нескольких типов слоев. Прежде чем настраивать слои, создайте экземпляры этих классов и передайте их своему объекту карты 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);
Затем вы сможете передать эти классы Manager конструкторам других слоев:
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);
Как добавить собственные объекты на карту
Создавать собственные маркеры, наземные наложения, ломаные линии или многоугольники напрямую в объекте GoogleMap
не рекомендуется. Советуем вместо этого создать собственный класс Collection
, а затем добавлять нужные объекты с помощью Managers
.
Например, чтобы добавить маркер, используйте приведенный ниже код:
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"));
Как обрабатывать события кликов
Для кластеров, объектов KML и GeoJSON прослушиватели кликов работают обычным образом (при условии, что вы пользовались описанным выше методом, то есть передали объекты Manager
конструкторам слоев).
Например, в следующем фрагменте кода показано, как настроить прослушиватель кликов для слоя 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());
Когда вы создаете собственные маркеры, наземные наложения, ломаные линии и многоугольники, добавляйте прослушиватели кликов в эти объекты Collection
. Например, в приведенном ниже фрагменте кода показано, как настроить прослушиватель кликов для объекта 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; });
Демонстрационное приложение
Пример добавления нескольких слоев можно найти в коде класса MultiLayerDemoActivity
в демонстрационном приложении из библиотеки утилит. Запуск демонстрационного приложения описан в руководстве по настройке.