Signed-off-by: Keith Packard <keithp@keithp.com>
<!-- Permissions needed for GoogleMaps -->
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES"/>
<!-- Permissions needed for GoogleMaps -->
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES"/>
- <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
<permission android:name="org.altusmetrum.AltosDroid.permission.MAPS_RECEIVE"
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
<permission android:name="org.altusmetrum.AltosDroid.permission.MAPS_RECEIVE"
import android.app.Service;
import android.bluetooth.BluetoothDevice;
import android.content.Intent;
import android.app.Service;
import android.bluetooth.BluetoothDevice;
import android.content.Intent;
-//import android.os.Bundle;
+import android.content.Context;
+import android.os.Bundle;
import android.os.IBinder;
import android.os.Handler;
import android.os.Message;
import android.os.IBinder;
import android.os.Handler;
import android.os.Message;
import android.os.RemoteException;
import android.util.Log;
import android.widget.Toast;
import android.os.RemoteException;
import android.util.Log;
import android.widget.Toast;
+import android.location.Location;
+import android.location.LocationManager;
+import android.location.LocationListener;
import org.altusmetrum.altoslib_1.*;
import org.altusmetrum.altoslib_1.*;
+class AltosLocationListener implements LocationListener {
+ boolean fine;
+
+ public void onLocationChanged(Location location) {
+ }
+
+ public void onStatusChanged(String provider, int status, Bundle extras) {
+ }
+
+ public void onProviderEnabled(String provider) {
+ }
+
+ public void onProviderDisabled(String provider) {
+ }
+
+ public AltosLocationListener(boolean fine) {
+ this.fine = fine;
+ }
+}
+
public class TelemetryService extends Service {
private static final String TAG = "TelemetryService";
public class TelemetryService extends Service {
private static final String TAG = "TelemetryService";
// internally track state of bluetooth connection
private int state = STATE_NONE;
// internally track state of bluetooth connection
private int state = STATE_NONE;
+ // location listeners
+
+ private AltosLocationListener gpsListener;
+ private AltosLocationListener netListener;
+
// Handler of incoming messages from clients.
static class IncomingHandler extends Handler {
private final WeakReference<TelemetryService> service;
// Handler of incoming messages from clients.
static class IncomingHandler extends Handler {
private final WeakReference<TelemetryService> service;
// Start our timer - first event in 10 seconds, then every 10 seconds after that.
timer.scheduleAtFixedRate(new TimerTask(){ public void run() {onTimerTick();}}, 10000L, 10000L);
// Start our timer - first event in 10 seconds, then every 10 seconds after that.
timer.scheduleAtFixedRate(new TimerTask(){ public void run() {onTimerTick();}}, 10000L, 10000L);
+ // Listen for GPS and Network position updates
+ gpsListener = new AltosLocationListener(true);
+ netListener = new AltosLocationListener(false);
+
+ LocationManager locationManager = (LocationManager) this.getSystemService(Context.LOCATION_SERVICE);
+
+ locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0, gpsListener);
+ locationManager.requestLocationUpdates(LocationManager.NETWORK_PROVIDER, 0, 0, netListener);
@Override
public void onDestroy() {
@Override
public void onDestroy() {
+ // Stop listening for location updates
+ LocationManager locationManager = (LocationManager) this.getSystemService(Context.LOCATION_SERVICE);
+ locationManager.removeUpdates(gpsListener);
+ locationManager.removeUpdates(netListener);
+
// Stop the bluetooth Comms threads
stopAltosBluetooth();
// Stop the bluetooth Comms threads
stopAltosBluetooth();