mirror of https://github.com/BOINC/boinc.git
android: prevent foreground service notification to be udpated every second, prevent blinking.
This commit is contained in:
parent
3f996ec9af
commit
3286cbfce2
|
@ -270,10 +270,8 @@ public class PrefsActivity extends FragmentActivity {
|
||||||
break;
|
break;
|
||||||
case R.string.prefs_show_notification_header: //app pref
|
case R.string.prefs_show_notification_header: //app pref
|
||||||
appPrefs.setShowNotification(isSet);
|
appPrefs.setShowNotification(isSet);
|
||||||
try{
|
if(isSet) ClientNotification.getInstance(getApplicationContext()).update();
|
||||||
if(isSet) ClientNotification.getInstance(getApplicationContext()).update(Monitor.getClientStatus());
|
else ClientNotification.getInstance(getApplicationContext()).cancel();
|
||||||
else ClientNotification.getInstance(getApplicationContext()).cancel();
|
|
||||||
} catch(Exception e) {if(Logging.WARNING) Log.d(Logging.TAG, "PrefsActivity: enabling notification failed");}
|
|
||||||
updateBoolPref(ID, isSet);
|
updateBoolPref(ID, isSet);
|
||||||
updateLayout();
|
updateLayout();
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -21,6 +21,7 @@ public class ClientNotification {
|
||||||
private NotificationManager nm;
|
private NotificationManager nm;
|
||||||
private Integer notificationId;
|
private Integer notificationId;
|
||||||
private PendingIntent contentIntent;
|
private PendingIntent contentIntent;
|
||||||
|
private Notification n = null;
|
||||||
|
|
||||||
private int mOldComputingStatus = -1;
|
private int mOldComputingStatus = -1;
|
||||||
private int mOldSuspendReason = -1;
|
private int mOldSuspendReason = -1;
|
||||||
|
@ -52,43 +53,43 @@ public class ClientNotification {
|
||||||
/**
|
/**
|
||||||
* Updates notification with client's current status
|
* Updates notification with client's current status
|
||||||
*/
|
*/
|
||||||
public synchronized void update(ClientStatus updatedStatus) {
|
public synchronized void update() {
|
||||||
|
try {
|
||||||
// during computation, setForeground is in charge of the notification
|
ClientStatus updatedStatus = Monitor.getClientStatus();
|
||||||
if(foreground) return;
|
|
||||||
|
|
||||||
// check whether notification is allowed in preferences
|
|
||||||
if (!Monitor.getAppPrefs().getShowNotification()) return;
|
|
||||||
|
|
||||||
// update notification, only after change in status
|
|
||||||
if (clientNotification.mOldComputingStatus == -1
|
|
||||||
|| updatedStatus.computingStatus.intValue() != clientNotification.mOldComputingStatus
|
|
||||||
|| (updatedStatus.computingStatus == ClientStatus.COMPUTING_STATUS_SUSPENDED
|
|
||||||
&& updatedStatus.computingSuspendReason != clientNotification.mOldSuspendReason)) {
|
|
||||||
|
|
||||||
// update notification
|
// update notification, only after change in status
|
||||||
nm.notify(notificationId, buildNotification(updatedStatus));
|
if (clientNotification.mOldComputingStatus == -1
|
||||||
|
|| updatedStatus.computingStatus.intValue() != clientNotification.mOldComputingStatus
|
||||||
// save status for comparison next time
|
|| (updatedStatus.computingStatus == ClientStatus.COMPUTING_STATUS_SUSPENDED
|
||||||
clientNotification.mOldComputingStatus = updatedStatus.computingStatus;
|
&& updatedStatus.computingSuspendReason != clientNotification.mOldSuspendReason)) {
|
||||||
clientNotification.mOldSuspendReason = updatedStatus.computingSuspendReason;
|
|
||||||
}
|
buildNotification(updatedStatus);
|
||||||
|
|
||||||
|
// update notification
|
||||||
|
if(foreground || Monitor.getAppPrefs().getShowNotification()) nm.notify(notificationId, n);
|
||||||
|
|
||||||
|
// save status for comparison next time
|
||||||
|
clientNotification.mOldComputingStatus = updatedStatus.computingStatus;
|
||||||
|
clientNotification.mOldSuspendReason = updatedStatus.computingSuspendReason;
|
||||||
|
}
|
||||||
|
} catch (Exception e) {if(Logging.WARNING) Log.d(Logging.TAG, "ClientNotification.update failed.");}
|
||||||
}
|
}
|
||||||
|
|
||||||
// called by Monitor to enable foreground with notification
|
// called by Monitor to enable foreground with notification
|
||||||
public synchronized void setForeground(Boolean setForeground, Boolean updated, ClientStatus status, Monitor service) {
|
public synchronized void setForeground(Boolean setForeground, Monitor service) {
|
||||||
if((foreground != setForeground) || updated) {
|
if(foreground != setForeground) {
|
||||||
if(setForeground) {
|
if(setForeground) {
|
||||||
// cancel suspend notification
|
// check whether notification is available
|
||||||
cancel();
|
if (n == null) update();
|
||||||
// set service foreground
|
// set service foreground
|
||||||
service.startForeground(1337, buildNotification(status));
|
service.startForeground(notificationId, n);
|
||||||
if(Logging.DEBUG) Log.d(Logging.TAG,"ClientNotification.setForeground() start service as foreground.");
|
if(Logging.DEBUG) Log.d(Logging.TAG,"ClientNotification.setForeground() start service as foreground.");
|
||||||
foreground = true;
|
foreground = true;
|
||||||
} else {
|
} else {
|
||||||
// set service background
|
// set service background
|
||||||
foreground = false;
|
foreground = false;
|
||||||
service.stopForeground(true);
|
Boolean remove = !Monitor.getAppPrefs().getShowNotification();
|
||||||
|
service.stopForeground(remove);
|
||||||
if(Logging.DEBUG) Log.d(Logging.TAG,"ClientNotification.setForeground() stop service as foreground.");
|
if(Logging.DEBUG) Log.d(Logging.TAG,"ClientNotification.setForeground() stop service as foreground.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -107,7 +108,7 @@ public class ClientNotification {
|
||||||
String statusText = status.getCurrentStatusString();
|
String statusText = status.getCurrentStatusString();
|
||||||
|
|
||||||
// build notification
|
// build notification
|
||||||
Notification n = new NotificationCompat.Builder(context)
|
n = new NotificationCompat.Builder(context)
|
||||||
.setContentTitle(context.getString(R.string.app_name))
|
.setContentTitle(context.getString(R.string.app_name))
|
||||||
.setContentText(statusText)
|
.setContentText(statusText)
|
||||||
.setSmallIcon(getIcon(computingStatus))
|
.setSmallIcon(getIcon(computingStatus))
|
||||||
|
|
|
@ -356,16 +356,19 @@ public class Monitor extends Service {
|
||||||
private void readClientStatus(Boolean forceCompleteUpdate) {
|
private void readClientStatus(Boolean forceCompleteUpdate) {
|
||||||
try{
|
try{
|
||||||
// read ccStatus and adjust wakelocks and service state independently of screen status
|
// read ccStatus and adjust wakelocks and service state independently of screen status
|
||||||
|
// wake locks and foreground enabled when Client is not suspended, therefore also during
|
||||||
|
// idle.
|
||||||
CcStatus status = rpc.getCcStatus();
|
CcStatus status = rpc.getCcStatus();
|
||||||
Boolean computing = (status.task_suspend_reason == BOINCDefs.SUSPEND_NOT_SUSPENDED);
|
Boolean computing = (status.task_suspend_reason == BOINCDefs.SUSPEND_NOT_SUSPENDED);
|
||||||
if(Logging.VERBOSE) Log.d(Logging.TAG,"readClientStatus(): computation enabled: " + computing);
|
if(Logging.VERBOSE) Log.d(Logging.TAG,"readClientStatus(): computation enabled: " + computing);
|
||||||
Monitor.getClientStatus().setWifiLock(computing);
|
Monitor.getClientStatus().setWifiLock(computing);
|
||||||
Monitor.getClientStatus().setWakeLock(computing);
|
Monitor.getClientStatus().setWakeLock(computing);
|
||||||
|
ClientNotification.getInstance(getApplicationContext()).setForeground(computing, this);
|
||||||
|
|
||||||
// complete status read, depending on screen status
|
// complete status read, depending on screen status
|
||||||
// screen off: only read computing status to adjust wakelock, do not send broadcast
|
// screen off: only read computing status to adjust wakelock, do not send broadcast
|
||||||
// screen on: read complete status, set ClientStatus, send broadcast
|
// screen on: read complete status, set ClientStatus, send broadcast
|
||||||
Boolean completeUpdate = false;
|
// forceCompleteUpdate: read complete status, independently of screen setting
|
||||||
if(screenOn || forceCompleteUpdate) {
|
if(screenOn || forceCompleteUpdate) {
|
||||||
// complete status read, with broadcast
|
// complete status read, with broadcast
|
||||||
if(Logging.VERBOSE) Log.d(Logging.TAG, "readClientStatus(): screen on, get complete status");
|
if(Logging.VERBOSE) Log.d(Logging.TAG, "readClientStatus(): screen on, get complete status");
|
||||||
|
@ -375,8 +378,7 @@ public class Monitor extends Service {
|
||||||
if( (status != null) && (state != null) && (state.results != null) && (state.projects != null) && (transfers != null) && (state.host_info != null)) {
|
if( (status != null) && (state != null) && (state.results != null) && (state.projects != null) && (transfers != null) && (state.host_info != null)) {
|
||||||
Monitor.getClientStatus().setClientStatus(status, state.results, state.projects, transfers, state.host_info);
|
Monitor.getClientStatus().setClientStatus(status, state.results, state.projects, transfers, state.host_info);
|
||||||
// Update status bar notification
|
// Update status bar notification
|
||||||
ClientNotification.getInstance(getApplicationContext()).update(Monitor.getClientStatus());
|
ClientNotification.getInstance(getApplicationContext()).update();
|
||||||
completeUpdate = true;
|
|
||||||
} else {
|
} else {
|
||||||
if(Logging.ERROR) Log.e(Logging.TAG, "readClientStatus(): connection problem");
|
if(Logging.ERROR) Log.e(Logging.TAG, "readClientStatus(): connection problem");
|
||||||
}
|
}
|
||||||
|
@ -388,9 +390,6 @@ public class Monitor extends Service {
|
||||||
getApplicationContext().sendBroadcast(clientStatus);
|
getApplicationContext().sendBroadcast(clientStatus);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// set service foreground notification, after initial data retrieval in ClientStatus
|
|
||||||
ClientNotification.getInstance(getApplicationContext()).setForeground(computing, completeUpdate, Monitor.getClientStatus(), this);
|
|
||||||
|
|
||||||
}catch(Exception e) {
|
}catch(Exception e) {
|
||||||
if(Logging.ERROR) Log.e(Logging.TAG, "Monitor.readClientStatus excpetion: " + e.getMessage(),e);
|
if(Logging.ERROR) Log.e(Logging.TAG, "Monitor.readClientStatus excpetion: " + e.getMessage(),e);
|
||||||
|
|
Loading…
Reference in New Issue