Eventos e gestos de marcador

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

Responder a eventos de marcadores

É possível responder a eventos de marcador adicionando o protocolo GMSMapViewDelegate à sua visualização e implementando 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 pressionar e manter. Para tornar um marcador arrastável, defina a propriedade GMSMarker.draggable como verdadeira.

Swift

marker.draggable = true

Objective-C

marker.draggable = YES;