altosdroid: Need access to handler inside AltosBluetooth
authorMike Beattie <mike@ethernal.org>
Sun, 26 Aug 2012 11:23:33 +0000 (23:23 +1200)
committerMike Beattie <mike@ethernal.org>
Sun, 26 Aug 2012 11:23:33 +0000 (23:23 +1200)
* Also move add_monitor() call

Signed-off-by: Mike Beattie <mike@ethernal.org>
altosdroid/src/org/altusmetrum/AltosDroid/AltosBluetooth.java
altosdroid/src/org/altusmetrum/AltosDroid/TelemetryService.java

index c16e3cf5bc8365d57d1a63de86ad6dff6eb71dc3..3bfa3488c8a25337de736e0b8a4b022125531468 100644 (file)
@@ -26,6 +26,7 @@ import java.util.UUID;
 import android.bluetooth.BluetoothAdapter;
 import android.bluetooth.BluetoothDevice;
 import android.bluetooth.BluetoothSocket;
+import android.os.Handler;
 import android.util.Log;
 
 import org.altusmetrum.AltosLib.*;
@@ -39,6 +40,8 @@ public class AltosBluetooth extends AltosLink {
        private ConnectThread    connect_thread = null;
        private Thread           input_thread   = null;
 
+       private Handler          handler;
+
        private BluetoothAdapter adapter;
        private BluetoothDevice  device;
        private BluetoothSocket  socket;
@@ -46,9 +49,10 @@ public class AltosBluetooth extends AltosLink {
        private OutputStream     output;
 
        // Constructor
-       public AltosBluetooth(BluetoothDevice in_device) {
+       public AltosBluetooth(BluetoothDevice in_device, Handler in_handler) {
                adapter = BluetoothAdapter.getDefaultAdapter();
                device = in_device;
+               handler = in_handler;
 
                connect_thread = new ConnectThread(device);
                connect_thread.start();
index 6a23dca32a6ab264ad922f69432dfa963775c0cc..1903cc1de2d8c2084cebfebda7cdabad9a3590ac 100644 (file)
@@ -61,7 +61,8 @@ public class TelemetryService extends Service {
        //private NotificationManager mNM;
 
        ArrayList<Messenger> mClients = new ArrayList<Messenger>(); // Keeps track of all current registered clients.
-       final Messenger mMessenger = new Messenger(new IncomingHandler()); // Target we publish for clients to send messages to IncomingHandler.
+       final Handler   mHandler   = new IncomingHandler(this);
+       final Messenger mMessenger = new Messenger(mHandler); // Target we publish for clients to send messages to IncomingHandler.
 
        // Name of the connected device
        private String mConnectedDeviceName = null;
@@ -93,6 +94,7 @@ public class TelemetryService extends Service {
                        case MSG_CONNECTED:
                                if (D) Log.d(TAG, "Connected to device");
                                s.setState(STATE_CONNECTED);
+                               s.mAltosBluetooth.add_monitor(s.telem);
                                break;
                        default:
                                super.handleMessage(msg);
@@ -110,8 +112,7 @@ public class TelemetryService extends Service {
        }
 
        private void startAltosBluetooth(BluetoothDevice d) {
-               mAltosBluetooth = new AltosBluetooth(d);
-               mAltosBluetooth.add_monitor(telem);
+                       mAltosBluetooth = new AltosBluetooth(d, mHandler);
                        setState(STATE_CONNECTING);
        }