java.lang.Object | |
↳ | com.google.android.gms.location.LocationRequest |
A data object that contains quality of service parameters for requests to
the FusedLocationProviderApi
.
LocationRequest objects are used to request a quality of service for location updates from
the FusedLocationProviderApi
.
For example, if your application wants high accuracy location it should create a location
request with setPriority(int)
set to PRIORITY_HIGH_ACCURACY
and
setInterval(long)
to 5 seconds. This would be appropriate for mapping applications that are
showing your location in real-time.
At the other extreme, if you want negligible power impact, but to still receive location
updates when available, then create a location request with setPriority(int)
set to
PRIORITY_NO_POWER
. With this request your application will not trigger (and therefore
will not receive any power blame) any location updates, but will receive locations triggered by
other applications. This would be appropriate for applications that have no firm requirement
for location, but can take advantage when available.
In between these two extremes is a very common use-case, where applications definitely want
to receive updates at a specified interval, and can receive them faster when available, but
still want a low power impact. These applications should consider
PRIORITY_BALANCED_POWER_ACCURACY
combined with a faster
setFastestInterval(long)
(such as 1 minute) and a slower setInterval(long)
(such as 60 minutes). They will only be assigned power blame for the interval set by
setInterval(long)
, but can still receive locations triggered by other applications at a rate
up to setFastestInterval(long)
. This style of request is appropriate for many location aware
applications, including background usage. Do be careful to also throttle
setFastestInterval(long)
if you perform heavy-weight work after receiving an update - such
as using the network.
Activities should strongly consider removing all location request when entering
the background (for example at onPause()
), or at least swap the
request to a larger interval and lower quality.
Applications cannot specify the exact location sources, such as GPS, that are used by the LocationClient. In fact, the system may have multiple location sources (providers) running and may fuse the results from several sources into a single Location object.
Location requests from applications with
ACCESS_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.
All location requests are considered hints, and you may receive locations that are more/less accurate, and faster/slower than requested.
Constants | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
int | PRIORITY_BALANCED_POWER_ACCURACY |
Used with setPriority(int) to request "block" level accuracy.
|
|||||||||
int | PRIORITY_HIGH_ACCURACY |
Used with setPriority(int) to request the most accurate locations available.
|
|||||||||
int | PRIORITY_LOW_POWER |
Used with setPriority(int) to request "city" level accuracy.
|
|||||||||
int | PRIORITY_NO_POWER |
Used with setPriority(int) to request the best accuracy possible with zero additional
power consumption.
|
[Expand]
Inherited Constants | |||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
From interface
android.os.Parcelable
|
Fields | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
CREATOR |
Public Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Create a location request with default parameters.
| |||||||||||
Get the request expiration time, in milliseconds since boot.
| |||||||||||
Get the fastest interval of this request, in milliseconds.
| |||||||||||
Get the desired interval of this request, in milliseconds.
| |||||||||||
Gets the maximum wait time in milliseconds for location updates.
| |||||||||||
Get the number of updates requested.
| |||||||||||
Get the quality of the request.
| |||||||||||
Get the minimum displacement between location updates in meters
By default this is 0. | |||||||||||
Set the duration of this request, in milliseconds.
| |||||||||||
Set the request expiration time, in millisecond since boot.
| |||||||||||
Explicitly set the fastest interval for location updates, in milliseconds.
| |||||||||||
Set the desired interval for active location updates, in milliseconds.
| |||||||||||
Sets the maximum wait time in milliseconds for location updates.
| |||||||||||
Set the number of location updates.
| |||||||||||
Set the priority of the request.
| |||||||||||
Set the minimum displacement between location updates in meters
By default this is 0. | |||||||||||
[Expand]
Inherited Methods | |||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
From class
java.lang.Object
| |||||||||||||||||||||||||||||||||
From interface
android.os.Parcelable
|
Used with setPriority(int)
to request "block" level accuracy.
Block level accuracy is considered to be about 100 meter accuracy. Using a coarse accuracy such as this often consumes less power.
Used with setPriority(int)
to request the most accurate locations available.
This will return the finest location available.
Used with setPriority(int)
to request "city" level accuracy.
City level accuracy is considered to be about 10km accuracy. Using a coarse accuracy such as this often consumes less power.
Used with setPriority(int)
to request the best accuracy possible with zero additional
power consumption.
No locations will be returned unless a different client has requested location updates in which case this request will act as a passive listener to those locations.
Create a location request with default parameters.
Default parameters are for a block accuracy, slowly updated location. It can then be
adjusted as required by the applications before passing to the
FusedLocationProviderApi
.
Get the request expiration time, in milliseconds since boot.
This value can be compared to elapsedRealtime()
to determine the time
until expiration.
Get the fastest interval of this request, in milliseconds.
The system will never provide location updates faster than the minimum of
getFastestInterval()
and getInterval()
.
Get the desired interval of this request, in milliseconds.
Gets the maximum wait time in milliseconds for location updates. If the wait time
is smaller than the interval requested with setInterval(long)
, then the interval
will be used instead.
Get the number of updates requested.
By default this is MAX_VALUE
, which indicates that locations are updated
until the request is explicitly removed.
Get the quality of the request.
Get the minimum displacement between location updates in meters
By default this is 0.
Set the duration of this request, in milliseconds.
The duration begins immediately (and not when the request is passed to the location client), so call this method again if the request is re-used at a later time.
The location client will automatically stop updates after the request expires.
The duration includes suspend time. Values less than 0 are allowed, but indicate that the request has already expired.
millis | duration of request in milliseconds |
---|
Set the request expiration time, in millisecond since boot.
This expiration time uses the same time base as elapsedRealtime()
.
The location client will automatically stop updates after the request expires.
The duration includes suspend time. Values before elapsedRealtime()
are allowed, but indicate that the request has already expired.
millis | expiration time of request, in milliseconds since boot including suspend |
---|
Explicitly set the fastest interval for location updates, in milliseconds.
This controls the fastest rate at which your application will receive location updates,
which might be faster than setInterval(long)
in some situations (for example, if other
applications are triggering location updates).
This allows your application to passively acquire locations at a rate faster than it actively acquires locations, saving power.
Unlike setInterval(long)
, this parameter is exact. Your application will never
receive updates faster than this value.
If you don't call this method, a fastest interval will be selected for you. It will be
a value faster than your active interval (setInterval(long)
).
An interval of 0 is allowed, but not recommended, since location updates may be extremely fast on future implementations.
If setFastestInterval(long)
is set slower than setInterval(long)
, then your
effective fastest interval is setInterval(long)
.
millis | fastest interval for updates in milliseconds, exact |
---|
IllegalArgumentException | if the interval is less than zero |
---|
Set the desired interval for active location updates, in milliseconds.
The location client will actively try to obtain location updates for your application at this interval, so it has a direct influence on the amount of power used by your application. Choose your interval wisely.
This interval is inexact. You may not receive updates at all (if no location sources
are available), or you may receive them slower than requested. You may also receive them
faster than requested (if other applications are requesting location at a faster interval).
The fastest rate that you will receive updates can be controlled with
setFastestInterval(long)
. By default this fastest rate is 6x the interval frequency.
Applications with only the coarse location permission may have their interval silently throttled.
An interval of 0 is allowed, but not recommended, since location updates may be extremely fast on future implementations.
setPriority(int)
and setInterval(long)
are the most important parameters
on a location request.
millis | desired interval in millisecond, inexact |
---|
IllegalArgumentException | if the interval is less than zero |
---|
Sets the maximum wait time in milliseconds for location updates.
If you pass a value at least 2x larger than the interval specified with
setInterval(long)
, then location delivery may be delayed and multiple locations can
be delivered at once. Locations are determined at the setInterval(long)
rate, but can be
delivered in batch after the interval you set in this method. This can consume less battery
and give more accurate locations, depending on the device's hardware capabilities. You
should set this value to be as large as possible for your needs if you don't need
immediate location delivery.
millis | desired maximum wait time in millisecond, inexact |
---|
IllegalArgumentException | if the interval is less than zero |
---|
Set the number of location updates.
By default locations are continuously updated until the request is explicitly removed, however you can optionally request a set number of updates. For example, if your application only needs a single fresh location, then call this method with a value of 1 before passing the request to the location client.
When using this option care must be taken to either explicitly remove the request
when no longer needed or to set an expiration with (setExpirationDuration(long)
or
setExpirationTime(long)
. Otherwise in some cases if a location can't be computed, this
request could stay active indefinitely consuming power.
numUpdates | the number of location updates requested |
---|
IllegalArgumentException | if numUpdates is 0 or less |
---|
Set the priority of the request.
Use with a priority constant such as PRIORITY_HIGH_ACCURACY
. No other values
are accepted.
The priority of the request is a strong hint to the LocationClient for which location
sources to use. For example, PRIORITY_HIGH_ACCURACY
is more likely to use GPS, and
PRIORITY_BALANCED_POWER_ACCURACY
is more likely to use WIFI & Cell tower
positioning, but it also depends on many other factors (such as which sources are available)
and is implementation dependent.
setPriority(int)
and setInterval(long)
are the most important parameters
on a location request.
priority | an accuracy or power constant |
---|
IllegalArgumentException | if the quality constant is not valid |
---|
Set the minimum displacement between location updates in meters
By default this is 0.
smallestDisplacementMeters | the smallest displacement in meters the user must move between location updates. |
---|
IllegalArgumentException | if smallestDisplacementMeters is negative |
---|