Уникайте використання інструментів діяльності OnMarkerClickListener, використовуйте локальний OnMarkerClickListener
// Not a good idea
class MapActivity extends Activity implements OnMarkerClickListener {
}
Вам знадобиться карта для пошуку оригінальної моделі даних, пов’язаної з маркером
private Map<Marker, Map<String, Object>> markers = new HashMap<>();
Вам знадобиться модель даних
private Map<String, Object> dataModel = new HashMap<>();
Покладіть деякі дані в модель даних
dataModel.put("title", "My Spot");
dataModel.put("snipet", "This is my spot!");
dataModel.put("latitude", 20.0f);
dataModel.put("longitude", 100.0f);
Створюючи новий маркер за допомогою моделі даних, додайте обидва на карту виробника
Marker marker = googleMap.addMarker(markerOptions);
markers.put(marker, dataModel);
Для події маркера натискань використовуйте локальний 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();
}
Для відображення інформаційного вікна витягніть оригінальну модель даних з карти маркера:
@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);
}
});