التعامل مع أحداث النقر

اختيار النظام الأساسي: Android iOS JavaScript

يمكنك جعل طبقة ميزة تستجيب لأحداث click للمستخدم للحصول على رقم تعريف المكان ونوع العنصر للحدود التي تم النقر عليها. يعرض المثال التالي على الخريطة حدود طبقة "البلد"، كما يعرض معالج أحداث يحدد نمط المضلّع الذي تم النقر عليه والمرتبط بالبلد المحدّد.

كتابة معالج حدث النقر

عند وقوع حدث ناتج عن النقر على إحدى طبقات الميزات، تمرِّر حزمة تطوير البرامج لـ "خرائط Google" لتطبيقات Android كائن FeatureClickEvent إلى معالج الأحداث. استخدم FeatureClickEvent للحصول على إحداثيات خط العرض وخط الطول للنقرة، وقائمة الميزات التي تأثرت بالنقرة.

التعامل مع أحداث طبقة الميزات

اتّبِع الخطوات التالية للتعامل مع الأحداث على طبقة عناصر. في هذا المثال، يمكنك تحديد معالِج لحدث النقر لطبقة عناصر "البلد" لتطبيق حشوة باللون الأحمر على المضلع الذي يمثّل البلد المحدّد.

عند استدعاء FeatureLayer.setFeatureStyle()، تضبط دالة المصنع في النمط النمط على جميع الميزات في طبقة الميزات. لتعديل نمط عنصر في معالِج الأحداث، عليك استدعاء FeatureLayer.setFeatureStyle() لضبط النمط المعدَّل على كل العناصر.

  1. يُرجى اتّباع الخطوات الواردة في البدء لإنشاء رقم تعريف ونمط خريطة جديدَين إذا لم يسبق لك إجراء ذلك. تأكَّد من تفعيل طبقة الميزات البلد.

  2. تأكد من تنفيذ الصف FeatureLayer.OnFeatureClickListener.

  3. يمكنك تسجيل معالج أحداث لأحداث النقر على الميزات من خلال الاتصال بالرقم 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 }