Tıklama etkinliklerini işleme

Platform seçin: Android iOS JavaScript

Tıklanan sınırın yer kimliğini ve özellik türünü almak için bir özellik katmanının kullanıcı click etkinliklerine yanıt vermesini sağlayabilirsiniz. Aşağıdaki örnek haritada Ülke katmanının sınırları ve seçilen ülkeyle ilişkili tıklanan poligonu biçimlendiren bir etkinlik işleyici gösterilmektedir.

Tıklama etkinlik işleyici yazma

Bir özellik katmanında tıklama etkinliği gerçekleştiğinde Android için Haritalar SDK'sı, etkinlik işleyiciye bir FeatureClickEvent nesnesi iletir. Tıklamanın enlem ve boylam koordinatlarını ve tıklamadan etkilenen özelliklerin listesini almak için FeatureClickEvent simgesini kullanın.

Özellik katmanı etkinliklerini işleme

Bir özellik katmanındaki etkinlikleri işlemek için aşağıdaki adımları uygulayın. Bu örnekte Ülke özellik katmanı için kırmızı bir renk uygulamak üzere bir tıklama etkinliği işleyicisi seçilen ülkeyi temsil eden poligona doldurun.

FeatureLayer.setFeatureStyle() işlevini çağırdığınızda stil fabrikası işlevi, özellik katmanındaki tüm özelliklerde stili ayarlar. Etkinlik işleyicisindeki bir özelliğin stilini güncellemek için tüm özelliklerde güncel stili ayarlamak üzere FeatureLayer.setFeatureStyle() işlevini çağırmanız gerekir.

  1. Henüz yapmadıysanız yeni bir harita kimliği ve harita stili oluşturmak için Başlayın bölümündeki adımları uygulayın. Ülke özellik katmanını etkinleştirdiğinizden emin olun.

  2. Sınıfınızın şunu uyguladığından emin olun: FeatureLayer.OnFeatureClickListener.

  3. Özellik tıklama etkinlikleri için şu numarayı arayarak bir etkinlik işleyici kaydedin: 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. Seçilen ülkeye kırmızı bir dolgu rengi uygulayın. Yalnızca görünür özellikler tıklanabilir.

    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 }