嗨所以我正在使用Geofire,每当我在查询范围内的某个对象时,我试图使用标记在用户地图上显示它并实时更新标记位置。
我在geofire onkeyentered方法中初始化标记,然后当键的位置发生变化时(因此onkeymoved被调用),我使用marker.setposition更改标记的位置。但是,标记会在原始位置创建它的副本,然后移动(创建2个标记,即使我只使用了setPosition)
以下是地理位置监听器的代码:
geoQueryP.addGeoQueryEventListener(new GeoQueryEventListener() {
@Override
public void onKeyEntered(String key, GeoLocation location) {
LatLng drivLoc = new LatLng(location.latitude, location.longitude);
createDriverMarker(key, drivLoc, reference);
}
@Override
public void onKeyExited(String key) {
if(markerPoints.get(key) != null) {
markerPoints.get(key).remove();
markerPoints.remove(key);
}
}
@Override
public void onKeyMoved(String key, GeoLocation location) {
if(markerPoints.get(key) != null) {
markerPoints.get(key).setPosition(new LatLng(location.latitude, location.longitude));
}
}
@Override
public void onGeoQueryReady() {
}
@Override
public void onGeoQueryError(DatabaseError error) {
Toast.makeText(getApplicationContext(), error + " Please Try Again", Toast.LENGTH_LONG).show();
}
});
以下是createDriverMarker方法的代码:
private void createDriverMarker(String key, LatLng drivLocation, String reference) {
MarkerOptions markerOptions = new MarkerOptions();
locationRelatedFunctions bitmap = new locationRelatedFunctions();
markerOptions.position(drivLocation)
.title(reference)
.icon((bitmap.bitmapDescriptorFromVector(getApplicationContext(), R.drawable.ic_radio_button_checked_black_24dp)));
Marker marker = mMap.addMarker(markerOptions);
markerPoints.put(key, marker);
}
MarkerPoints是一个hashmap,初始化如下:
public HashMap<String, Marker> markerPoints;
然后在onCreate:
markerPoints = new HashMap<String, Marker>();
答案 0 :(得分:0)
怀疑onKeyEntered
被调用的次数超出预期 - 但可以纠正:
public void onKeyEntered(String key, GeoLocation location) {
LatLng drivLoc = new LatLng(location.latitude, location.longitude);
if (!markerPoints.containsKey(key)) {
createDriverMarker(key, drivLoc, reference);
} else {
// this part is optional given that the 'moved' event may have
// triggered first...
onKeyMoved(key,location);
}
}
您可能需要添加调试以确认额外的onKeyEntered调用。
OP代码中的一个缺陷是沿着相同的行 - 如果onKeyEntered被调用两次同一个键,你将最终得到2个标记 - 一个非托管,因为同一个键的第二个“put”覆盖了第一个但将原始标记留在地图上。原则上,您的代码应该可以工作 - 但是您仍然应该防范意外的事件序列。
更完整的分析需要您发布如何使用位置更新来更新GeoFire。