Mi1: Attempt at throttling notifications during sync #438
This commit is contained in:
parent
4925dec9f6
commit
999d3e3252
|
@ -55,6 +55,7 @@ public class FetchActivityOperation extends AbstractMiBand1Operation {
|
||||||
private final boolean hasExtendedActivityData;
|
private final boolean hasExtendedActivityData;
|
||||||
|
|
||||||
private static class ActivityStruct {
|
private static class ActivityStruct {
|
||||||
|
private int lastNotifiedProgress;
|
||||||
private final byte[] activityDataHolder;
|
private final byte[] activityDataHolder;
|
||||||
private final int activityDataHolderSize;
|
private final int activityDataHolderSize;
|
||||||
//index of the buffer above
|
//index of the buffer above
|
||||||
|
@ -129,6 +130,7 @@ public class FetchActivityOperation extends AbstractMiBand1Operation {
|
||||||
public void bufferFlushed(int minutes) {
|
public void bufferFlushed(int minutes) {
|
||||||
activityDataTimestampProgress.add(Calendar.MINUTE, minutes);
|
activityDataTimestampProgress.add(Calendar.MINUTE, minutes);
|
||||||
activityDataHolderProgress = 0;
|
activityDataHolderProgress = 0;
|
||||||
|
lastNotifiedProgress = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -199,9 +201,16 @@ public class FetchActivityOperation extends AbstractMiBand1Operation {
|
||||||
} else {
|
} else {
|
||||||
bufferActivityData(value);
|
bufferActivityData(value);
|
||||||
}
|
}
|
||||||
|
if (LOG.isDebugEnabled()) {
|
||||||
LOG.debug("activity data: length: " + value.length + ", remaining bytes: " + activityStruct.activityDataRemainingBytes);
|
LOG.debug("activity data: length: " + value.length + ", remaining bytes: " + activityStruct.activityDataRemainingBytes);
|
||||||
|
}
|
||||||
|
|
||||||
GB.updateTransferNotification(getContext().getString(R.string.busy_task_fetch_activity_data), true, (int) (((float) (activityStruct.activityDataUntilNextHeader - activityStruct.activityDataRemainingBytes)) / activityStruct.activityDataUntilNextHeader * 100), getContext());
|
int progress = (int) (((float) (activityStruct.activityDataUntilNextHeader - activityStruct.activityDataRemainingBytes)) / activityStruct.activityDataUntilNextHeader * 100);
|
||||||
|
// avoid too many notifications overloading the system
|
||||||
|
if (progress - activityStruct.lastNotifiedProgress >= 8) {
|
||||||
|
activityStruct.lastNotifiedProgress = progress;
|
||||||
|
GB.updateTransferNotification(getContext().getString(R.string.busy_task_fetch_activity_data), true, progress, getContext());
|
||||||
|
}
|
||||||
|
|
||||||
if (activityStruct.isBlockFinished()) {
|
if (activityStruct.isBlockFinished()) {
|
||||||
sendAckDataTransfer(activityStruct.activityDataTimestampToAck, activityStruct.activityDataUntilNextHeader);
|
sendAckDataTransfer(activityStruct.activityDataTimestampToAck, activityStruct.activityDataUntilNextHeader);
|
||||||
|
|
Loading…
Reference in New Issue