Evite usar los implementos de actividad OnMarkerClickListener, use un OnMarkerClickListener local
// Not a good idea
class MapActivity extends Activity implements OnMarkerClickListener {
}
Necesitará un mapa para buscar el modelo de datos original vinculado al marcador
private Map<Marker, Map<String, Object>> markers = new HashMap<>();
Necesitará un modelo de datos.
private Map<String, Object> dataModel = new HashMap<>();
Poner algunos datos en el modelo de datos
dataModel.put("title", "My Spot");
dataModel.put("snipet", "This is my spot!");
dataModel.put("latitude", 20.0f);
dataModel.put("longitude", 100.0f);
Al crear un nuevo marcador con un modelo de datos, agregue ambos al mapa del creador
Marker marker = googleMap.addMarker(markerOptions);
markers.put(marker, dataModel);
Para el evento de marcador al hacer clic, use un OnMarkerClickListener local:
@Override
public void onMapReady(GoogleMap googleMap) {
// grab for laters
this.googleMap = googleMap;
googleMap.setOnMarkerClickListener(new GoogleMap.OnMarkerClickListener() {
@Override
public boolean onMarkerClick(Marker marker) {
Map dataModel = (Map)markers.get(marker);
String title = (String)dataModel.get("title");
markerOnClick(title);
return false;
}
});
mapView.onResume();
showMarkers();
ZoomAsync zoomAsync = new ZoomAsync();
zoomAsync.execute();
}
Para mostrar la ventana de información, recupere el modelo de datos original del mapa de marcadores:
@Override
public void onMapReady(GoogleMap googleMap) {
this.googleMap = googleMap;
googleMap.setOnInfoWindowClickListener(new GoogleMap.OnInfoWindowClickListener() {
@Override
public void onInfoWindowClick(Marker marker) {
Map dataModel = (Map)markers.get(marker);
String title = (String)dataModel.get("title");
infoWindowOnClick(title);
}
});