Firmy i inne ciekawe miejsca

Wybierz platformę: Android iOS JavaScript

Domyślnie ciekawe miejsca (POI) wyświetlają się na mapie podstawowej wraz z odpowiednimi ikonami. Ciekawe miejsca to m.in. parki, szkoły, budynki administracyjne. Ponadto punkty firmowe są domyślnie widoczne na mapie, gdy jej typ to kGMSTypeNormal. Obiekty firmowe to firmy takie jak sklepy, restauracje, hotele itp.

Punkt zainteresowania odpowiada identyfikatorowi miejsca zdefiniowanemu w pakiecie SDK Miejsc na iOS. Na przykład parki rekreacyjne są punktami orientacyjnymi, ale takie obiekty jak fontanny nie są zwykle punktami orientacyjnymi (chyba że mają znaczenie narodowe lub historyczne).

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

Jeśli chcesz zareagować na kliknięcie przez użytkownika punktu POI, wdrożyć metodę GMSMapViewDelegate i wdrożyć 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 z informacjami

Miejsca docelowe są domyślnie wyświetlane na mapie, ale nie ma domyślnego interfejsu po kliknięciu (interfejs API nie wyświetla automatycznie okna z informacjami ani żadnego innego interfejsu, gdy użytkownik kliknie miejsce docelowe). Ten przykład pokazuje, jak za pomocą znacznika wyświetlić okno informacyjne punktu zainteresowania:

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

Wyłączanie wyświetlania punktów POI na mapie

Możesz ukryć punkty zainteresowania, stosując niestandardowe style do wszystkich punktów zainteresowania lub do określonych kategorii punktów zainteresowania.

Poniższa deklaracja stylu JSON powoduje ukrycie na mapie wszystkich punktów zainteresowania związanych z firmą:

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

Ten kod JSON upraszcza wyświetlanie wszystkich kategorii punktów zainteresowania:

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

Więcej informacji znajdziesz w przewodniku Ukrywanie elementów mapy za pomocą stylizacji.