Организации и объекты инфраструктуры

Выберите платформу: Android iOS JavaScript

По умолчанию точки интереса (POI) отображаются на базовой карте вместе с соответствующими значками. К ним относятся парки, школы, правительственные здания и многое другое. Кроме того, коммерческие POI отображаются на карте по умолчанию, если выбран тип карты kGMSTypeNormal . Коммерческие POI представляют такие предприятия, как магазины, рестораны, отели и т. д.

POI соответствует идентификатору места (Place ID) , как определено в Places SDK для iOS. Например, парки отдыха являются 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)")
  }
}
      

Objective-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
      

Отображение подробностей в информационном окне

Достопримечательности отображаются на карте по умолчанию, но стандартный пользовательский интерфейс, активируемый при нажатии, отсутствует (API не отображает автоматически информационное окно или другой пользовательский интерфейс при нажатии пользователем на достопримечательность). В следующем примере показано, как использовать маркер для отображения информационного окна для достопримечательности:

Быстрый

// 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
}
      

Objective-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.

Следующее объявление в стиле JSON скрывает все бизнес-объекты POI на карте:

[
  {
    "featureType": "poi.business",
    "stylers": [
      { "visibility": "off" }
    ]
  }
]

В качестве другого примера, следующий JSON упрощает отображение всех категорий POI:

[
  {
    "featureType": "poi",
    "stylers": [
      { "visibility": "simplified" }
    ]
  }
]

Более подробную информацию см. в руководстве по скрытию объектов карты с помощью стилей .