- บทนำ
- การเพิ่มคลัสเตอร์, เลเยอร์ 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);
ขั้นตอนต่อไป คุณสามารถส่งคลาสผู้จัดการเหล่านี้ไปยังตัวสร้างของเลเยอร์อื่นๆ เมื่อคุณตั้งค่า
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);
การเพิ่มฟีเจอร์ของคุณเอง
หากต้องการเพิ่มตัวทำเครื่องหมาย การวางซ้อนพื้น โพลีไลน์ หรือรูปหลายเหลี่ยมของคุณเองไว้ข้างเลเยอร์เหล่านี้ ให้สร้าง Collection
ของคุณเอง แล้วใช้ Managers
เพื่อเพิ่มฟีเจอร์ดังกล่าวแทนการเพิ่มลงในวัตถุ GoogleMap
โดยตรง
ตัวอย่างเช่น หากคุณต้องการเพิ่มเครื่องหมายใหม่ ให้ทำดังนี้
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 คลิก Listener จะทำงานตามปกติ ตราบใดที่คุณผ่านคลาส Manager
ในตัวสร้างเลเยอร์ที่คุณตั้งค่า
ตัวอย่างเช่น วิธีตั้งค่า Listener การคลิกสำหรับเลเยอร์ 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());
เมื่อคุณเพิ่มเครื่องหมาย การวางซ้อนพื้น เส้น หรือรูปหลายเหลี่ยมของคุณเอง อย่าลืมเพิ่ม Listener การคลิกลงในวัตถุ Collection
เหล่านั้น ตัวอย่างเช่น วิธีตั้งค่า Listener การคลิกตัวทำเครื่องหมายใน 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
ในแอปเดโมที่ส่งมาพร้อมกับไลบรารียูทิลิตี คู่มือการตั้งค่าแสดงวิธีเรียกใช้แอปเดโม