如何强制FusedLocationProviderClient明确要求新位置?
几个月前,我升级了FusedLocationProviderClient。从那时起,要求对新地点进行采样将不会提供新的地点。
// Request a single location.
// Note: FusedLocationProviderClient.lastLocation
// is no better
val request = LocationRequest()
.setNumUpdates(1)
.setExpirationDuration(0)
.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY)
.setMaxWaitTime(10*DateUtils.SECOND_IN_MILLIS)
.setFastestInterval(0)
fusedLocationClient?.requestLocationUpdates(request, object:LocationCallback() {
override fun onLocationResult(result: LocationResult?) {
super.onLocationResult(result)
Log.v(LOG_TAG, "Single fused location request yields ${result?.lastLocation} ")
callOnDone(result?.lastLocation)
}
}, Looper.getMainLooper())
当我获得请求位置时,即使相隔几秒钟,它也会获得具有相同时间戳的相同位置。
我使用带有GPX录音功能的模拟器,因此GPS读数始终可用。
但是,当我尝试从位置管理器请求位置时(并且对结果不做任何操作),它的效果会更好。
(context?.getSystemService(Context.LOCATION_SERVICE) as? LocationManager)?
.requestSingleUpdate(
LocationManager.GPS_PROVIDER,
object :LocationListener{...dummy, just log the callback...},
Looper.getMainLooper())
结论:即使在高优先级模式下,FusedLocationProviderClient也不会从操作系统请求新位置。但是,如果可以从外部获得新位置,它确实接受新位置。
问题是:当我现在需要新的位置时,如何强制 FusedLocationProviderClient主动请求新位置?
答案 0 :(得分:0)
这个问题已经很老了,但是我来到这里的时候也遇到了类似的问题,在过去的几个月中,我看到另外65个问题。以下代码有效。它提供一个位置 到onLocationResult回调,位于locationResult.getLastLocation():
public void getNewLocation() {
LocationRequest locationRequest = new LocationRequest()
.setNumUpdates(1)
.setFastestInterval(0)
.setSmallestDisplacement(0)
.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);
if (ActivityCompat.checkSelfPermission(context,
Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED
&& ActivityCompat.checkSelfPermission(context,
Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
return;
}
fusedLocationProviderClient.requestLocationUpdates(locationRequest,
new com.google.android.gms.location.LocationCallback() {
@Override
public void onLocationResult(LocationResult locationResult) {
locationListener.onLocationChanged(locationResult.getLastLocation());
}
},
Looper.getMainLooper());
}
这里的区别是我删除了setMaxWaitTime和setExpirationDuration。显然他们打断了电话。如果我解释 setExpirationDuration正确,这意味着该请求应在 x毫秒将其设置为零意味着请求立即过期,因此当某个位置确实可用时,该请求已经过期。 因此,没有回调到onLocationChanged。
我希望这对某人有帮助。