Firmy i inne ciekawe miejsca

Wybierz platformę: Android iOS JavaScript

Domyślnie na mapie podstawowej wyświetlają się ważne miejsca (POI) wraz z odpowiadającymi im ikonami. Ważne miejsca obejmują parki, szkoły, budynki rządowe i inne. Dodatkowo ważne miejsca firmowe domyślnie wyświetlają się na mapie, gdy jej typ to kGMSTypeNormal. Firmowe ważne miejsca reprezentują firmy, takie jak sklepy, restauracje, hotele itp.

Ważne miejsce odpowiada identyfikatorowi miejsca zdefiniowanemu w pakiecie SDK Miejsc na iOS. Na przykład parki rekreacyjne są ważnymi miejscami, ale takie obiekty jak fontanny zwykle nie są (chyba że mają znaczenie historyczne lub narodowe).

Nasłuchiwanie zdarzeń kliknięcia ważnych miejsc

Jeśli chcesz reagować na kliknięcia użytkownika w ważne miejsce, zaimplementuj GMSMapViewDelegate, i zaimplementuj metodę mapView(_:didTapPOIWithPlaceID:name:location:), jak pokazano w tym przykładzie:

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
      

Wyświetlanie szczegółów w oknie informacyjnym

Ważne miejsca domyślnie wyświetlają się na mapie, ale nie ma domyślnego interfejsu kliknięcia (API nie wyświetla automatycznie okna informacyjnego ani żadnego innego interfejsu, gdy użytkownik kliknie ważne miejsce). Poniższy przykład pokazuje, jak użyć znacznika do wyświetlania okna informacyjnego dla ważnego miejsca:

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

Blokowanie wyświetlania ważnych miejsc na mapie

Możesz ukryć ważne miejsca, stosując style niestandardowe do wszystkich ważnych miejsc lub do określonych kategorii ważnych miejsc.

Ta deklaracja stylu JSON ukrywa wszystkie firmowe ważne miejsca na mapie:

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

Inny przykład: ten kod JSON upraszcza wyświetlanie wszystkich kategorii ważnych miejsc:

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

Więcej informacji znajdziesz w przewodniku po ukrywaniu elementów mapy za pomocą stylów.