Firmy i inne ciekawe miejsca

Wybierz platformę: Android iOS JavaScript

Domyślnie ciekawe miejsca (POI) są wyświetlane na mapie podstawowej wraz z odpowiadającymi im ikonami. Ważne miejsca to parki, szkoły, budynki rządowe i wiele innych. Jeśli typ mapy to kGMSTypeNormal, ważne miejsca firmowe są domyślnie wyświetlane na mapie. Ważne miejsca biznesowe to m.in. sklepy, restauracje i hotele.

Ciekawe miejsce odpowiada identyfikatorowi miejsca zdefiniowanemu w pakiecie Places SDK na iOS. Np. parki rekreacyjne to ważne miejsca, ale takie obiekty jak fontanny wodne zwykle nie są ważnym miejscem (chyba że mają znaczenie narodowe lub historyczne).

Wykrywa zdarzenia kliknięcia ważnych miejsc

Jeśli chcesz odpowiedzieć, gdy użytkownik kliknie ważne miejsce, zaimplementuj GMSMapViewDelegate i zaimplementuj metodę mapView(_:didTapPOIWithPlaceID:name:location:), jak 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świetlam szczegóły w oknie informacyjnym

Ważne miejsca są domyślnie wyświetlane na mapie, ale po kliknięciu ciekawego miejsca interfejs API nie wyświetla automatycznie okna informacyjnego ani żadnego innego interfejsu. Z przykładu poniżej dowiesz się, jak za pomocą znacznika wyświetlić okno informacyjne dla ciekawego 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;
}
      

Wyłączanie wyświetlania ważnych miejsc na mapie

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

Poniższa deklaracja stylu JSON ukrywa wszystkie ważne miejsca biznesowe na mapie:

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

Innym przykładem jest ten JSON, aby uprościć wyświetlanie wszystkich kategorii ważnych miejsc:

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

Więcej informacji znajdziesz w przewodniku o ukrywaniu funkcji mapy za pomocą stylu.