I have been working and testing on background location updates using GoogleApiClient
for Interval and Displacement based updates. On testing and analyzing for a few days I figured out some variations in the output which I did not expect.
While using setInterval
and setFastestInterval
for Interval based updates, say I have set an Interval as 15 mins and Fastest Interval as 10 mins, 90% of the time I am getting updates in the expected Interval (10 to 15 mins). But sometimes I noticed that the updates take much longer time than the specified Interval, like, the difference is around 30 mins and 60 mins. Any Idea about why is the difference?
While using setMinimumDisplacement
for Distance based updates, say I have set a Displacement as 200 meters, I am getting updates only on stationary points(While travelling it doesn't give updates even if it is more than 200 meters) which are 200 meters and above. Is this how it works normally?
I am using PendingIntent
type of location requests in order to receive location updates in BroadcastReceiver
for location updates in background.
fusedLocationProviderClient.requestLocationUpdates(locationRequest, pendingIntent);
While testing, the Location Services were ON and Location Mode was HIGH_ACCURACY.
Accuracy of defined location varies based on number of visible satellites, device hardware and environment. Usually it's about 3m in case if there are no high buildings or metallic structures (hiding satellites from your device sight) around.
Once a location request is in place you can start the regular updates by calling requestLocationUpdates() .
Allow only while using the app This option is the recommended option for most apps. Also known as "while-in-use" or "foreground only" access, this option was added in Android 10 and allows developers to retrieve location only while the app is actively being used.
The fused location provider manages the underlying location technologies, such as GPS and Wi-Fi, and provides a simple API that you can use to specify the required quality of service. For example, you can request the most accurate data available, or the best accuracy possible with no additional power consumption.
Please refer to the documentation to get the proper behavior of LocationRequest API.
LocationRequest Api documentation
From this documentation:
LocationClient
. In fact, the system may have multiple location sources (providers) running and may fuse the results from several sources into a single Location objectACCESS_COARSE_LOCATION
and not ACCESS_FINE_LOCATION
will be automatically throttled to a slower interval, and the location object will be obfuscated to only show a coarse level of accuracy.For more detail description read full documentation from above link.
Hope this explanation may help you.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With