...
In the AndroidManifest file, you must declare ACCESS_FINE_LOCATION and ACCESS_BACKGROUND_LOCATION
|
If your app targets Android 10 (API level 29) or higher ACCESS_BACKGROUND_LOCATION is mandatory.
Ask for runtime permission when the user interacts with a feature in your application which demands location access.
|
|
To start geofence call (deprecated, without receiving Geofence status or errors)
|
To start geofence call (with receiving geofence status or errors)
Code Block |
---|
// Define callback for getting result when calling start geofence private final ResultCallback<String> geofenceCallback = new ResultCallback<>() { @Override public void onResult(@Nullable String result) { devLogger.d(result); if (result != null) { switch (result) { // handle different cases of a result status } } } }; // Start Geofence Appoxee.instance().startGeoFencing(geofenceCallback); |
List of all possible statuses when starting Geofence:
Code Block |
---|
String GEOFENCE_SDK_NOT_READY = "GEOFENCE_SDK_NOT_READY"; String GEOFENCE_LOCATION_PERMISSIONS_NOT_GRANTED = "GEOFENCE_LOCATION_PERMISSIONS_NOT_GRANTED"; String GEOFENCE_LOCATION_NOT_ACCURATE = "GEOFENCE_LOCATION_NOT_ACCURATE"; String GEOFENCE_LOCATION_NOT_AVAILABLE = "GEOFENCE_LOCATION_NOT_AVAILABLE"; String GEOFENCE_NO_INTERNET_CONNECTION = "GEOFENCE_NO_INTERNET_CONNECTION"; String GEOFENCE_FAILED_GETTING_REGIONS = "GEOFENCE_FAILED_GETTING_REGIONS"; String GEOFENCE_STARTED_OK = "GEOFENCE_STARTED_OK"; String GEOFENCE_STOPPED_OK="GEOFENCE_STOPPED_OK"; String GEOFENCE_GENERAL_ERROR = "GEOFENCE_GENERAL_ERROR"; String GEOFENCE_TOO_MANY_GEOFENCE_CALLS = "GEOFENCE_TOO_MANY_GEOFENCE_CALLS"; String GEOFENCE_TOO_MANY_GEOFENCES = "GEOFENCE_TOO_MANY_GEOFENCES"; String GEOFENCE_TOO_MANY_PENDING_INTENTS="GEOFENCE_TOO_MANY_PENDING_INTENTS"; String GEOFENCE_ERROR_STOPPING = "GEOFENCE_ERROR_STOPPING"; |
In the example below, you can see how to ask for permission and start geofencing:
...
|
To stop geofence call (deprecated, without receiving Geofence status or errors)
|
To stop geofence call (with receiving Geofence status or errors)
Code Block |
---|
Appoxee.instance().stopGeoFencing(geofenceCallback); |
Best practices to improve geofencing:
enable Wi-Fi or Wi-Fi scanning
enable Bluetooth or Bluetooth scanning
enable Mobile data
disable Airplane Mode (the phone must NOT be in Airplane Mode)
avoid using Power Saving Mode
enable Mobile data
Use code below to enable Wi-Fi scanning from code
...
|
Or you can use code below to redirect the user to Location Service in Settings:
...
|
On this page user should enable:
Wi-FI scanning,
Bluetooth scanning,
Emergency Location Service and
Google Location Accuracy
...
...
In the screenshots above you can see which options should be enabled when the user is redirected to Location Service in Settings.
Recommendations
Setting a minimum radius of 100 meters (150 is recommended ) will get you the best results from your geofences. This helps account for the location accuracy of typical Wi-Fi networks, and also helps reduce device power consumption.
Troubleshoot the geofence entrance event: (https://developer.android.com/training/location/geofencing#Troubleshooting). If geofences aren't being triggered when the device enters a geofence (the GEOFENCE_TRANSITION_ENTER alert isn’t triggered), first, ensure that your geofences are registered properly as described in this guide.
Here are some possible reasons for alerts not working as expected:
Accurate location isn't available inside your geofence or your geofence is too small. On most devices, the geofence service uses only the network location for geofence triggering. The service uses this approach because network location consumes much less power, it takes less time to get discrete locations, and most importantly it’s available indoors.
Wi-Fi is turned off on the device. Having Wi-Fi on can significantly improve the location accuracy, so if Wi-Fi is turned off, your application might never get geofence alerts depending on several settings including the radius of the geofence, the device model, or the Android version. Starting from Android 4.3 (API level 18), we added the capability of “Wi-Fi scan only mode” which allows users to disable Wi-Fi but still get a good network location. It’s good practice to prompt the user and provide a shortcut for the user to enable Wi-Fi or Wi-Fi scan only mode if both of them are disabled. Use SettingsClient to ensure that the device's system settings are properly configured for optimal location detection.
Note: If your app targets Android 10 (API level 29) or higher, you cannot call WifiManager.setEnabled() (deprecated from API 28!!!) directly unless your app is a system app or a device policy controller (DPC). Instead, use a settings panel.
There is no reliable network connectivity inside your geofence. If there is no reliable data connection, alerts might not be generated. This is because the geofence service depends on the network location provider which in turn requires a data connection.
Alerts can be late. The geofence service doesn't continuously query for location, so expect some latency when receiving alerts. Usually, the latency is less than 2 minutes, even less when the device has been moving. If Background Location Limits are in effect, the latency is about 2-3 minutes on average. If the device has been stationary for a significant period of time, the latency may increase (up to 6 minutes).
Additional information on handling geofencing transitions can be found here.
Location settings
Android 9.0+
To change location settings:
Open your device's Settings app.
Tap Security & Location → Location.
If you have a work profile, tap Advanced.
Then, choose the option:
Turn Location on or off: Tap Location.
Scan for nearby networks: Tap Advanced → Scanning. Turn Wi-Fi scanning and Bluetooth scanning on.
Turn emergency location service on or off: Tap Advanced → Google Emergency Location Service. Turn Emergency Location Service on.
Android 4.4 - 8.1
You can choose your location mode based on accuracy, speed, and battery use.
Open your phone's Settings app.
Tap Security & Location → Location. If you don't see "Security & Location," tap Location.
Tap Mode. Then pick:
High accuracy: Use GPS, Wi-Fi, mobile networks, and sensors to get the most accurate location. Use Google Location Services to help estimate your phone's location faster and more accurately.
Battery saving: Use sources that use less battery, like Wi-Fi and mobile networks. Use Google Location Services to help estimate your phone's location faster and more accurately.
Device only: Use the only GPS. Don’t use Google Location Services to provide location information. This can estimate your phone's location more slowly and use more battery.