我正在使用Eclipse3.5开发一个映射应用程序。
我正在通过配置活动使用LocationManager的requestLocationUpdates方法设置最小更新周期。当我设置属性时,我在Logcat中看到系统进程将值设置为OK。
当我从DDMS emulator控件实际发送一个新位置并且在地图视图上的位置发生更改时,我看到系统进程随后将最小时间设置为零。
下面是系统日志消息的捕获。你可以看到我把周期设置为32秒,然后是16秒,然后,在我发送了一个模拟位置更改后,系统将其设置为零
地图会立即响应位置的变化,即使它们之间只有几秒钟的间隔。
有人知道为什么我的最短时间被系统覆盖了吗?
10-26 22:21:09.770: DEBUG/GpsLocationProvider(54): setMinTime 32000
10-26 22:21:53.011: DEBUG/GpsLocationProvider(54): stopNavigating
10-26 22:21:57.810: DEBUG/GpsLocationProvider(54): setMinTime 16000
10-26 22:21:57.810: DEBUG/GpsLocationProvider(54): startNavigating
10-26 22:21:57.900: DEBUG/GpsLocationProvider(54): setMinTime 16000
10-26 22:22:39.099: DEBUG/GpsLocationProvider(54): TTFF: 41290
10-26 22:22:39.350: DEBUG/GpsLocationProvider(54): setMinTime 0
10-26 22:22:51.740: DEBUG/GpsLocationProvider(54): TTFF: 53925
10-26 22:22:51.820: DEBUG/GpsLocationProvider(54): setMinTime 0
10-26 22:22:56.780: DEBUG/GpsLocationProvider(54): TTFF: 58967
10-26 22:22:56.879: DEBUG/GpsLocationProvider(54): setMinTime 0
相关代码,下面,在onResume()中调用enableGPS()
private void enableGPS() {
if (confData.getTrackMode() == AppConstants.GPS_ON) {
if (lm == null)
lm = (LocationManager) getSystemService(LOCATION_SERVICE);
long updateMillis = confData.getMapUpdatePeriod() * 1000;
lm.requestLocationUpdates(LocationManager.GPS_PROVIDER,
updateMillis, confData.getMapMinResendDistance(), this);
}
}
而听众是
public void onLocationChanged(Location location) {
List<Overlay> overlays = mv.getOverlays();
lo = new MyLocationOverlay(this, mv);
overlays.add(lo);
lo.enableMyLocation();
int lat = (int) (location.getLatitude() * 1E6);
int lng = (int) (location.getLongitude() * 1E6);
GeoPoint point = new GeoPoint(lat, lng);
mc.setCenter(point);
mv.invalidate();
}