Вы можете настроить слой объектов на реакцию на click пользователя, чтобы получать идентификатор места и тип объекта для границы, на которую нажал пользователь. На следующем примере карты показаны границы слоя «Страна» и обработчик событий, который стилизует полигон, на который нажал пользователь, связанный с выбранной страной.
Напишите обработчик событий щелчка
 Когда на слое объектов происходит событие щелчка, Maps SDK для Android передаёт обработчику событий объект FeatureClickEvent . Используйте FeatureClickEvent для получения координат широты и долготы щелчка, а также списка объектов, затронутых щелчком.
Обработка событий слоя объектов
Выполните следующие шаги для обработки событий на векторном слое. В этом примере вы определяете обработчик событий щелчка для векторного слоя «Страна», чтобы применить красную заливку к полигону, представляющему выбранную страну.
 При вызове FeatureLayer.setFeatureStyle() функция-фабрика стилей устанавливает стиль для всех объектов в слое объектов. Чтобы обновить стиль объекта в обработчике событий, необходимо вызвать FeatureLayer.setFeatureStyle() , чтобы установить обновлённый стиль для всех объектов.
- Если вы ещё этого не сделали, следуйте инструкциям в разделе «Начало работы» , чтобы создать новый идентификатор и стиль карты. Не забудьте включить слой объектов « Страна» . 
- Убедитесь, что ваш класс реализует - FeatureLayer.OnFeatureClickListener.
- Зарегистрируйте обработчик событий для событий щелчков по функциям, вызвав - FeatureLayer.addOnFeatureClickListener().- Ява- 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); }- Котлин- 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) }
- Применить заливку красным цветом к выбранной стране. Щелкнуть можно только по видимым объектам. - Ява- @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; }- Котлин- // 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 }