İşletmeler ve diğer önemli yerler

Platform seçin: Android iOS JavaScript

Varsayılan olarak, önemli yerler (ÖY'ler) temel haritada karşılık gelen simgeleriyle birlikte görünür. ÖY'ler arasında parklar, okullar, hükümet binaları ve daha fazlası yer alır. Ayrıca, harita türü kGMSTypeNormal olduğunda haritada varsayılan olarak işletme ÖY'leri görünür. Ticari önemli noktalar; mağazalar, restoranlar, oteller vb. işletmeleri temsil eder.

ÖY, iOS için Yerler SDK'sında tanımlandığı gibi bir Yer Kimliği'ne karşılık gelir. Örneğin, eğlence parkları ÖY'dir, ancak su çeşmeleri gibi şeyler genellikle ÖY' değildir (ulusal veya tarihi bir önem taşımadıkları sürece).

ÖY'lerdeki tıklama etkinliklerini dinleme

ÖY'ye dokunan bir kullanıcıya yanıt vermek istiyorsanız GMSMapViewDelegate yöntemini uygulayın ve aşağıdaki örnekte gösterildiği gibi mapView(_:didTapPOIWithPlaceID:name:location:) yöntemini uygulayın:

Swift

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
      

Ayrıntılar bir bilgi penceresinde gösteriliyor

ÖY'ler haritada varsayılan olarak görünür ancak varsayılan olarak tıklanan kullanıcı arayüzü yoktur (Kullanıcı bir ÖY'ye dokunduğunda API, bilgi penceresini veya başka bir kullanıcı arayüzünü otomatik olarak göstermez). Aşağıdaki örnekte bir ÖY için bilgi penceresini görüntülemek üzere işaretçinin nasıl kullanılacağı gösterilmektedir:

Swift

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

ÖY'lerin haritada gösterilmesi durduruluyor

Tüm ÖY'lere veya belirli ÖY kategorilerine özel stiller uygulayarak ÖY'leri gizleyebilirsiniz.

Aşağıdaki JSON stil bildirimi, haritada işle ilgili tüm ÖY'leri gizler:

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

Başka bir örnek olarak, aşağıdaki JSON tüm ÖY kategorilerinin görüntülenmesini basitleştirir:

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

Daha ayrıntılı bilgi için stil özelliklerini kullanarak harita özelliklerini gizleme rehberine bakın.