1
0
mirror of https://codeberg.org/Freeyourgadget/Gadgetbridge synced 2025-01-13 11:17:33 +01:00

Unify SleepMonitor with code from PR #59. Thanks Daniele!

This commit is contained in:
Andreas Shimokawa 2015-06-05 19:32:09 +02:00
parent 2f1908e480
commit 813a02d5c7
3 changed files with 59 additions and 21 deletions

View File

@ -4,7 +4,9 @@ public class GBActivitySample {
public static final byte PROVIDER_MIBAND = 0; public static final byte PROVIDER_MIBAND = 0;
public static final byte PROVIDER_PEBBLE_MORPHEUZ = 1; public static final byte PROVIDER_PEBBLE_MORPHEUZ = 1;
public static final byte TYPE_SLEEP = 0; //FIXME: we could just adapt to Mi Band (Dont know the correct values) public static final byte TYPE_DEEP_SLEEP = 5;
public static final byte TYPE_LIGHT_SLEEP = 4;
public static final byte TYPE_UNKNOWN = -1;
// add more here // add more here
private final int timestamp; private final int timestamp;

View File

@ -96,9 +96,27 @@ public class SleepMonitorActivity extends Activity implements SurfaceHolder.Call
int height = canvas.getHeight(); int height = canvas.getHeight();
RectF r = new RectF(0.0f, 0.0f, 0.0f, height); RectF r = new RectF(0.0f, 0.0f, 0.0f, height);
short last_movement = 5000; float movement_divisor;
boolean annotate;
boolean use_steps_as_movement;
switch (provider) {
case GBActivitySample.PROVIDER_MIBAND:
movement_divisor = 256.0f;
annotate = false; // sample density to high?
use_steps_as_movement = true;
break;
default: // Morpheuz
movement_divisor = 5000.0f;
annotate = true;
use_steps_as_movement = false;
break;
}
byte last_type = GBActivitySample.TYPE_UNKNOWN;
for (int i = 0; i < samples.size(); i++) { for (int i = 0; i < samples.size(); i++) {
GBActivitySample sample = samples.get(i); GBActivitySample sample = samples.get(i);
byte type = sample.getType();
if (i == 0) { if (i == 0) {
cal.setTimeInMillis((long) sample.getTimestamp() * 1000L); cal.setTimeInMillis((long) sample.getTimestamp() * 1000L);
@ -109,30 +127,42 @@ public class SleepMonitorActivity extends Activity implements SurfaceHolder.Call
date = cal.getTime(); date = cal.getTime();
dateStringTo = new SimpleDateFormat("dd.MM.yyyy HH:mm").format(date); dateStringTo = new SimpleDateFormat("dd.MM.yyyy HH:mm").format(date);
} }
boolean annotate = false;
short movement = sample.getIntensity(); short movement = sample.getIntensity();
r.left = r.right; r.left = r.right;
r.right = (float) (i + 1) / (samples.size()) * width; r.right = (float) (i + 1) / (samples.size()) * width;
r.top = (1.0f - (float) movement / 5000.0f) * height; if (type == GBActivitySample.TYPE_DEEP_SLEEP) {
if (movement > 1000) { paint.setColor(Color.BLUE);
paint.setColor(Color.RED); r.top = 0.98f * height;
if (last_movement <= 1000) {
annotate = true;
}
} else if (movement > 120) {
paint.setColor(Color.YELLOW);
} else { } else {
paint.setColor(Color.GREEN); if (type == GBActivitySample.TYPE_LIGHT_SLEEP) {
paint.setColor(Color.CYAN);
} else {
if (use_steps_as_movement) {
movement = sample.getSteps();
} }
paint.setColor(Color.YELLOW);
}
r.top = (1.0f - (float) movement / movement_divisor) * height;
}
canvas.drawRect(r, paint); canvas.drawRect(r, paint);
boolean annotate_this = false;
if (annotate) { if (annotate) {
if (type != GBActivitySample.TYPE_DEEP_SLEEP && type != GBActivitySample.TYPE_LIGHT_SLEEP &&
(last_type == GBActivitySample.TYPE_DEEP_SLEEP || last_type == GBActivitySample.TYPE_LIGHT_SLEEP)) {
// seems that we woke up
annotate_this = true;
}
if (annotate_this) {
cal.setTimeInMillis((long) (sample.getTimestamp()) * 1000L); cal.setTimeInMillis((long) (sample.getTimestamp()) * 1000L);
date = cal.getTime(); date = cal.getTime();
String dateString = new SimpleDateFormat("HH:mm").format(date); String dateString = new SimpleDateFormat("HH:mm").format(date);
paint.setColor(Color.WHITE); paint.setColor(Color.WHITE);
canvas.drawText(dateString, r.left - 20, r.top - 20, paint); canvas.drawText(dateString, r.left - 20, r.top - 20, paint);
} }
last_movement = movement; last_type = type;
}
} }
textView.setText(dateStringFrom + " to " + dateStringTo); textView.setText(dateStringFrom + " to " + dateStringTo);

View File

@ -98,10 +98,16 @@ public class MorpheuzSupport {
ctrl_message = MorpheuzSupport.CTRL_VERSION_DONE | MorpheuzSupport.CTRL_GONEOFF_DONE | MorpheuzSupport.CTRL_TRANSMIT_DONE | MorpheuzSupport.CTRL_SET_LAST_SENT; ctrl_message = MorpheuzSupport.CTRL_VERSION_DONE | MorpheuzSupport.CTRL_GONEOFF_DONE | MorpheuzSupport.CTRL_TRANSMIT_DONE | MorpheuzSupport.CTRL_SET_LAST_SENT;
} else { } else {
short index = (short) ((int) pair.second >> 16); short index = (short) ((int) pair.second >> 16);
short data = (short) ((int) pair.second & 0xffff); short intensity = (short) ((int) pair.second & 0xffff);
LOG.info("got point:" + index + " " + data); LOG.info("got point:" + index + " " + intensity);
byte type = GBActivitySample.TYPE_UNKNOWN;
if (intensity <= 120) {
type = GBActivitySample.TYPE_DEEP_SLEEP;
} else if (intensity <= 1000) {
type = GBActivitySample.TYPE_LIGHT_SLEEP;
}
if (index >= 0 && index < 54) { if (index >= 0 && index < 54) {
GBApplication.getActivityDatabaseHandler().addGBActivitySample(recording_base_timestamp + index * 600, GBActivitySample.PROVIDER_PEBBLE_MORPHEUZ, data, (byte) 0, GBActivitySample.TYPE_SLEEP); GBApplication.getActivityDatabaseHandler().addGBActivitySample(recording_base_timestamp + index * 600, GBActivitySample.PROVIDER_PEBBLE_MORPHEUZ, intensity, (byte) 0, type);
} }
ctrl_message = MorpheuzSupport.CTRL_VERSION_DONE | MorpheuzSupport.CTRL_SET_LAST_SENT | MorpheuzSupport.CTRL_DO_NEXT; ctrl_message = MorpheuzSupport.CTRL_VERSION_DONE | MorpheuzSupport.CTRL_SET_LAST_SENT | MorpheuzSupport.CTRL_DO_NEXT;