ניהול אירועי קליקים

בחירת פלטפורמה: Android iOS JavaScript

אפשר להגדיר לשכבת התכונות להגיב לאירועים מסוג click של משתמש כדי לקבל את המקום המזהה וסוג התכונה עבור התחום שעליו המשתמש לחץ. המפה הבאה מציגה את הגבולות של השכבה 'מדינה'. מציג handler של אירועים שמפרט את הפוליגון שעליו לוחצים ומשויכים המדינה שנבחרה.

כתיבת הגורם המטפל באירועים של קליקים

כשמתרחש אירוע מסוג קליק בשכבת תכונה, ה-SDK של מפות Google ל-Android מעביר FeatureClickEvent לגורם המטפל באירועים. יש להשתמש ב-FeatureClickEvent כדי לקבל את קו הרוחב וקו האורך של הקליק ורשימת מאפיינים שהושפעו לקליק.

טיפול באירועים של שכבות תכונות

יש לפעול לפי השלבים הבאים כדי לטפל באירועים בשכבת התכונות. במשפט הזה, מגדירים מטפל באירועי קליק בשכבת התכונות 'מדינה' כדי להחיל מילוי לפוליגון שמייצג את המדינה שנבחרה.

כשמתקשרים FeatureLayer.setFeatureStyle(), פונקציה זו מגדירה את הסגנון עבור כל התכונות בשכבת זרימת הנתונים. כדי לעדכן את הסגנון של תכונה ב-handler של אירועים, צריך קוראים לפונקציה FeatureLayer.setFeatureStyle() כדי להגדיר את הסגנון המעודכן בכל המכשירים לבינה מלאכותית גנרטיבית.

  1. אם עדיין לא עשית זאת, יש לפעול לפי השלבים המפורטים ב- איך מתחילים כדי ליצור מזהה מפה וסגנון מפה חדשים. צריך להפעיל את המדינה. בשכבת זרימת הנתונים.

  2. חשוב לוודא שהכיתה מוטמעת FeatureLayer.OnFeatureClickListener

  3. רישום handler של אירועים לאירועי קליקים על תכונות באמצעות קריאה 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) }

  4. החלת צבע מילוי אדום על המדינה שנבחרה. רק התכונות הגלויות קליקבילי.

    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 }