Unternehmen und andere POIs

Plattform auswählen: Android iOS JavaScript

Standardmäßig werden Points of Interest (POIs) zusammen mit den entsprechenden Symbolen auf der Basiskarte dargestellt. POIs sind beispielsweise Parks, Schulen und Behördengebäude. Darüber hinaus werden Unternehmens-POIs standardmäßig auf der Karte angezeigt, wenn der Kartentyp kGMSTypeNormal ist. Unternehmens-POIs sind beispielsweise Geschäfte, Restaurants und Hotels.

Ein POI entspricht einer Orts-ID gemäß der Definition im Places SDK for iOS. So sind beispielsweise der Erholung dienende Parks POIs, Objekte wie Springbrunnen hingegen nicht (es sei denn, sie sind von nationaler oder historischer Bedeutung).

Auf Klickereignisse für POIs warten

Wenn du möchtest, dass nach dem Tippen eines Nutzers auf einen POI eine Reaktion erfolgt, musst du GMSMapViewDelegate und die Methode mapView(_:didTapPOIWithPlaceID:name:location:) implementieren, wie im folgenden Beispiel gezeigt:

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
      

Details in einem Infofenster anzeigen

POIs erscheinen standardmäßig auf der Karte. Beim Anklicken wird jedoch keine standardmäßige UI angezeigt. Das heißt, über die API wird nicht automatisch ein Infofenster oder ein anderes UI-Element dargestellt, wenn der Nutzer auf einen POI tippt. Im folgenden Beispiel wird gezeigt, wie Sie mit einer Markierung ein Infofenster für einen POI anzeigen:

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

POIs nicht mehr auf der Karte anzeigen

Sie können POIs ausblenden, indem Sie benutzerdefinierte Formate auf alle POIs oder auf bestimmte POI-Kategorien anwenden.

Mit der folgenden JSON-Stildeklaration werden alle Unternehmens-POIs auf der Karte ausgeblendet:

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

Als weiteres Beispiel vereinfacht die folgende Deklaration die Darstellung aller POI-Kategorien:

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

Weitere Informationen finden Sie in der Anleitung Kartenelemente mit Stilen ausblenden.