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

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

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

Объект интереса (POI) соответствует идентификатору места (Place ID ), как определено в SDK Places для iOS. Например, парки отдыха являются объектами интереса, но такие объекты, как фонтаны, как правило, не являются объектами интереса (если только они не имеют национального или исторического значения).

Отслеживание кликов по точкам интереса

Если вы хотите реагировать на нажатие пользователем точки интереса (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
      

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

Точки интереса (POI) отображаются на карте по умолчанию, но отсутствует стандартный интерфейс по клику (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;
}
      

Предотвращение отображения точек интереса на карте

Вы можете скрыть объекты интереса, применив пользовательские стили ко всем объектам интереса или к определенным категориям объектов интереса.

Следующее объявление в формате JSON скрывает все объекты интереса (POI) на карте:

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

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

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

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