マーカー イベントと操作

特定の高度なマーカー プロパティが設定されている場合、タップや操作などのマーカー イベントをモニタリングできます。マーカーをタップすると、マーカーのタイトルやスニペットなどの追加情報が表示されます。長押しのジェスチャーを使用して、ドラッグ可能なマーカーを移動することもできます。

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

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

マーカー イベントに応答するには、GMSMapViewDelegate プロトコルをビューに追加し、対応するコールバックを実装します。この例では、選択されたマーカーの titlesnippet を識別しています。

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;