# Titanium.Geolocation
The top level Geolocation module. The Geolocation module is used for accessing device location based information.
# Overview
This module combines two sets of features:
Location services. Determining the location of the device.
Geocoding and reverse geocoding. Converting geographic coordinates into addresses, and converting addresses into geographic coordinates.
Using location services can have a significant impact on a device's battery life, so it's important to use them in the most efficient manner possible. Power consumption is strongly influenced by the accuracy and frequency of location updates required by your application.
The location services systems of the underlying platforms are very different, so there are significant implementation differences between the platforms.
The basic methods of requesting location information and receiving location updates are essentially the same on all platforms. However, the method of configuring the accuracy and frequency of location updates is different for each platform.
# Getting Location Information
There are two ways to get location information:
Make a one-time request with Titanium.Geolocation.getCurrentPosition.
Register to receive location updates by adding an event listener for the Titanium.Geolocation.location event.
NOTE: Location services stay enabled for as long as a listener is registered for the
location
event, so be sure to remove the event listener when you do not require
location updates.
# Configurating Location Updates on iOS
In iOS, the accuracy (and power consumption) of location services is primarily determined by the Titanium.Geolocation.accuracy setting. This can be set to one of the following values:
- Titanium.Geolocation.ACCURACY_BEST (highest accuracy and power consumption)
- Titanium.Geolocation.ACCURACY_BEST_FOR_NAVIGATION
- Titanium.Geolocation.ACCURACY_HIGH
- Titanium.Geolocation.ACCURACY_NEAREST_TEN_METERS
- Titanium.Geolocation.ACCURACY_HUNDRED_METERS
- Titanium.Geolocation.ACCURACY_KILOMETER
- Titanium.Geolocation.ACCURACY_LOW
- Titanium.Geolocation.ACCURACY_THREE_KILOMETERS (lowest accuracy and power consumption).
Based on the accuracy you choose, iOS uses its own logic to select location providers and filter location updates to provide location updates that meet your accuracy requirements.
You can further limit power consumption on iOS by setting the Titanium.Geolocation.distanceFilter property to eliminate position updates when the user is not moving.
In order to receive the user's location, add either the
NSLocationWhenInUseUsageDescription
(opens new window)
or
NSLocationAlwaysUsageDescription
(opens new window)
key to the iOS plist section of the project's tiapp.xml
file.
<ti:app>
<ios>
<plist>
<dict>
<key>NSLocationAlwaysUsageDescription</key>
<string>
Specify the reason for accessing the user's location information.
This appears in the alert dialog when asking the user for permission to
access their location.
</string>
</dict>
</plist>
</ios>
</ti:app>
For iOS 11 and later, also add the NSLocationAlwaysAndWhenInUseUsageDescription
(opens new window)
when planning to request the "Always" permission. Using the above key, you are also able to upgrade your permissions from
"When in Use" to "Always", which is the recommended way for managing location permissions in iOS 11 and later.
Please also remember to request your desired location-permissions before using any geolocation-related API in
order to receive the best usability and permission-control during the app-lifecycle using Titanium.Geolocation.hasLocationPermissions
and Titanium.Geolocation.requestLocationPermissions. Also note that you also need to include the NSLocationWhenInUseUsageDescription
key
in any case when targeting iOS 11 and later. Descriptive error-logs will be thrown if required permissions are missing.
# Configurating Location Updates on Android
On Android, two different location service modes are supported: simple, and manual.
Simple mode provides a compromise mode that provides adaquate support for undemanding location applications without requiring developers to write a lot of Android-specific code. To use simple mode:
Leave the Titanium.Geolocation.Android.manualMode flag set to
false
(the default value).Set the Titanium.Geolocation.accuracy property to either Titanium.Geolocation.ACCURACY_HIGH or Titanium.Geolocation.ACCURACY_LOW.
Manual mode gives developers low-level control of location updates, including enabling individual location providers and filtering updates, for the best combination of accuracy and battery life.
Manual mode is used when the Titanium.Geolocation.Android.manualMode flag is set to
true
. In manual mode, theaccuracy
property is not used, and all configuration is done through the Titanium.Geolocation.Android module.
As of Titanium SDK 7.1.0 and later, including the ti.playservices
(opens new window) module will allow Google Play Services
to be used by default to obtain location information. This means the provider passed into Titanium.Geolocation.Android.createLocationProvider
will be ignored, as Google Play Services will select the best provider based on current device conditions.
If Google Play Services is not available it will fallback to previous behaviour of using Android location APIs.
To retrieve location events:
var win = Ti.UI.createWindow({ backgroundColor: 'white' });
Ti.Geolocation.accuracy = Ti.Geolocation.ACCURACY_HIGH;
function getLocation() {
Ti.Geolocation.addEventListener('location', function(e) {
alert(JSON.stringify(e, null, 2));
});
}
win.addEventListener('open', function() {
if (Ti.Geolocation.hasLocationPermissions()) {
getLocation();
} else {
Ti.Geolocation.requestLocationPermissions(Ti.Geolocation.AUTHORIZATION_ALWAYS, function(e) {
if (e.success) {
getLocation();
} else {
alert('could not obtain location permissions');
}
});
}
});
win.open();
# Using the Compass
Both iOS and Android support a receiving heading updates from a hardware compass, if available.
Check the Titanium.Geolocation.hasCompass property to see if the current device supports a compass.
To retrieve compass readings, you can either use Titanium.Geolocation.getCurrentHeading as shown in the previous example, or add a listener for the Titanium.Geolocation.heading event, as shown below:
function compassHandler (e) {
if (e.success) {
Ti.API.info('Heading: ' + e.heading.magneticHeading);
}
}
Ti.Geolocation.addEventListener('heading', compassHandler);
Note that Android did not include a success
property in the heading
event prior to SDK 7.5.0.
Heading events are only generated on Android when heading data is available. So if
success
is undefined on prior SDK versions, we assume that the event contains valid compass data.
To obtain true heading data for the compass (as opposed to magnetic heading data), a current location fix is required. See the notes on HeadingData.trueHeading for more information.
As with location updates, the application should unregister for heading updates
when it is no longer being used, or when it goes into the background. Use
removeEventListener
to stop heading updates:
Ti.Geolocation.removeEventListener('heading', compassHandler);
Finally, note that neither the Android emulator nor the iOS simulator provide compass support. Compass code must be tested on physical devices.
# Geocoding Services
The module provides two methods, Titanium.Geolocation.forwardGeocoder and Titanium.Geolocation.reverseGeocoder to convert between geographic coordinates and addresses. These methods map to MapQuest Open Nominatim Search Service.
While this API has the advantage that it has no daily usage limits, please note that the data backing this API is crowd sourced and might not return proper values for valid addresses and geographic coordinates.
If geocoding services are essential component of the application, developers are encouraged to use commercial geocoding providers.
# Properties
# accuracy
Specifies the requested accuracy for location updates.
For basic location updates on all platforms, set accuracy
to either:
- ACCURACY_HIGH for higher-quality location updates, with the higher power consumption.
- ACCURACY_LOW for lower-quality location updates with lower power consumption.
For finer-grained control on iOS, specify one of ACCURACY_BEST
,
ACCURACY_NEAREST_TEN_METERS
, ACCURACY_HUNDRED_METERS
, ACCURACY_KILOMETER
, or
ACCURACY_THREE_KILOMETERS
.
For finer-grained control on Android, use manual mode, instead of specifing an accuracy. This mode requires more active management on the part of the application, but it is recommended to maximize accuracy and battery life. See Titanium.Geolocation.Android for details on using manual mode.
- Titanium.Geolocation.ACCURACY_HIGH
- Titanium.Geolocation.ACCURACY_BEST_FOR_NAVIGATION
- Titanium.Geolocation.ACCURACY_LOW
- Titanium.Geolocation.ACCURACY_BEST
- Titanium.Geolocation.ACCURACY_NEAREST_TEN_METERS
- Titanium.Geolocation.ACCURACY_HUNDRED_METERS
- Titanium.Geolocation.ACCURACY_KILOMETER
- Titanium.Geolocation.ACCURACY_THREE_KILOMETERS
- Titanium.Geolocation.ACCURACY_REDUCED
# activityType
The type of user activity to be associated with the location updates.
The information in this property is used as a cue to determine when location updates may be automatically paused. Pausing updates gives the system the opportunity to save power in situations where the user's location is not likely to be changing. For example, if the activity type is ACTIVITYTYPE_AUTOMOTIVE_NAVIGATION and no location changes have occurred recently, the radios might be powered down until movement is detected again.
Default: Titanium.Geolocation.ACTIVITYTYPE_OTHER
# allowsBackgroundLocationUpdates
Determines if the app can do background location updates.
When UIBackgroundModes
include location
in tiapp.xml, this property is
set to true
by default.
Default: false
# distanceFilter
The minimum change of position (in meters) before a 'location' event is fired.
If set to 0, distance filtering is disabled, meaning that location events are generated continuously.
Default: 0
# frequency DEPRECATED
DEPRECATED SINCE 2.0.0
Android legacy mode operation is deprecated. For new development, use either simple mode or manual mode. See "Configurating Location Updates on Android" in the main description of this class for more information.
Requested frequency for location updates, in milliseconds.
Setting a frequency value enables legacy location mode on Android. Note that only a single provider can be active at one time in legacy mode. Note that the frequency value is used as a guideline: there are no guarantees that the device will provide updates at the specified frequency. A lower frequency value generally increases power consumption. A value of 0 means that updates should be generated as quickly as possible.
# headingFilter
Minimum heading change (in degrees) before a heading
event is fired.
Set to a value greater than zero to reduce the number of heading events generated.
Default: 0 (No limit on heading updates)
# lastGeolocation READONLY
JSON representation of the last geolocation received.
LastEvent is the JSON version of the last geolocation sent by the OS. This does not trigger a geolocation attempt, nor wait for such. If no geolocation has happened, this value may be null or undefined.
# locationAccuracyAuthorization READONLY
A value that indicates the level of location accuracy the app has permission to use.
If the value of this property is ACCURACY_AUTHORIZATION_FULL, you can set any constant to accuracy. If value is ACCURACY_AUTHORIZATION_REDUCED setting accuracy to a value other than ACCURACY_REDUCED has no effect on the location information.
Default: Titanium.Geolocation.ACCURACY_AUTHORIZATION_REDUCED
# locationServicesAuthorization READONLY
Returns an authorization constant indicating if the application has access to location services.
If locationServicesAuthorization
is AUTHORIZATION_RESTRICTED
, you should not
attempt to re-authorize: this will lead to issues.
# locationServicesEnabled READONLY
Indicates if the user has enabled or disabled location services for the device (not the application).
This method returns true
if any location provider is enabled.
On Android, there is a "passive" location provider that is enabled
at all times, even when the user disables both the GPS and Network location providers.
Therefore, this method returns true
on these devices if only there is GPS or network provider available.
# pauseLocationUpdateAutomatically
Indicates whether the location updates may be paused.
Allowing the location updates to be paused can improve battery life on the target device without sacrificing location data. When this property is set to YES, the location updates are paused (and powers down the appropriate hardware) at times when the location data is unlikely to change. For example, if the user stops for food while using a navigation app, the location manager might pause updates for a period of time. You can help the determination of when to pause location updates by assigning a value to the activityType property.
Default: false
# preferredProvider DEPRECATED
DEPRECATED SINCE 2.0.0
Android legacy mode operation is deprecated. For new development, use either simple mode or manual mode. See "Configurating Location Updates on Android" in the main description of this class for more information.
Determines the preferred location provider.
Setting a preferred provider enables legacy location mode on Android.
Note that only a single provider can be active at one time in legacy mode.
The preferred provider affects power consumption. In general, PROVIDER_GPS
requires the most power, and PROVIDER_PASSIVE
requires the least.
If undefined
, the preferred provider is auto-detected.
Default: Titanium.Geolocation.Android.PROVIDER_NETWORK
# showBackgroundLocationIndicator
Specifies that an indicator be shown when the app makes use of continuous background location updates.
Starting continuous background location updates requires the app to
set UIBackgroundModes
to include "location" and to set this property
to true
before calling getCurrentPosition
with the intent to continue
in the background.
Note that this property only applies to apps with Always authorization. For apps with WhenInUse authorization, the indicator is always shown when using continuous background location updates in order to maintain user visibility and that the app is still in use.
Default: false
# showCalibration
Determines whether the compass calibration UI is shown if needed.
Set to false
to disable display of the compass calibration UI. This may result
in invalid heading data.
Default: true
# trackSignificantLocationChange
Indicates if the location changes should be updated only when a significant change in location occurs.
The trackSignificantLocationChange service offers a low-power location service for devices with cellular radios.
This service offers a significant power savings and provides accuracy that is good enough for most applications. It uses the device's cellular radio to determine the user's location and report changes in that location, allowing the system to manage power usage much more aggressively than it could otherwise. This service is also capable of waking up an application that is currently suspended or not running in order to deliver new location data.
Default: false
# Methods
# forwardGeocoder
Resolves an address to a location.
Parameters
Name | Type | Description |
---|---|---|
address | String | address to resolve. |
callback | Callback<ForwardGeocodeResponse> | Function to invoke on success or failure.
Optional on SDK 10, as this method will return a |
Returns
On SDK 10+, this method will return a Promise
whose resolved value is equivalent to that passed to the optional callback argument.
- Type
- Promise<ForwardGeocodeResponse>
# getCurrentHeading
Retrieves the current compass heading.
Parameters
Name | Type | Description |
---|---|---|
callback | Callback<HeadingResponse> | Function to invoke on success or failure of obtaining the current heading.
Optional on SDK 10, as this method will return a |
Returns
On SDK 10+, this method will return a Promise
whose resolved value is equivalent to that passed to the optional callback argument.
- Type
- Promise<HeadingResponse>
# getCurrentPosition
Retrieves the last known location from the device.
On Android, the radios are not turned on to update the location, and a cached location is used.
On iOS the radios may be used if the location is too "old".
Parameters
Name | Type | Description |
---|---|---|
callback | Callback<LocationResults> | Function to invoke on success or failure of obtaining the current location.
Optional on SDK 10, as this method will return a |
Returns
On SDK 10+, this method will return a Promise
whose resolved value is equivalent to that passed to the optional callback argument.
- Type
- Promise<LocationResults>
# hasLocationPermissions
Returns true
if the app has location access.
Parameters
Name | Type | Description |
---|---|---|
authorizationType | Number | Types of geolocation's authorizations. This is an iOS only parameter and is ignored on Android. |
Returns
- Type
- Boolean
# requestLocationPermissions
Requests for location access.
On Android, the request view will show if the permission is not accepted by the user, and the user did
not check the box "Never ask again" when denying the request. If the user checks the box "Never ask again,"
the user has to manually enable the permission in device settings. If the user asks for permissions or
tries to get unauthorized location information, then the app should call the request method to show
the permission settings. This method requests Manifest.permission.ACCESS_FINE_LOCATION
on Android.
If you require other permissions, you can also use requestPermissions.
In iOS 8, Apple introduced the Info.plist keys NSLocationWhenInUseUsageDescription
and NSLocationAlwaysUsageDescription
that are used to display an own description while requesting location permissions. In addition to this method, you need to
include one of these keys (based on how your location updates should behave) or the application will crash if your app does not.
In iOS 11, Apple introduced another Info.plist key NSLocationAlwaysAndWhenInUseUsageDescription
that allows developers to upgrade
their permissions from "When in Use" to "Always". In order to get the best usability for iOS 11 and later, request "When in Use" first
and upgrade your location-permissions by requesting "Always" permissions later if required. If this permission-flow is not used, iOS
will still ask the user to select between "When in Use", "Always", and "Don't Allow" (primary action) on iOS 11 when asking for "Always"
permissions, which can lead to a higher frequence of denied permissions, so be careful requesting location permissions.
The iOS 11 related upgrade-flow is available in Titanium SDK 6.3.0 and later.
Finally, iOS 11 and later will require you to always include the NSLocationWhenInUseUsageDescription
permission and Titanium will throw a
descriptive error-log if any required keys are missing.
More infos:
Parameters
Name | Type | Description |
---|---|---|
authorizationType | Number | Types of geolocation's authorizations. This is an iOS only parameter and is ignored on Android. |
callback | Callback<LocationAuthorizationResponse> | Function to call upon user decision to grant location access.
Optional on SDK 10, as this method will return a |
Returns
On SDK 10+, this method will return a Promise
whose resolved value is equivalent to that passed to the optional callback argument.
- Type
- Promise<LocationAuthorizationResponse>
# requestTemporaryFullAccuracyAuthorization
Requests the user's permission to temporarily use location services with full accuracy.
If your app doesn't have permission to access accurate location (see locationAccuracyAuthorization,
you can use this method to request temporary access to accurate location. This access will expire automatically,
but it won't expire while the user is still engaged with your app. So, for example, while your app is in
the foreground your app will retain the temporary access it was granted. Similarly, if your app starts a
Continuous Background Location session with the background location indicator enabled (see showBackgroundLocationIndicator,
your access to accurate location will remain as long as the background location indicator remains enabled.
This allows your app to provide session-oriented experiences which require accurate location (e.g. fitness or navigation),
even if the user has decided not to grant your app persistent access to accurate location.
You need to add key NSLocationTemporaryUsageDescriptionDictionary
in tiapp.xml
. See following example -
<ti:app>
<ios>
<plist>
<dict>
<key>NSLocationTemporaryUsageDescriptionDictionary</key>
<dict>
<key>PurposeKey1</key>
<string>
Specify the reason for accessing the user's location data with full accuracy.
This appears in the alert dialog when asking the user for permission to
access their location.
</string>
<key>PurposeKey2</key>
<string>
Specify the reason for accessing the user's location data with full accuracy.
This appears in the alert dialog when asking the user for permission to
access their location.
</string>
</dict>
</dict>
</plist>
</ios>
</ti:app>
When CoreLocation prepares the prompt for display, it will look at the NSLocationTemporaryUsageDescriptionDictionary key in your tiapp.xml. The value should be a dictionary containing usage descriptions. The purposeKey you provide to this method must correspond to an entry in that dictionary.
Parameters
Name | Type | Description |
---|---|---|
purposeKey | String | A key in the NSLocationTemporaryUsageDescriptionDictionary dictionary of the app's tiapp.xml file. The value for this key is an app-provided string that describes the reason for accessing location data with full accuracy. |
callback | Callback<LocationAccuracyAuthorizationResponse> | Function to call upon user decision to grant authorization. |
Returns
- Type
- void
# reverseGeocoder
Tries to resolve a location to an address.
The callback receives a ReverseGeocodeResponse object. If the request is successful, the object includes one or more addresses that are possible matches for the requested coordinates.
Parameters
Name | Type | Description |
---|---|---|
latitude | Number | Latitude to search, specified in decimal degrees. |
longitude | Number | Longitude to search, specified in decimal degrees. |
callback | Callback<ReverseGeocodeResponse> | Function to invoke on success or failure.
Optional on SDK 10, as this method will return a |
Returns
On SDK 10+, this method will return a Promise
whose resolved value is equivalent to that passed to the optional callback argument.
- Type
- Promise<ReverseGeocodeResponse>
# Events
# calibration
Fired when the device detects interface and requires calibration.
When this event is fired, the iOS calibration UI is being displayed to the end user.
# heading
Fired when an heading update is received.
Properties
Name | Type | Description |
---|---|---|
code | Number | If |
success | Boolean | Indicate if the heading event was successfully received. Android returns this since SDK 7.5.0. |
error | String | If |
heading | HeadingData | Dictionary object containing the heading data. |
source | Object | Source object that fired the event. |
type | String | Name of the event fired. |
bubbles | Boolean | True if the event will try to bubble up if possible. |
cancelBubble | Boolean | Set to true to stop the event from bubbling. |
# location
Fired when a location update is received.
Properties
Name | Type | Description |
---|---|---|
code | Number | if |
success | Boolean | Indicates if location data was successfully retrieved. |
provider | LocationProviderDict | If |
coords | LocationCoordinates | If |
error | String | If |
source | Object | Source object that fired the event. |
type | String | Name of the event fired. |
bubbles | Boolean | True if the event will try to bubble up if possible. |
cancelBubble | Boolean | Set to true to stop the event from bubbling. |
# locationupdatepaused
Fired when location updates are paused by the OS.
This event is fired when pauseLocationUpdateAutomatically
is set to true
and if the OS detects that the device's location is not changing,
causing it to pause the delivery of updates in order to shut down the appropriate
hardware and save power.
# locationupdateresumed
Fired when location manager is resumed by the OS.
When location updates are paused and need to be resumed (perhaps because the user is moving again), this event is fired to let the app know that it is about to begin the delivery of those updates again.
# authorization
Fired when changes are made to the authorization status for location services.
This event is fired whenever the application's ability to use location services changes. Changes can occur because the user allowed or denied the use of location services for the app or the system as a whole.
Properties
Name | Type | Description |
---|---|---|
authorizationStatus | Number | New authorization status for the application. |
source | Object | Source object that fired the event. |
type | String | Name of the event fired. |
bubbles | Boolean | True if the event will try to bubble up if possible. |
cancelBubble | Boolean | Set to true to stop the event from bubbling. |
# Constants
# ACCURACY_AUTHORIZATION_FULL
The user authorized the app to access location data with full accuracy.
# ACCURACY_AUTHORIZATION_REDUCED
The user authorized the app to access location data with reduced accuracy.
# ACCURACY_BEST
Use with accuracy to request the best accuracy available.
Using this value results in the most accurate location updates, and the highest battery usage.
Using this value on Android enables legacy mode operation, which is not recommended.
# ACCURACY_BEST_FOR_NAVIGATION
Use with accuracy to request highest possible accuracy and combine it with additional sensor data.
Using this value is intended for use in navigation applications that require precise position information at all times and are intended to be used only while the device is plugged in.
# ACCURACY_HIGH
Use with accuracy to request more accurate location updates with higher battery usage.
Using this value on Android enables simple mode operation.
# ACCURACY_HUNDRED_METERS
Use with accuracy to request location updates accurate to the nearest 100 meters.
Using this value on Android enables legacy mode operation, which is not recommended.
# ACCURACY_KILOMETER
Use with accuracy to request location updates accurate to the nearest kilometer.
Using this value on Android enables legacy mode operation, which is not recommended.
# ACCURACY_LOW
Use with accuracy to request less accurate location updates with lower battery usage.
Using this value on Android enables simple mode operation.
# ACCURACY_NEAREST_TEN_METERS
Use with accuracy to request location updates accurate to the nearest 10 meters.
Using this value on Android enables legacy mode operation, which is not recommended.
# ACCURACY_REDUCED
The level of accuracy used when an app isn’t authorized for full accuracy location data.
Use with accuracy. The accuracy of location data is reduced in both space and time using approaches like selecting a nearby point of interest and updating the location at most a few times per hour. The approximate location preserves the user’s country, typically preserves the city, and is usually within 1–20 kilometers of the actual location. If your app is authorized to access location information with full accuracy, you can use this constant to access location data as if the app didn’t have that authorization.
# ACCURACY_THREE_KILOMETERS
Use with accuracy to request location updates accurate to the nearest three kilometers.
Using this value on Android enables legacy mode operation, which is not recommended.
# ACTIVITYTYPE_AUTOMOTIVE_NAVIGATION
The location data is used for tracking location changes to the automobile specifically during vehicular navigation.
Used with activityType. This activity might cause location updates to be paused only when the vehicle does not move for an extended period of time.
# ACTIVITYTYPE_FITNESS
The location data is used for tracking any pedestrian-related activity.
Used with activityType. This activity might cause location updates to be paused only when the user does not move a significant distance over a period of time.
# ACTIVITYTYPE_OTHER
The location data is being used for an unknown activity.
Used with activityType.
# ACTIVITYTYPE_OTHER_NAVIGATION
The location data is used for tracking movements of other types of vehicular navigation that are not automobile related.
Used with activityType. You would use this to track navigation by boat, train, or plane. Do not use this type for pedestrian navigation tracking. This activity might cause location updates to be paused only when the vehicle does not move a significant distance over a period of time.
# AUTHORIZATION_ALWAYS
A locationServicesAuthorization value indicating that the application is authorized to start location services at any time. This authorization includes the use of all location services, including monitoring regions and significant location changes.
# AUTHORIZATION_AUTHORIZED DEPRECATED
DEPRECATED SINCE 7.0.0
Use AUTHORIZATION_ALWAYS as advised by Apple.
A locationServicesAuthorization value indicating that the application is authorized to use location services.
# AUTHORIZATION_DENIED
A locationServicesAuthorization value indicating that the application is not authorized to use location services, or location services are disabled.
# AUTHORIZATION_RESTRICTED
A locationServicesAuthorization value indicating that the application is not authorized to use location servies and the user cannot change this application's status.
# AUTHORIZATION_UNKNOWN
A locationServicesAuthorization value indicating that the authorization state is unknown.
# AUTHORIZATION_WHEN_IN_USE
A locationServicesAuthorization value indicating that the application is authorized to start most location services only while running in the foreground.
# ERROR_DENIED
Error code indicating that the user denied access to the location service.
# ERROR_HEADING_FAILURE
Error code indicating that the heading could not be determined.
# ERROR_LOCATION_UNKNOWN
Error code indicating that the user's location could not be determined.
# ERROR_REGION_MONITORING_DELAYED
Error code indicating that region monitoring is delayed.
# ERROR_REGION_MONITORING_DENIED
Error code indicating that region monitoring is denied.
# ERROR_REGION_MONITORING_FAILURE
Error code indicating a region monitoring failure.