Pebble: notification cleanups

- remove notification update code from PebbleIoThread (is in generic code now)
- use a separate notification for app/firmware installation
This commit is contained in:
Andreas Shimokawa 2015-04-28 21:59:53 +02:00
parent 9b676b5354
commit 31b01d860f
2 changed files with 44 additions and 14 deletions

View File

@ -1,8 +1,13 @@
###Changelog ###Changelog
####next release
* Pebble: Huge speedup for app/firmware installation.
* Pebble: Use a separate notification for installation procedure
* Mi Band: Display connection status in notification (previously Pebble only)
####Version 0.3.3 ####Version 0.3.3
* Pebble: try to reduce battery usage by acknowledging datalog packeets * Pebble: Try to reduce battery usage by acknowledging datalog packets
* Mi Band: set current time on the device (thanks to PR by @danielegobbetti) * Mi Band: Set current time on the device (thanks to PR by @danielegobbetti)
* General: more robust connection state handling and display * General: More robust connection state handling and display
####Version 0.3.2 ####Version 0.3.2
* Mi Band: Fix for notifications only working after manual connection * Mi Band: Fix for notifications only working after manual connection

View File

@ -1,5 +1,8 @@
package nodomain.freeyourgadget.gadgetbridge.pebble; package nodomain.freeyourgadget.gadgetbridge.pebble;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.bluetooth.BluetoothAdapter; import android.bluetooth.BluetoothAdapter;
import android.bluetooth.BluetoothDevice; import android.bluetooth.BluetoothDevice;
import android.bluetooth.BluetoothSocket; import android.bluetooth.BluetoothSocket;
@ -9,6 +12,7 @@ import android.content.SharedPreferences;
import android.net.Uri; import android.net.Uri;
import android.os.ParcelUuid; import android.os.ParcelUuid;
import android.preference.PreferenceManager; import android.preference.PreferenceManager;
import android.support.v4.app.NotificationCompat;
import android.support.v4.content.LocalBroadcastManager; import android.support.v4.content.LocalBroadcastManager;
import android.util.Log; import android.util.Log;
@ -25,6 +29,7 @@ import nodomain.freeyourgadget.gadgetbridge.GBCallControlReceiver;
import nodomain.freeyourgadget.gadgetbridge.GBDevice; import nodomain.freeyourgadget.gadgetbridge.GBDevice;
import nodomain.freeyourgadget.gadgetbridge.GBDeviceIoThread; import nodomain.freeyourgadget.gadgetbridge.GBDeviceIoThread;
import nodomain.freeyourgadget.gadgetbridge.GBMusicControlReceiver; import nodomain.freeyourgadget.gadgetbridge.GBMusicControlReceiver;
import nodomain.freeyourgadget.gadgetbridge.R;
import nodomain.freeyourgadget.gadgetbridge.protocol.GBDeviceCommand; import nodomain.freeyourgadget.gadgetbridge.protocol.GBDeviceCommand;
import nodomain.freeyourgadget.gadgetbridge.protocol.GBDeviceCommandAppInfo; import nodomain.freeyourgadget.gadgetbridge.protocol.GBDeviceCommandAppInfo;
import nodomain.freeyourgadget.gadgetbridge.protocol.GBDeviceCommandAppManagementResult; import nodomain.freeyourgadget.gadgetbridge.protocol.GBDeviceCommandAppManagementResult;
@ -35,6 +40,7 @@ import nodomain.freeyourgadget.gadgetbridge.protocol.GBDeviceProtocol;
public class PebbleIoThread extends GBDeviceIoThread { public class PebbleIoThread extends GBDeviceIoThread {
private static final String TAG = PebbleIoThread.class.getSimpleName(); private static final String TAG = PebbleIoThread.class.getSimpleName();
private static final int NOTIFICATION_ID = 2;
private enum PebbleAppInstallState { private enum PebbleAppInstallState {
UNKNOWN, UNKNOWN,
@ -43,7 +49,7 @@ public class PebbleIoThread extends GBDeviceIoThread {
APP_WAIT_TOKEN, APP_WAIT_TOKEN,
APP_UPLOAD_CHUNK, APP_UPLOAD_CHUNK,
APP_UPLOAD_COMMIT, APP_UPLOAD_COMMIT,
APP_WAIT_COMMMIT, APP_WAIT_COMMIT,
APP_UPLOAD_COMPLETE, APP_UPLOAD_COMPLETE,
APP_REFRESH, APP_REFRESH,
} }
@ -66,11 +72,33 @@ public class PebbleIoThread extends GBDeviceIoThread {
private ZipInputStream mZis = null; private ZipInputStream mZis = null;
private PebbleAppInstallState mInstallState = PebbleAppInstallState.UNKNOWN; private PebbleAppInstallState mInstallState = PebbleAppInstallState.UNKNOWN;
private PebbleInstallable[] mPebbleInstallables = null; private PebbleInstallable[] mPebbleInstallables = null;
private PebbleInstallable mPebbleInstallable = null;
private int mCurrentInstallableIndex = -1; private int mCurrentInstallableIndex = -1;
private int mInstallSlot = -1; private int mInstallSlot = -1;
private int mCRC = -1; private int mCRC = -1;
public static Notification createInstallNotification(String text, boolean ongoing, Context context) {
Intent notificationIntent = new Intent(context, AppManagerActivity.class);
notificationIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK
| Intent.FLAG_ACTIVITY_CLEAR_TASK);
PendingIntent pendingIntent = PendingIntent.getActivity(context, 0,
notificationIntent, 0);
return new NotificationCompat.Builder(context)
.setContentTitle("Gadgetbridge")
.setTicker(text)
.setContentText(text)
.setSmallIcon(R.drawable.ic_notification)
.setContentIntent(pendingIntent)
.setOngoing(ongoing).build();
}
public static void updateInstallNotification(String text, boolean ongoing, Context context) {
Notification notification = createInstallNotification(text, ongoing, context);
NotificationManager nm = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
nm.notify(NOTIFICATION_ID, notification);
}
public PebbleIoThread(GBDevice gbDevice, GBDeviceProtocol gbDeviceProtocol, BluetoothAdapter btAdapter, Context context) { public PebbleIoThread(GBDevice gbDevice, GBDeviceProtocol gbDeviceProtocol, BluetoothAdapter btAdapter, Context context) {
super(gbDevice, context); super(gbDevice, context);
mPebbleProtocol = (PebbleProtocol) gbDeviceProtocol; mPebbleProtocol = (PebbleProtocol) gbDeviceProtocol;
@ -96,7 +124,6 @@ public class PebbleIoThread extends GBDeviceIoThread {
} }
gbDevice.setState(GBDevice.State.CONNECTED); gbDevice.setState(GBDevice.State.CONNECTED);
gbDevice.sendDeviceUpdateIntent(getContext()); gbDevice.sendDeviceUpdateIntent(getContext());
GB.updateNotification("connected to " + btDevice.getName(), getContext());
return true; return true;
} }
@ -113,7 +140,7 @@ public class PebbleIoThread extends GBDeviceIoThread {
switch (mInstallState) { switch (mInstallState) {
case APP_WAIT_SLOT: case APP_WAIT_SLOT:
if (mInstallSlot != -1) { if (mInstallSlot != -1) {
GB.updateNotification("starting installation", getContext()); updateInstallNotification("starting installation", true, getContext());
mInstallState = PebbleAppInstallState.APP_START_INSTALL; mInstallState = PebbleAppInstallState.APP_START_INSTALL;
continue; continue;
} }
@ -164,9 +191,9 @@ public class PebbleIoThread extends GBDeviceIoThread {
case APP_UPLOAD_COMMIT: case APP_UPLOAD_COMMIT:
writeInstallApp(mPebbleProtocol.encodeUploadCommit(mAppInstallToken, mCRC)); writeInstallApp(mPebbleProtocol.encodeUploadCommit(mAppInstallToken, mCRC));
mAppInstallToken = -1; mAppInstallToken = -1;
mInstallState = PebbleAppInstallState.APP_WAIT_COMMMIT; mInstallState = PebbleAppInstallState.APP_WAIT_COMMIT;
break; break;
case APP_WAIT_COMMMIT: case APP_WAIT_COMMIT:
if (mAppInstallToken != -1) { if (mAppInstallToken != -1) {
Log.i(TAG, "got token " + mAppInstallToken); Log.i(TAG, "got token " + mAppInstallToken);
mInstallState = PebbleAppInstallState.APP_UPLOAD_COMPLETE; mInstallState = PebbleAppInstallState.APP_UPLOAD_COMPLETE;
@ -253,7 +280,6 @@ public class PebbleIoThread extends GBDeviceIoThread {
Log.i(TAG, e.getMessage()); Log.i(TAG, e.getMessage());
gbDevice.setState(GBDevice.State.CONNECTING); gbDevice.setState(GBDevice.State.CONNECTING);
gbDevice.sendDeviceUpdateIntent(getContext()); gbDevice.sendDeviceUpdateIntent(getContext());
GB.updateNotification("connection lost, trying to reconnect", getContext());
while (mConnectionAttempts++ < 10 && !mQuit) { while (mConnectionAttempts++ < 10 && !mQuit) {
Log.i(TAG, "Trying to reconnect (attempt " + mConnectionAttempts + ")"); Log.i(TAG, "Trying to reconnect (attempt " + mConnectionAttempts + ")");
@ -279,7 +305,6 @@ public class PebbleIoThread extends GBDeviceIoThread {
} }
} }
mBtSocket = null; mBtSocket = null;
GB.updateNotification("not connected", getContext());
gbDevice.setState(GBDevice.State.NOT_CONNECTED); gbDevice.setState(GBDevice.State.NOT_CONNECTED);
gbDevice.sendDeviceUpdateIntent(getContext()); gbDevice.sendDeviceUpdateIntent(getContext());
} }
@ -421,13 +446,13 @@ public class PebbleIoThread extends GBDeviceIoThread {
return; return;
} }
if (hadError) { if (hadError) {
GB.updateNotification("installation failed!", getContext()); updateInstallNotification("installation failed!", false, getContext());
} else { } else {
GB.updateNotification("installation successful", getContext()); updateInstallNotification("installation successful", false, getContext());
} }
mInstallState = PebbleAppInstallState.UNKNOWN; mInstallState = PebbleAppInstallState.UNKNOWN;
if (hadError == true && mAppInstallToken != -1) { if (hadError && mAppInstallToken != -1) {
writeInstallApp(mPebbleProtocol.encodeUploadCancel(mAppInstallToken)); writeInstallApp(mPebbleProtocol.encodeUploadCancel(mAppInstallToken));
} }