По умолчанию точки интереса (POI) отображаются на базовой карте вместе с соответствующими значками. К POI относятся парки, школы, правительственные здания и многое другое. Кроме того, бизнес -POI по умолчанию отображаются на карте, если тип карты — kGMSTypeNormal
. Бизнес-POI представляют собой такие предприятия, как магазины, рестораны, гостиницы и т. д.
POI соответствует идентификатору места , как определено в Places SDK для iOS. Например, парки отдыха являются POI, но такие объекты, как фонтаны, как правило, не являются POI (если только они не имеют национального или исторического значения).
Прослушивание событий кликов на POI
Если вы хотите реагировать на то, что пользователь нажимает на POI, реализуйте GMSMapViewDelegate
и реализуйте mapView(_:didTapPOIWithPlaceID:name:location:)
, как показано в следующем примере:
Быстрый
import GoogleMaps class POI: UIViewController, GMSMapViewDelegate { override func loadView() { let camera = GMSCameraPosition.camera( withLatitude: 47.603, longitude:-122.331, zoom:14 ) let mapView = GMSMapView.map(withFrame: .zero, camera: camera) mapView.delegate = self self.view = mapView } func mapView( _ mapView: GMSMapView, didTapPOIWithPlaceID placeID: String, name: String, location: CLLocationCoordinate2D ) { print("You tapped \(name): \(placeID), \(location.latitude)/\(location.longitude)") } }
Цель-C
#import "POI.h" @import GoogleMaps; @interface POI () <GMSMapViewDelegate> @end @implementation POI - (void)loadView { GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:47.603 longitude:-122.331 zoom:14]; GMSMapView *mapView = [GMSMapView mapWithFrame:CGRectZero camera:camera]; mapView.delegate = self; self.view = mapView; } #pragma mark - GMSMapViewDelegate - (void)mapView:(GMSMapView *)mapView didTapPOIWithPlaceID:(NSString *)placeID name:(NSString *)name location:(CLLocationCoordinate2D)location { NSLog(@"You tapped %@: %@, %f/%f", name, placeID, location.latitude, location.longitude); } @end
Отображение подробностей в информационном окне
POI отображаются на карте по умолчанию, но пользовательский интерфейс по умолчанию отсутствует (API не отображает автоматически информационное окно или любой другой пользовательский интерфейс, когда пользователь касается POI). В следующем примере показано, как использовать маркер для отображения информационного окна для POI:
Быстрый
// Declare GMSMarker instance at the class level. let infoMarker = GMSMarker() // Attach an info window to the POI using the GMSMarker. func mapView( _ mapView: GMSMapView, didTapPOIWithPlaceID placeID: String, name: String, location: CLLocationCoordinate2D ) { infoMarker.snippet = placeID infoMarker.position = location infoMarker.title = name infoMarker.opacity = 0; infoMarker.infoWindowAnchor.y = 1 infoMarker.map = mapView mapView.selectedMarker = infoMarker }
Цель-C
// Declare a GMSMarker instance at the class level. GMSMarker *infoMarker; // Attach an info window to the POI using the GMSMarker. - (void)mapView:(GMSMapView *)mapView didTapPOIWithPlaceID:(NSString *)placeID name:(NSString *)name location:(CLLocationCoordinate2D)location { infoMarker = [GMSMarker markerWithPosition:location]; infoMarker.snippet = placeID; infoMarker.title = name; infoMarker.opacity = 0; CGPoint pos = infoMarker.infoWindowAnchor; pos.y = 1; infoMarker.infoWindowAnchor = pos; infoMarker.map = mapView; mapView.selectedMarker = infoMarker; }
Отключение отображения POI на карте
Вы можете скрыть POI, применив собственные стили ко всем POI или к определенным категориям POI.
Следующее объявление в стиле JSON скрывает все бизнес-POI на карте:
[
{
"featureType": "poi.business",
"stylers": [
{ "visibility": "off" }
]
}
]
Другой пример: следующий JSON упрощает отображение всех категорий POI:
[
{
"featureType": "poi",
"stylers": [
{ "visibility": "simplified" }
]
}
]
Более подробную информацию см. в руководстве по сокрытию объектов карты с помощью стилей .