2020-01-09 10:44:32 +01:00
|
|
|
/* Copyright (C) 2019-2020 Andreas Shimokawa, vanous
|
2019-08-13 19:54:18 +02:00
|
|
|
|
|
|
|
This file is part of Gadgetbridge.
|
|
|
|
|
|
|
|
Gadgetbridge is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU Affero General Public License as published
|
|
|
|
by the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
Gadgetbridge is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU Affero General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
|
|
|
package nodomain.freeyourgadget.gadgetbridge.model;
|
|
|
|
|
|
|
|
import android.content.Context;
|
|
|
|
import android.widget.Toast;
|
|
|
|
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
|
|
|
import java.util.Calendar;
|
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.activities.charts.ActivityAnalysis;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.database.DBHandler;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.devices.DeviceCoordinator;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.devices.SampleProvider;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.entities.AbstractActivitySample;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.util.DeviceHelper;
|
|
|
|
import nodomain.freeyourgadget.gadgetbridge.util.GB;
|
|
|
|
|
|
|
|
|
|
|
|
public class DailyTotals {
|
2019-09-01 22:35:02 +02:00
|
|
|
private static final Logger LOG = LoggerFactory.getLogger(DailyTotals.class);
|
2019-08-13 19:54:18 +02:00
|
|
|
|
|
|
|
|
2020-02-26 22:37:18 +01:00
|
|
|
public long[] getDailyTotalsForAllDevices(Calendar day) {
|
2019-08-13 19:54:18 +02:00
|
|
|
Context context = GBApplication.getContext();
|
|
|
|
//get today's steps for all devices in GB
|
2020-02-26 22:37:18 +01:00
|
|
|
long all_steps = 0;
|
|
|
|
long all_sleep = 0;
|
2019-08-13 19:54:18 +02:00
|
|
|
|
|
|
|
if (context instanceof GBApplication) {
|
|
|
|
GBApplication gbApp = (GBApplication) context;
|
|
|
|
List<? extends GBDevice> devices = gbApp.getDeviceManager().getDevices();
|
|
|
|
for (GBDevice device : devices) {
|
2019-09-01 22:35:02 +02:00
|
|
|
DeviceCoordinator coordinator = DeviceHelper.getInstance().getCoordinator(device);
|
2020-09-17 21:34:03 +02:00
|
|
|
if (!coordinator.supportsActivityDataFetching() && !coordinator.supportsActivityTracking()) {
|
2019-09-01 22:35:02 +02:00
|
|
|
continue;
|
|
|
|
}
|
2020-02-26 22:37:18 +01:00
|
|
|
long[] all_daily = getDailyTotalsForDevice(device, day);
|
2019-08-13 19:54:18 +02:00
|
|
|
all_steps += all_daily[0];
|
|
|
|
all_sleep += all_daily[1] + all_daily[2];
|
|
|
|
}
|
|
|
|
}
|
2020-09-17 21:34:03 +02:00
|
|
|
//LOG.debug("gbwidget daily totals, all steps:" + all_steps);
|
|
|
|
//LOG.debug("gbwidget daily totals, all sleep:" + all_sleep);
|
2020-02-26 22:37:18 +01:00
|
|
|
return new long[]{all_steps, all_sleep};
|
2019-08-13 19:54:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-02-26 22:37:18 +01:00
|
|
|
public long[] getDailyTotalsForDevice(GBDevice device, Calendar day) {
|
2019-08-13 19:54:18 +02:00
|
|
|
|
|
|
|
try (DBHandler handler = GBApplication.acquireDB()) {
|
|
|
|
ActivityAnalysis analysis = new ActivityAnalysis();
|
2019-09-01 22:35:02 +02:00
|
|
|
ActivityAmounts amountsSteps;
|
|
|
|
ActivityAmounts amountsSleep;
|
2019-08-13 19:54:18 +02:00
|
|
|
|
|
|
|
amountsSteps = analysis.calculateActivityAmounts(getSamplesOfDay(handler, day, 0, device));
|
|
|
|
amountsSleep = analysis.calculateActivityAmounts(getSamplesOfDay(handler, day, -12, device));
|
|
|
|
|
2020-02-26 22:37:18 +01:00
|
|
|
long[] sleep = getTotalsSleepForActivityAmounts(amountsSleep);
|
|
|
|
long steps = getTotalsStepsForActivityAmounts(amountsSteps);
|
2019-08-13 19:54:18 +02:00
|
|
|
|
2020-02-26 22:37:18 +01:00
|
|
|
return new long[]{steps, sleep[0], sleep[1]};
|
2019-08-13 19:54:18 +02:00
|
|
|
|
|
|
|
} catch (Exception e) {
|
|
|
|
|
|
|
|
GB.toast("Error loading activity summaries.", Toast.LENGTH_SHORT, GB.ERROR, e);
|
2020-02-26 22:37:18 +01:00
|
|
|
return new long[]{0, 0, 0};
|
2019-08-13 19:54:18 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-02-26 22:37:18 +01:00
|
|
|
private long[] getTotalsSleepForActivityAmounts(ActivityAmounts activityAmounts) {
|
2019-08-13 19:54:18 +02:00
|
|
|
long totalSecondsDeepSleep = 0;
|
|
|
|
long totalSecondsLightSleep = 0;
|
|
|
|
for (ActivityAmount amount : activityAmounts.getAmounts()) {
|
|
|
|
if (amount.getActivityKind() == ActivityKind.TYPE_DEEP_SLEEP) {
|
|
|
|
totalSecondsDeepSleep += amount.getTotalSeconds();
|
|
|
|
} else if (amount.getActivityKind() == ActivityKind.TYPE_LIGHT_SLEEP) {
|
|
|
|
totalSecondsLightSleep += amount.getTotalSeconds();
|
|
|
|
}
|
|
|
|
}
|
2020-02-26 22:37:18 +01:00
|
|
|
long totalMinutesDeepSleep = (totalSecondsDeepSleep / 60);
|
|
|
|
long totalMinutesLightSleep = (totalSecondsLightSleep / 60);
|
|
|
|
return new long[]{totalMinutesDeepSleep, totalMinutesLightSleep};
|
2019-08-13 19:54:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-08-07 09:21:14 +02:00
|
|
|
public long getTotalsStepsForActivityAmounts(ActivityAmounts activityAmounts) {
|
2020-02-26 22:37:18 +01:00
|
|
|
long totalSteps = 0;
|
2019-08-13 19:54:18 +02:00
|
|
|
|
|
|
|
for (ActivityAmount amount : activityAmounts.getAmounts()) {
|
|
|
|
totalSteps += amount.getTotalSteps();
|
|
|
|
}
|
2019-09-01 22:48:52 +02:00
|
|
|
return totalSteps;
|
2019-08-13 19:54:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private List<? extends ActivitySample> getSamplesOfDay(DBHandler db, Calendar day, int offsetHours, GBDevice device) {
|
|
|
|
int startTs;
|
|
|
|
int endTs;
|
|
|
|
|
|
|
|
day = (Calendar) day.clone(); // do not modify the caller's argument
|
|
|
|
day.set(Calendar.HOUR_OF_DAY, 0);
|
|
|
|
day.set(Calendar.MINUTE, 0);
|
|
|
|
day.set(Calendar.SECOND, 0);
|
|
|
|
day.add(Calendar.HOUR, offsetHours);
|
|
|
|
|
|
|
|
startTs = (int) (day.getTimeInMillis() / 1000);
|
|
|
|
endTs = startTs + 24 * 60 * 60 - 1;
|
|
|
|
|
|
|
|
return getSamples(db, device, startTs, endTs);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-08-07 09:21:14 +02:00
|
|
|
public List<? extends ActivitySample> getSamples(DBHandler db, GBDevice device, int tsFrom, int tsTo) {
|
2019-08-13 19:54:18 +02:00
|
|
|
return getAllSamples(db, device, tsFrom, tsTo);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
protected SampleProvider<? extends AbstractActivitySample> getProvider(DBHandler db, GBDevice device) {
|
|
|
|
DeviceCoordinator coordinator = DeviceHelper.getInstance().getCoordinator(device);
|
|
|
|
return coordinator.getSampleProvider(device, db.getDaoSession());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
protected List<? extends ActivitySample> getAllSamples(DBHandler db, GBDevice device, int tsFrom, int tsTo) {
|
|
|
|
SampleProvider<? extends ActivitySample> provider = getProvider(db, device);
|
|
|
|
return provider.getAllActivitySamples(tsFrom, tsTo);
|
|
|
|
}
|
|
|
|
}
|