マーカー イベントと操作

高度なマーカーの特定のプロパティを設定すると、マーカー イベントをモニタリングできます たとえば、タップや操作などです。 マーカーをタップすると、マーカーのタイトルなどの追加情報が表示されます。 記述できます長押し操作でドラッグ可能なマーカーを移動することもできます。

  • マーカー イベントをトラッキングするには、GMSMapViewDelegate を を view に追加します。
  • マーカーをドラッグ可能にするには、 GMSMarker.draggable プロパティ。
  • マーカーの説明テキストを設定するには、 GMSMarker.title プロパティ。

マーカー イベントに応答する

マーカー イベントに応答するには、 GMSMapViewDelegate プロトコルをビューと 対応するコールバックを実装します。この例では、title と 選択したマーカーの snippet

Swift

// MARK: GMSMapViewDelegate

func mapView(_ mapView: GMSMapView, didTap marker: GMSMarker) -> Bool {
  if let title = marker.title {
    if let snippet = marker.snippet {
      print("marker title: \(title): snippet: \(snippet)")
    }
  }
  return true
}

Objective-C

// MARK: GMSMapViewDelegate

-   (BOOL)mapView:(GMSMapView *)mapView didTapMarker:(GMSMarker *)marker {
  if (marker.title && marker.snippet) {
    NSLog(@"marker with title:%@ snippet: %@", marker.title,  marker.snippet)
  }
  return YES;
}

地図のズームレベルに応じたマーカーの可視性を制御する

GMSMarker の公開設定を制御するには、以下を実装します。 GMSMapViewDelegate プロトコルを使用し、設定する条件を追加します。 GMSMarker.map

Swift

// MARK: GMSMapViewDelegate

func mapView(_ mapView: GMSMapView, didChange position: GMSCameraPosition) {
    marker.map = position.zoom >= 14 ? mapView : nil
}

Objective-C

// MARK: GMSMapViewDelegate

-   (void)mapView:(GMSMapView *)mapView didChangeCameraPosition:(GMSCameraPosition *)position {
  marker.map = position.zoom >= 14 ? mapView : nil;
}

マーカーをドラッグ可能にする

draggable プロパティを有効にすると、ユーザーは 長押しします。マーカーをドラッグ可能にするには、GMSMarker.draggable プロパティを true に設定します。

Swift

marker.draggable = true

Objective-C

marker.draggable = YES;