mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge
synced 2025-01-14 11:47:32 +01:00
Colmi R0x: Fix sleep gap at midnight in dashboard today widget
This commit is contained in:
parent
ea41bbd1a9
commit
e8c295df51
@ -146,12 +146,21 @@ public class ColmiActivitySampleProvider extends AbstractSampleProvider<ColmiAct
|
|||||||
final ColmiSleepStageSampleProvider sleepStageSampleProvider = new ColmiSleepStageSampleProvider(getDevice(), getSession());
|
final ColmiSleepStageSampleProvider sleepStageSampleProvider = new ColmiSleepStageSampleProvider(getDevice(), getSession());
|
||||||
final List<ColmiSleepStageSample> sleepStageSamples = sleepStageSampleProvider.getAllSamples(timestamp_from * 1000L, timestamp_to * 1000L);
|
final List<ColmiSleepStageSample> sleepStageSamples = sleepStageSampleProvider.getAllSamples(timestamp_from * 1000L, timestamp_to * 1000L);
|
||||||
|
|
||||||
|
// Retrieve the last stage before this time range, as the user could have been asleep during
|
||||||
|
// the range transition
|
||||||
|
final ColmiSleepStageSample lastSleepStageBeforeRange = sleepStageSampleProvider.getLastSampleBefore(timestamp_from * 1000L);
|
||||||
|
if (lastSleepStageBeforeRange != null && (lastSleepStageBeforeRange.getTimestamp() + lastSleepStageBeforeRange.getDuration() * 1000L > timestamp_from)) {
|
||||||
|
LOG.debug("Last sleep stage before range: ts={}, stage={}", lastSleepStageBeforeRange.getTimestamp(), lastSleepStageBeforeRange.getStage());
|
||||||
|
sleepStageSamples.add(0, lastSleepStageBeforeRange);
|
||||||
|
}
|
||||||
|
|
||||||
for (final ColmiSleepStageSample sleepStageSample : sleepStageSamples) {
|
for (final ColmiSleepStageSample sleepStageSample : sleepStageSamples) {
|
||||||
final ActivityKind sleepRawKind = sleepStageToActivityKind(sleepStageSample.getStage());
|
final ActivityKind sleepRawKind = sleepStageToActivityKind(sleepStageSample.getStage());
|
||||||
if (sleepRawKind == ActivityKind.AWAKE_SLEEP) continue;
|
if (sleepRawKind == ActivityKind.AWAKE_SLEEP) continue;
|
||||||
// round to the nearest minute, we don't need per-second granularity
|
// round to the nearest minute, we don't need per-second granularity
|
||||||
final int tsSeconds = (int) ((sleepStageSample.getTimestamp() / 1000) / 60) * 60;
|
final int tsSeconds = (int) ((sleepStageSample.getTimestamp() / 1000) / 60) * 60;
|
||||||
for (int i = tsSeconds; i < tsSeconds + sleepStageSample.getDuration() * 60; i += 60) {
|
for (int i = tsSeconds; i < tsSeconds + sleepStageSample.getDuration() * 60; i += 60) {
|
||||||
|
if (i < timestamp_from) continue;
|
||||||
ColmiActivitySample sample = sampleByTs.get(i);
|
ColmiActivitySample sample = sampleByTs.get(i);
|
||||||
if (sample == null) {
|
if (sample == null) {
|
||||||
sample = new ColmiActivitySample();
|
sample = new ColmiActivitySample();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user