Vermeiden Sie die Verwendung von Aktivitätsimplementen für OnMarkerClickListener. Verwenden Sie einen lokalen OnMarkerClickListener
// Not a good idea
class MapActivity extends Activity implements OnMarkerClickListener {
}
Sie benötigen eine Karte, um das mit der Markierung verknüpfte Originaldatenmodell nachzuschlagen
private Map<Marker, Map<String, Object>> markers = new HashMap<>();
Sie benötigen ein Datenmodell
private Map<String, Object> dataModel = new HashMap<>();
Fügen Sie einige Daten in das Datenmodell ein
dataModel.put("title", "My Spot");
dataModel.put("snipet", "This is my spot!");
dataModel.put("latitude", 20.0f);
dataModel.put("longitude", 100.0f);
Wenn Sie einen neuen Marker mithilfe eines Datenmodells erstellen, fügen Sie beide zur Maker-Map hinzu
Marker marker = googleMap.addMarker(markerOptions);
markers.put(marker, dataModel);
Verwenden Sie für ein On-Click-Marker-Ereignis einen lokalen OnMarkerClickListener:
@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();
}
Um das Infofenster anzuzeigen, rufen Sie das ursprüngliche Datenmodell von der Markierungskarte ab:
@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);
}
});