אפשר להגדיר שכבת תכונות שתגיב לאירועים של משתמש click
כדי לקבל את מזהה המיקום ואת סוג התכונה של הגבול שבו לוחצים. במפה לדוגמה הבאה מוצגים הגבולות של השכבה 'מדינה', וכן פונקציית טיפול באירועים שמגדירה את הסגנון של הפוליגון שנלחץ עליו ומשויך למדינה שנבחרה.
כתיבת פונקציית טיפול באירוע קליק
כשאירוע קליק מתרחש בשכבת תכונות, ה-SDK של מפות ל-Android מעביר אובייקט FeatureClickEvent
למטפל באירוע. משתמשים ב-FeatureClickEvent
כדי לקבל את קואורדינטות קו האורך וקו הרוחב של הלחיצה, ורשימה של התכונות שהושפעו מהלחיצה.
טיפול באירועים של שכבת תכונות
כדי לטפל באירועים בשכבת תכונות, פועלים לפי השלבים הבאים. בדוגמה הזו מגדירים טיפול באירוע לחיצה בשכבת המאפיינים Country כדי להחיל מילוי אדום על הפוליגון שמייצג את המדינה שנבחרה.
כשקוראים לפונקציה FeatureLayer.setFeatureStyle()
, פונקציית המפעל של הסגנון מגדירה את הסגנון לכל התכונות בשכבת התכונות. כדי לעדכן את הסגנון של תכונה במטפל באירוע, צריך להפעיל את FeatureLayer.setFeatureStyle()
כדי להגדיר את הסגנון המעודכן בכל התכונות.
אם עדיין לא עשיתם זאת, עליכם לפעול לפי השלבים המפורטים במאמר תחילת העבודה כדי ליצור מזהה מפה וסגנון מפה חדשים. חשוב להפעיל את שכבת המאפיינים Country.
מוודאים שהכיתה מיישמת את
FeatureLayer.OnFeatureClickListener
.כדי לרשום טיפול באירועים של קליקים על תכונות, צריך לבצע קריאה ל-
FeatureLayer.addOnFeatureClickListener()
.Java
private FeatureLayer countryLayer;
@Override public void onMapReady(GoogleMap map) {
// Get the COUNTRY feature layer. countryLayer = map.getFeatureLayer(new FeatureLayerOptions.Builder() .featureType(FeatureType.COUNTRY) .build());
// Register the click event handler for the Country layer. countryLayer.addOnFeatureClickListener(this);
// Apply default style to all countries on load to enable clicking. styleCountryLayer(); }
// Set default fill and border for all countries to ensure that they respond // to click events. private void styleCountryLayer() { FeatureLayer.StyleFactory styleFactory = (Feature feature) -> { return new FeatureStyle.Builder() // Set the fill color for the country as white with a 10% opacity. .fillColor(Color.argb(0.1, 0, 0, 0)) // Set border color to solid black. .strokeColor(Color.BLACK) .build(); };
// Apply the style factory function to the country feature layer. countryLayer.setFeatureStyle(styleFactory); }Kotlin
private var countryLayer: FeatureLayer? = null
override fun onMapReady(googleMap: GoogleMap) { // Get the COUNTRY feature layer. countryLayer = googleMap.getFeatureLayer(FeatureLayerOptions.Builder() .featureType(FeatureType.COUNTRY) .build())
// Register the click event handler for the Country layer. countryLayer?.addOnFeatureClickListener(this)
// Apply default style to all countries on load to enable clicking. styleCountryLayer() }
// Set default fill and border for all countries to ensure that they respond // to click events. private fun styleCountryLayer() { val styleFactory = FeatureLayer.StyleFactory { feature: Feature -> return@StyleFactory FeatureStyle.Builder() // Set the fill color for the country as white with a 10% opacity. .fillColor(Color.argb(0.1f, 0f, 0f, 0f)) // Set border color to solid black. .strokeColor(Color.BLACK) .build() }
// Apply the style factory function to the country feature layer. countryLayer?.setFeatureStyle(styleFactory) }מחילים צבע מילוי אדום על המדינה שנבחרה. רק על תכונות גלויות אפשר ללחוץ.
Java
@Override // Define the click event handler. public void onFeatureClick(FeatureClickEvent event) {
// Get the list of features affected by the click using // getPlaceIds() defined below. List<String> selectedPlaceIds = getPlaceIds(event.getFeatures());
if (!selectedPlaceIds.isEmpty()) { FeatureLayer.StyleFactory styleFactory = (Feature feature) -> { // Use PlaceFeature to get the placeID of the country. if (feature instanceof PlaceFeature) { if (selectedPlaceIds.contains(((PlaceFeature) feature).getPlaceId())) { return new FeatureStyle.Builder() // Set the fill color to red. .fillColor(Color.RED) .build(); } } return null; };
// Apply the style factory function to the feature layer. countryLayer.setFeatureStyle(styleFactory); } }
// Get a List of place IDs from the FeatureClickEvent object. private List<String> getPlaceIds(List<Feature> features) { List<String> placeIds = new ArrayList<>(); for (Feature feature : features) { if (feature instanceof PlaceFeature) { placeIds.add(((PlaceFeature) feature).getPlaceId()); } } return placeIds; }Kotlin
// Define the click event handler. override fun onFeatureClick(event: FeatureClickEvent) {
// Get the list of features affected by the click using // getPlaceIds() defined below. val selectedPlaceIds = getPlaceIds(event.getFeatures()) if (!selectedPlaceIds.isEmpty()) { val styleFactory = FeatureLayer.StyleFactory { feature: Feature -> // Use PlaceFeature to get the placeID of the country. if (feature is PlaceFeature) { if (selectedPlaceIds.contains((feature as PlaceFeature).getPlaceId())) { return@StyleFactory FeatureStyle.Builder() // Set the fill color to red. .fillColor(Color.RED) .build() } } return@StyleFactory null }
// Apply the style factory function to the feature layer. countryLayer?.setFeatureStyle(styleFactory) } }
// Get a List of place IDs from the FeatureClickEvent object. private fun getPlaceIds(features: List<Feature>): List<String> { val placeIds: MutableList<String> = ArrayList() for (feature in features) { if (feature is PlaceFeature) { placeIds.add((feature as PlaceFeature).getPlaceId()) } } return placeIds }