İşletmeler ve diğer önemli yerler

Platform seçin: Android iOS JavaScript

İlgi çekici yerler (ÖY), varsayılan olarak temel haritada ilgili simgeleriyle birlikte görünür. Önemli yerler arasında parklar, okullar, resmi binalar ve daha fazlası yer alır. Ayrıca, harita türü kGMSTypeNormal olduğunda ÖY'leri varsayılan olarak haritada görünür. İşletme ÖY'leri; mağazalar, restoranlar, oteller gibi işletmeleri temsil eder.

ÖY, iOS için Yerler SDK'sında tanımlandığı şekilde bir yer kimliğine karşılık gelir. Örneğin, rekreasyon parkları ÖY'dir ancak çeşmeler gibi öğeler genellikle ÖY değildir (ulusal veya tarihi öneme sahip olmadıkları sürece).

Önemli yerlerde tıklama etkinliklerini dinleme

Bir kullanıcının ÖY'ye dokunmasına yanıt vermek istiyorsanız GMSMapViewDelegate ve mapView(_:didTapPOIWithPlaceID:name:location:) yöntemini aşağıdaki örnekte gösterildiği gibi 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ı bilgi penceresinde gösterme

Önemli yerler varsayılan olarak haritada görünür ancak tıklamayla açılan varsayılan bir kullanıcı arayüzü yoktur (API, kullanıcı bir ÖY'ye dokunduğunda otomatik olarak bilgi penceresi veya başka bir kullanıcı arayüzü göstermez). Aşağıdaki örnekte, bir ÖY için bilgi penceresi görüntülemek üzere işaretçi 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;
}
      

Önemli yerleri haritada göstermeyi durdurma

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

Aşağıdaki JSON stili beyanı, haritada tüm işletme ÖY'lerini gizler:

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

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

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

Daha fazla bilgi için stil kullanarak harita özelliklerini gizleme başlıklı makaleyi inceleyin.