Eventos e gestos de marcador

Quando propriedades avançadas específicas são definidas, é possível monitorar eventos de marcadores, como toques e gestos. Se um marcador for tocado, será possível ver informações adicionais, como um título ou snippet. Também é possível mover marcadores arrastáveis usando um gesto de toque longo.

Responder a eventos de marcadores

Para responder a eventos de marcador, adicione o protocolo GMSMapViewDelegate à sua visualização e implemente o callback correspondente. Este exemplo identifica o title e o snippet de um marcador selecionado.

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

Controlar a visibilidade do marcador por nível de zoom do mapa

Para controlar a visibilidade de GMSMarker, implemente o protocolo GMSMapViewDelegate e adicione uma condição para definir 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;
}

Tornar um marcador arrastável

Quando você ativa a propriedade draggable, os usuários podem arrastar marcadores no mapa com um gesto de toque longo. Para tornar um marcador arrastável, defina a propriedade GMSMarker.draggable como verdadeira.

Swift

marker.draggable = true

Objective-C

marker.draggable = YES;