-
Notifications
You must be signed in to change notification settings - Fork 159
How to use library
- Add it in your root build.gradle at the end of repositories:
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
- Add the dependency:
dependencies {
compile 'com.github.maddevsio:mad-location-manager:0.1.9'
}
- Add the JitPack repository to your build file:
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
- Add the dependency:
<dependency>
<groupId>com.github.maddevsio</groupId>
<artifactId>mad-location-manager</artifactId>
<version>0.1.9</version>
</dependency>
There is example application in current repository called "Sensor Data Collector" .
This is main class. It implements data collecting and processing. You need to make several preparation steps for using it :
- Add to application manifest this :
<service
android:name="mad.location.manager.lib.Services.KalmanLocationService"
android:enabled="true"
android:exported="false"
android:stopWithTask="false" />
- Create some class and implement LocationServiceInterface and optionally LocationServiceStatusInterface .
- Register this class with ServicesHelper.addLocationServiceInterface(this) (do it in constructor for example)
- Handle locationChanged callback. There is Kalman filtered location WITHOUT geohash filtering. Example of geohash filtering is in MainActivity class.
- Init location service settings object (or use standard one) and pass it to reset() function.
It's recommended to use start(), stop() and reset() methods, because this service has internal state. Use start() method at the beginning of new route. Stop service when your application doesn't use locations data. That need to be done for decrease battery consumption.
There are several settings for KalmanFilter. All of them stored in KalmanLocationService.Settings class.
- Acceleration deviation - this value controls process noise covariance matrix. In other words it's "trust level" of accelerometer data. Low value means that accelerometer data is more preferable.
- Gps min time - minimum time interval between location updates, in milliseconds
- Gps min distance - minimum distance between location updates, in meters
- Sensor frequency in Herz - the rate sensor events are delivered at
- GeoHash precision - length of geohash string (and precision)
- GeoHash min point - count of points with same geohash. GPS point becomes valid only when count greater then this value.
- Logger - if you need to log something to file just implement ILogger interface and initialize settings with that object. If you don't need that - just pass null .
There is an example in MainActivity class how to use logger and settings.
There are 2 ways of using GeoHash real-time filter :
- It could be used as part of KalmanLocationService. It will work inside that thread and will be used by service. But then you need to use start(), stop() and reset() methods.
- It could be used as external component and filter Location objects from any source (not only from KalmanLocationService). You need to reset it before using and then use method filter() .
It will calculate distance in 2 ways : Vincenty and haversine formula . Both of them show good results so maybe we will add some flag for choose.
It's very simple qt-application for track visualization. It uses log files collected by android application (by library). Before using log file should be prepared with prepare.sh script. That script is really simple too.
Everything is hardcoded there. So if you want to play with it you need 2 files : mainwindow.cpp and SensorController.cpp . You can generate noise for logged track and see what happens if you change some coefficients.
See main.cpp. Input files are hardcoded there so you need to change it first.
See method FilterInputFile in SensorController.cpp . There is 2 flags : usePredicted and noise.
See method initMap in mainwindow.cpp. There are settings for GeoHash real-time filter.