İşletmeler ve diğer önemli yerler

Platform seçin: Android iOS JavaScript

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

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

İÇY’lerde tıklama etkinliklerini dinleme

Bir ÖY'ye dokunan kullanıcıya yanıt vermek istiyorsanız aşağıdaki örnekte gösterildiği gibi GMSMapViewDelegate ve 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
      

Bir bilgi penceresinde ayrıntıları gösterme

ÖY'ler varsayılan olarak haritada görünür, ancak varsayılan tıklama kullanıcı arayüzü yoktur (API, kullanıcı bir ÖY'ye dokunduğunda otomatik olarak bir bilgi penceresi veya başka bir kullanıcı arayüzü görüntülemez). Aşağıdaki örnekte, bir ÖY ile ilgili bilgi penceresini görüntülemek için 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österilmesini durdurma

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

Aşağıdaki JSON stil bildirimi, haritadaki tüm işletme ÖY'lerini gizler:

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

Başka bir örnek olarak, aşağıdaki JSON tüm ÖY kategorilerini daha basit bir şekilde gösterir:

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

Daha ayrıntılı bilgi için stil içeren harita özelliklerini gizleme kılavuzuna bakın.