Allowing destructive migrations and writing locations to dabase in a new thread.

This commit is contained in:
Filip Strajnar 2024-10-19 15:24:31 +02:00
parent 678cce4536
commit 1b7e725026

View file

@ -7,6 +7,7 @@ import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager;
import android.location.LocationProvider;
import android.os.Build;
import android.os.IBinder;
import android.util.Log;
@ -34,6 +35,7 @@ public class LocationLoggingService extends Service implements LocationListener
LocationDatabase database = Room
.databaseBuilder(getApplicationContext(), LocationDatabase.class, "location")
.fallbackToDestructiveMigration()
.build();
locationDao = database.locationDao();
@ -64,12 +66,72 @@ public class LocationLoggingService extends Service implements LocationListener
@Override
public void onLocationChanged(@NonNull Location location) {
Log.d(TAG, String.format(
"New location. Latitude: %s Longitude: %s Altitude: %s",
location.getLatitude(),
location.getLongitude(),
location.getAltitude())
);
new Thread(()->{
Log.d(TAG, String.format(
"New location. Latitude: %s Longitude: %s Altitude: %s",
location.getLatitude(),
location.getLongitude(),
location.getAltitude())
);
if(locationDao == null)
{
Log.w(TAG, "Location DAO is null, could not write new location.");
return;
}
LocationEntity locationEntity = new LocationEntity();
locationEntity.latitude = location.getLatitude();
locationEntity.longitude = location.getLongitude();
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.S) {
locationEntity.isMock = location.isMock();
}
if(location.hasAccuracy())
{
locationEntity.accuracy = location.getAccuracy();
}
if(location.hasAltitude())
{
locationEntity.altitude = location.getAltitude();
}
if(location.hasBearing())
{
locationEntity.bearing = location.getBearing();
}
if(location.hasSpeed())
{
locationEntity.speed = location.getSpeed();
}
if(location.hasSpeedAccuracy())
{
locationEntity.speedAccuracy = location.getSpeedAccuracyMetersPerSecond();
}
if(location.hasVerticalAccuracy())
{
locationEntity.altitudeAccuracy = location.getVerticalAccuracyMeters();
}
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.UPSIDE_DOWN_CAKE) {
if(location.hasMslAltitude())
{
locationEntity.mslAltitude = location.getMslAltitudeMeters();
}
if(location.hasMslAltitudeAccuracy())
{
locationEntity.mslAltitudeAccuracy = location.getMslAltitudeAccuracyMeters();
}
}
locationDao.insert(locationEntity);
}).start();
}
@Override