Cleanup, use fragment based charts (WIP #45)
Known issue: scrolling a zoomed-in chart interferes with swiping to the next/previous chart (so far there's just one, but...) Workaround: Swipe down and then left or right in one go, this will let you scroll the zoomed chart
This commit is contained in:
parent
7c61bbb2be
commit
a6e26e5ddc
|
@ -59,13 +59,6 @@
|
||||||
android:name="android.support.PARENT_ACTIVITY"
|
android:name="android.support.PARENT_ACTIVITY"
|
||||||
android:value=".ControlCenter" />
|
android:value=".ControlCenter" />
|
||||||
</activity>
|
</activity>
|
||||||
<activity
|
|
||||||
android:name=".activities.SleepChartActivity"
|
|
||||||
android:label="@string/title_activity_sleepmonitor">
|
|
||||||
<meta-data
|
|
||||||
android:name="android.support.PARENT_ACTIVITY"
|
|
||||||
android:value=".ControlCenter" />
|
|
||||||
</activity>
|
|
||||||
<activity
|
<activity
|
||||||
android:name=".pebble.PebbleAppInstallerActivity"
|
android:name=".pebble.PebbleAppInstallerActivity"
|
||||||
android:label="@string/title_activity_appinstaller">
|
android:label="@string/title_activity_appinstaller">
|
||||||
|
|
|
@ -18,7 +18,7 @@ import java.io.File;
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
|
||||||
import nodomain.freeyourgadget.gadgetbridge.activities.SleepChartActivity;
|
import nodomain.freeyourgadget.gadgetbridge.activities.AbstractChartFragment;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEvent;
|
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEvent;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventAppInfo;
|
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventAppInfo;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventCallControl;
|
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventCallControl;
|
||||||
|
@ -142,7 +142,7 @@ public abstract class AbstractDeviceSupport implements DeviceSupport {
|
||||||
public void handleGBDeviceEvent(GBDeviceEventSleepMonitorResult sleepMonitorResult) {
|
public void handleGBDeviceEvent(GBDeviceEventSleepMonitorResult sleepMonitorResult) {
|
||||||
Context context = getContext();
|
Context context = getContext();
|
||||||
LOG.info("Got event for SLEEP_MONIOR_RES");
|
LOG.info("Got event for SLEEP_MONIOR_RES");
|
||||||
Intent sleepMontiorIntent = new Intent(SleepChartActivity.ACTION_REFRESH);
|
Intent sleepMontiorIntent = new Intent(AbstractChartFragment.ACTION_REFRESH);
|
||||||
sleepMontiorIntent.putExtra("smartalarm_from", sleepMonitorResult.smartalarm_from);
|
sleepMontiorIntent.putExtra("smartalarm_from", sleepMonitorResult.smartalarm_from);
|
||||||
sleepMontiorIntent.putExtra("smartalarm_to", sleepMonitorResult.smartalarm_to);
|
sleepMontiorIntent.putExtra("smartalarm_to", sleepMonitorResult.smartalarm_to);
|
||||||
sleepMontiorIntent.putExtra("recording_base_timestamp", sleepMonitorResult.recording_base_timestamp);
|
sleepMontiorIntent.putExtra("recording_base_timestamp", sleepMonitorResult.recording_base_timestamp);
|
||||||
|
|
|
@ -29,8 +29,8 @@ import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.activities.ChartsActivity;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.activities.ConfigureAlarms;
|
import nodomain.freeyourgadget.gadgetbridge.activities.ConfigureAlarms;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.activities.SleepChartActivity;
|
|
||||||
import nodomain.freeyourgadget.gadgetbridge.adapter.GBDeviceAdapter;
|
import nodomain.freeyourgadget.gadgetbridge.adapter.GBDeviceAdapter;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.discovery.DiscoveryActivity;
|
import nodomain.freeyourgadget.gadgetbridge.discovery.DiscoveryActivity;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.miband.MiBandConst;
|
import nodomain.freeyourgadget.gadgetbridge.miband.MiBandConst;
|
||||||
|
@ -195,8 +195,8 @@ public class ControlCenter extends Activity {
|
||||||
case R.id.controlcenter_start_sleepmonitor:
|
case R.id.controlcenter_start_sleepmonitor:
|
||||||
if (selectedDevice != null) {
|
if (selectedDevice != null) {
|
||||||
Intent startIntent;
|
Intent startIntent;
|
||||||
startIntent = new Intent(ControlCenter.this, SleepChartActivity.class);
|
// startIntent = new Intent(ControlCenter.this, SleepChartActivity.class);
|
||||||
// startIntent = new Intent(ControlCenter.this, ChartsActivity.class);
|
startIntent = new Intent(ControlCenter.this, ChartsActivity.class);
|
||||||
startIntent.putExtra("device", selectedDevice);
|
startIntent.putExtra("device", selectedDevice);
|
||||||
startActivity(startIntent);
|
startActivity(startIntent);
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,166 @@
|
||||||
|
package nodomain.freeyourgadget.gadgetbridge.activities;
|
||||||
|
|
||||||
|
import android.graphics.Color;
|
||||||
|
import android.support.v4.app.Fragment;
|
||||||
|
|
||||||
|
import com.github.mikephil.charting.charts.BarLineChartBase;
|
||||||
|
import com.github.mikephil.charting.charts.Chart;
|
||||||
|
import com.github.mikephil.charting.data.BarDataSet;
|
||||||
|
import com.github.mikephil.charting.data.BarEntry;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Calendar;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.GBActivitySample;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.GBDevice;
|
||||||
|
|
||||||
|
public class AbstractChartFragment extends Fragment {
|
||||||
|
public static final String ACTION_REFRESH
|
||||||
|
= "nodomain.freeyourgadget.gadgetbride.chart.action.refresh";
|
||||||
|
|
||||||
|
protected static final class ActivityKind {
|
||||||
|
public final byte type;
|
||||||
|
public final String label;
|
||||||
|
public final Integer color;
|
||||||
|
|
||||||
|
public ActivityKind(byte type, String label, Integer color) {
|
||||||
|
this.type = type;
|
||||||
|
this.label = label;
|
||||||
|
this.color = color;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected ActivityKind akActivity = new ActivityKind(GBActivitySample.TYPE_UNKNOWN, "Activity", Color.rgb(89, 178, 44));
|
||||||
|
protected ActivityKind akLightSleep = new ActivityKind(GBActivitySample.TYPE_LIGHT_SLEEP, "Light Sleep", Color.rgb(182, 191, 255));
|
||||||
|
protected ActivityKind akDeepSleep = new ActivityKind(GBActivitySample.TYPE_DEEP_SLEEP, "Deep Sleep", Color.rgb(76, 90, 255));
|
||||||
|
|
||||||
|
protected static final int BACKGROUND_COLOR = Color.rgb(24, 22, 24);
|
||||||
|
protected static final int DESCRIPTION_COLOR = Color.WHITE;
|
||||||
|
protected static final int CHART_TEXT_COLOR = Color.WHITE;
|
||||||
|
protected static final int LEGEND_TEXT_COLOR = Color.WHITE;
|
||||||
|
|
||||||
|
protected byte getProvider(GBDevice device) {
|
||||||
|
byte provider = -1;
|
||||||
|
switch (device.getType()) {
|
||||||
|
case MIBAND:
|
||||||
|
provider = GBActivitySample.PROVIDER_MIBAND;
|
||||||
|
break;
|
||||||
|
case PEBBLE:
|
||||||
|
provider = GBActivitySample.PROVIDER_PEBBLE_MORPHEUZ; // FIXME
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return provider;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected ArrayList<GBActivitySample> getSamples(GBDevice device, int tsFrom, int tsTo) {
|
||||||
|
if (tsFrom == -1) {
|
||||||
|
long ts = System.currentTimeMillis();
|
||||||
|
tsFrom = (int) ((ts / 1000) - (24 * 60 * 60) & 0xffffffff); // -24 hours
|
||||||
|
}
|
||||||
|
|
||||||
|
byte provider = getProvider(device);
|
||||||
|
return GBApplication.getActivityDatabaseHandler().getGBActivitySamples(tsFrom, tsTo, provider);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected ArrayList<GBActivitySample> getSleepSamples(GBDevice device, int tsFrom, int tsTo) {
|
||||||
|
if (tsFrom == -1) {
|
||||||
|
long ts = System.currentTimeMillis();
|
||||||
|
tsFrom = (int) ((ts / 1000) - (24 * 60 * 60) & 0xffffffff); // -24 hours
|
||||||
|
}
|
||||||
|
|
||||||
|
byte provider = getProvider(device);
|
||||||
|
return GBApplication.getActivityDatabaseHandler().getGBActivitySamples(tsFrom, tsTo, provider);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected ArrayList<GBActivitySample> getTestSamples(GBDevice device, int tsFrom, int tsTo) {
|
||||||
|
Calendar cal = Calendar.getInstance();
|
||||||
|
cal.clear();
|
||||||
|
cal.set(2015, Calendar.JUNE, 10, 6, 40);
|
||||||
|
// ignore provided date ranges
|
||||||
|
tsTo = (int) ((cal.getTimeInMillis() / 1000) & 0xffffffff);
|
||||||
|
tsFrom = tsTo - (24 * 60 * 60);
|
||||||
|
|
||||||
|
byte provider = getProvider(device);
|
||||||
|
return GBApplication.getActivityDatabaseHandler().getGBActivitySamples(tsFrom, tsTo, provider);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void configureChartDefaults(Chart<?> mChart) {
|
||||||
|
// if enabled, the chart will always start at zero on the y-axis
|
||||||
|
|
||||||
|
// disable value highlighting
|
||||||
|
mChart.setHighlightEnabled(false);
|
||||||
|
|
||||||
|
// enable touch gestures
|
||||||
|
mChart.setTouchEnabled(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void configureBarLineChartDefaults(BarLineChartBase<?> mChart) {
|
||||||
|
configureChartDefaults(mChart);
|
||||||
|
|
||||||
|
// enable scaling and dragging
|
||||||
|
mChart.setDragEnabled(true);
|
||||||
|
mChart.setScaleEnabled(true);
|
||||||
|
|
||||||
|
// if disabled, scaling can be done on x- and y-axis separately
|
||||||
|
// mChart.setPinchZoom(true);
|
||||||
|
|
||||||
|
mChart.setDrawGridBackground(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected BarEntry createBarEntry(float value, int index) {
|
||||||
|
return new BarEntry(value, index);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected BarDataSet createActivitySet(List<BarEntry> values, List<Integer> colors, String label) {
|
||||||
|
BarDataSet set1 = new BarDataSet(values, label);
|
||||||
|
set1.setColors(colors);
|
||||||
|
// set1.setDrawCubic(true);
|
||||||
|
// set1.setCubicIntensity(0.2f);
|
||||||
|
// //set1.setDrawFilled(true);
|
||||||
|
// set1.setDrawCircles(false);
|
||||||
|
// set1.setLineWidth(2f);
|
||||||
|
// set1.setCircleSize(5f);
|
||||||
|
// set1.setFillColor(ColorTemplate.getHoloBlue());
|
||||||
|
set1.setDrawValues(false);
|
||||||
|
// set1.setHighLightColor(Color.rgb(128, 0, 255));
|
||||||
|
// set1.setColor(Color.rgb(89, 178, 44));
|
||||||
|
set1.setValueTextColor(CHART_TEXT_COLOR);
|
||||||
|
return set1;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected BarDataSet createDeepSleepSet(List<BarEntry> values, String label) {
|
||||||
|
BarDataSet set1 = new BarDataSet(values, label);
|
||||||
|
// set1.setDrawCubic(true);
|
||||||
|
// set1.setCubicIntensity(0.2f);
|
||||||
|
// //set1.setDrawFilled(true);
|
||||||
|
// set1.setDrawCircles(false);
|
||||||
|
// set1.setLineWidth(2f);
|
||||||
|
// set1.setCircleSize(5f);
|
||||||
|
// set1.setFillColor(ColorTemplate.getHoloBlue());
|
||||||
|
set1.setDrawValues(false);
|
||||||
|
// set1.setHighLightColor(Color.rgb(244, 117, 117));
|
||||||
|
// set1.setColor(Color.rgb(76, 90, 255));
|
||||||
|
set1.setValueTextColor(CHART_TEXT_COLOR);
|
||||||
|
return set1;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected BarDataSet createLightSleepSet(List<BarEntry> values, String label) {
|
||||||
|
BarDataSet set1 = new BarDataSet(values, label);
|
||||||
|
|
||||||
|
// set1.setDrawCubic(true);
|
||||||
|
// set1.setCubicIntensity(0.2f);
|
||||||
|
// //set1.setDrawFilled(true);
|
||||||
|
// set1.setDrawCircles(false);
|
||||||
|
// set1.setLineWidth(2f);
|
||||||
|
// set1.setCircleSize(5f);
|
||||||
|
// set1.setFillColor(ColorTemplate.getHoloBlue());
|
||||||
|
set1.setDrawValues(false);
|
||||||
|
// set1.setHighLightColor(Color.rgb(244, 117, 117));
|
||||||
|
// set1.setColor(Color.rgb(182, 191, 255));
|
||||||
|
set1.setValueTextColor(CHART_TEXT_COLOR);
|
||||||
|
// set1.setColor(Color.CYAN);
|
||||||
|
return set1;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,15 +1,16 @@
|
||||||
package nodomain.freeyourgadget.gadgetbridge.activities;
|
package nodomain.freeyourgadget.gadgetbridge.activities;
|
||||||
|
|
||||||
import android.app.Activity;
|
|
||||||
import android.content.BroadcastReceiver;
|
import android.content.BroadcastReceiver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.IntentFilter;
|
import android.content.IntentFilter;
|
||||||
import android.graphics.Color;
|
import android.graphics.Color;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.support.v4.app.NavUtils;
|
import android.support.v4.app.Fragment;
|
||||||
import android.support.v4.content.LocalBroadcastManager;
|
import android.support.v4.content.LocalBroadcastManager;
|
||||||
import android.view.MenuItem;
|
import android.view.LayoutInflater;
|
||||||
|
import android.view.View;
|
||||||
|
import android.view.ViewGroup;
|
||||||
|
|
||||||
import com.github.mikephil.charting.animation.Easing;
|
import com.github.mikephil.charting.animation.Easing;
|
||||||
import com.github.mikephil.charting.charts.BarLineChartBase;
|
import com.github.mikephil.charting.charts.BarLineChartBase;
|
||||||
|
@ -33,27 +34,11 @@ import nodomain.freeyourgadget.gadgetbridge.GBActivitySample;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.GBDevice;
|
import nodomain.freeyourgadget.gadgetbridge.GBDevice;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.R;
|
import nodomain.freeyourgadget.gadgetbridge.R;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.charts.SleepUtils;
|
||||||
|
|
||||||
|
|
||||||
public class SleepChartActivity extends Activity {
|
public class ActivitySleepChartFragment extends AbstractChartFragment {
|
||||||
private static final float Y_VALUE_DEEP_SLEEP = 0.01f;
|
protected static final Logger LOG = LoggerFactory.getLogger(ActivitySleepChartFragment.class);
|
||||||
private static final float Y_VALUE_LIGHT_SLEEP = 0.016f;
|
|
||||||
|
|
||||||
private static final class ActivityKind {
|
|
||||||
public final byte type;
|
|
||||||
public final String label;
|
|
||||||
public final Integer color;
|
|
||||||
|
|
||||||
public ActivityKind(byte type, String label, Integer color) {
|
|
||||||
this.type = type;
|
|
||||||
this.label = label;
|
|
||||||
this.color = color;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final String ACTION_REFRESH
|
|
||||||
= "nodomain.freeyourgadget.gadgetbride.chart.action.refresh";
|
|
||||||
protected static final Logger LOG = LoggerFactory.getLogger(SleepChartActivity.class);
|
|
||||||
|
|
||||||
private BarLineChartBase mChart;
|
private BarLineChartBase mChart;
|
||||||
|
|
||||||
|
@ -63,17 +48,11 @@ public class SleepChartActivity extends Activity {
|
||||||
private int mSmartAlarmGoneOff = -1;
|
private int mSmartAlarmGoneOff = -1;
|
||||||
private GBDevice mGBDevice = null;
|
private GBDevice mGBDevice = null;
|
||||||
|
|
||||||
private ActivityKind akActivity = new ActivityKind(GBActivitySample.TYPE_UNKNOWN, "Activity", Color.rgb(89, 178, 44));
|
|
||||||
private ActivityKind akLightSleep = new ActivityKind(GBActivitySample.TYPE_LIGHT_SLEEP, "Light Sleep", Color.rgb(182, 191, 255));
|
|
||||||
private ActivityKind akDeepSleep = new ActivityKind(GBActivitySample.TYPE_DEEP_SLEEP, "Deep Sleep", Color.rgb(76, 90, 255));
|
|
||||||
|
|
||||||
private BroadcastReceiver mReceiver = new BroadcastReceiver() {
|
private BroadcastReceiver mReceiver = new BroadcastReceiver() {
|
||||||
@Override
|
@Override
|
||||||
public void onReceive(Context context, Intent intent) {
|
public void onReceive(Context context, Intent intent) {
|
||||||
String action = intent.getAction();
|
String action = intent.getAction();
|
||||||
if (action.equals(ControlCenter.ACTION_QUIT)) {
|
if (action.equals(ACTION_REFRESH)) {
|
||||||
finish();
|
|
||||||
} else if (action.equals(ACTION_REFRESH)) {
|
|
||||||
// TODO: use LimitLines to visualize smart alarms?
|
// TODO: use LimitLines to visualize smart alarms?
|
||||||
mSmartAlarmFrom = intent.getIntExtra("smartalarm_from", -1);
|
mSmartAlarmFrom = intent.getIntExtra("smartalarm_from", -1);
|
||||||
mSmartAlarmTo = intent.getIntExtra("smartalarm_to", -1);
|
mSmartAlarmTo = intent.getIntExtra("smartalarm_to", -1);
|
||||||
|
@ -85,55 +64,39 @@ public class SleepChartActivity extends Activity {
|
||||||
};
|
};
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
public View onCreateView(LayoutInflater inflater, ViewGroup container,
|
||||||
super.onCreate(savedInstanceState);
|
Bundle savedInstanceState) {
|
||||||
|
View rootView = inflater.inflate(R.layout.fragment_charts, container, false);
|
||||||
|
|
||||||
Bundle extras = getIntent().getExtras();
|
Bundle extras = getActivity().getIntent().getExtras();
|
||||||
if (extras != null) {
|
if (extras != null) {
|
||||||
mGBDevice = extras.getParcelable("device");
|
mGBDevice = extras.getParcelable(GBDevice.EXTRA_DEVICE);
|
||||||
}
|
}
|
||||||
|
|
||||||
getActionBar().setDisplayHomeAsUpEnabled(true);
|
|
||||||
|
|
||||||
IntentFilter filter = new IntentFilter();
|
IntentFilter filter = new IntentFilter();
|
||||||
filter.addAction(ControlCenter.ACTION_QUIT);
|
filter.addAction(ControlCenter.ACTION_QUIT);
|
||||||
filter.addAction(ACTION_REFRESH);
|
filter.addAction(ACTION_REFRESH);
|
||||||
|
|
||||||
LocalBroadcastManager.getInstance(this).registerReceiver(mReceiver, filter);
|
LocalBroadcastManager.getInstance(getActivity()).registerReceiver(mReceiver, filter);
|
||||||
|
|
||||||
// getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
|
mChart = (BarLineChartBase) rootView.findViewById(R.id.sleepchart);
|
||||||
// WindowManager.LayoutParams.FLAG_FULLSCREEN);
|
|
||||||
setContentView(R.layout.activity_sleepmonitor2);
|
|
||||||
|
|
||||||
mChart = (BarLineChartBase) findViewById(R.id.sleepchart2);
|
setupChart();
|
||||||
mChart.setBackgroundColor(Color.rgb(24, 22, 24));
|
|
||||||
mChart.setDescriptionColor(Color.WHITE);
|
|
||||||
|
|
||||||
// if enabled, the chart will always start at zero on the y-axis
|
return rootView;
|
||||||
|
}
|
||||||
|
|
||||||
// disable value highlighting
|
private void setupChart() {
|
||||||
mChart.setHighlightEnabled(false);
|
mChart.setBackgroundColor(BACKGROUND_COLOR);
|
||||||
|
mChart.setDescriptionColor(DESCRIPTION_COLOR);
|
||||||
|
configureBarLineChartDefaults(mChart);
|
||||||
|
|
||||||
// enable touch gestures
|
|
||||||
mChart.setTouchEnabled(true);
|
|
||||||
|
|
||||||
// enable scaling and dragging
|
|
||||||
mChart.setDragEnabled(true);
|
|
||||||
mChart.setScaleEnabled(true);
|
|
||||||
|
|
||||||
// if disabled, scaling can be done on x- and y-axis separately
|
|
||||||
// mChart.setPinchZoom(true);
|
|
||||||
|
|
||||||
mChart.setDrawGridBackground(false);
|
|
||||||
|
|
||||||
// tf = Typeface.createFromAsset(getAssets(), "OpenSans-Regular.ttf");
|
|
||||||
|
|
||||||
XAxis x = mChart.getXAxis();
|
XAxis x = mChart.getXAxis();
|
||||||
x.setDrawLabels(true);
|
x.setDrawLabels(true);
|
||||||
x.setDrawGridLines(false);
|
x.setDrawGridLines(false);
|
||||||
// x.setTypeface(tf);
|
|
||||||
x.setEnabled(true);
|
x.setEnabled(true);
|
||||||
x.setTextColor(Color.WHITE);
|
x.setTextColor(CHART_TEXT_COLOR);
|
||||||
x.setDrawLimitLinesBehindData(true);
|
x.setDrawLimitLinesBehindData(true);
|
||||||
|
|
||||||
YAxis y = mChart.getAxisLeft();
|
YAxis y = mChart.getAxisLeft();
|
||||||
|
@ -142,9 +105,8 @@ public class SleepChartActivity extends Activity {
|
||||||
// TODO: make fixed max value optional
|
// TODO: make fixed max value optional
|
||||||
y.setAxisMaxValue(1f);
|
y.setAxisMaxValue(1f);
|
||||||
y.setDrawTopYLabelEntry(false);
|
y.setDrawTopYLabelEntry(false);
|
||||||
y.setTextColor(Color.WHITE);
|
y.setTextColor(CHART_TEXT_COLOR);
|
||||||
|
|
||||||
// y.setTypeface(tf);
|
|
||||||
// y.setLabelCount(5);
|
// y.setLabelCount(5);
|
||||||
y.setEnabled(true);
|
y.setEnabled(true);
|
||||||
|
|
||||||
|
@ -153,60 +115,25 @@ public class SleepChartActivity extends Activity {
|
||||||
yAxisRight.setEnabled(false);
|
yAxisRight.setEnabled(false);
|
||||||
yAxisRight.setDrawLabels(false);
|
yAxisRight.setDrawLabels(false);
|
||||||
yAxisRight.setDrawTopYLabelEntry(false);
|
yAxisRight.setDrawTopYLabelEntry(false);
|
||||||
yAxisRight.setTextColor(Color.WHITE);
|
yAxisRight.setTextColor(CHART_TEXT_COLOR);
|
||||||
|
|
||||||
refresh();
|
refresh();
|
||||||
|
|
||||||
mChart.getLegend().setTextColor(Color.WHITE);
|
mChart.getLegend().setTextColor(LEGEND_TEXT_COLOR);
|
||||||
// mChart.getLegend().setEnabled(false);
|
// mChart.getLegend().setEnabled(false);
|
||||||
//
|
//
|
||||||
// mChart.animateXY(2000, 2000);
|
// mChart.animateXY(2000, 2000);
|
||||||
|
|
||||||
// dont forget to refresh the drawing
|
// don't forget to refresh the drawing
|
||||||
mChart.invalidate();
|
mChart.invalidate();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onDestroy() {
|
public void onDestroy() {
|
||||||
LocalBroadcastManager.getInstance(this).unregisterReceiver(mReceiver);
|
LocalBroadcastManager.getInstance(getActivity()).unregisterReceiver(mReceiver);
|
||||||
super.onDestroy();
|
super.onDestroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
private byte getProvider(GBDevice device) {
|
|
||||||
byte provider = -1;
|
|
||||||
switch (device.getType()) {
|
|
||||||
case MIBAND:
|
|
||||||
provider = GBActivitySample.PROVIDER_MIBAND;
|
|
||||||
break;
|
|
||||||
case PEBBLE:
|
|
||||||
provider = GBActivitySample.PROVIDER_PEBBLE_MORPHEUZ; // FIXME
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return provider;
|
|
||||||
}
|
|
||||||
|
|
||||||
private ArrayList<GBActivitySample> getSamples(GBDevice device, int tsFrom, int tsTo) {
|
|
||||||
if (tsFrom == -1) {
|
|
||||||
long ts = System.currentTimeMillis();
|
|
||||||
tsFrom = (int) ((ts / 1000) - (24 * 60 * 60) & 0xffffffff); // -24 hours
|
|
||||||
}
|
|
||||||
|
|
||||||
byte provider = getProvider(device);
|
|
||||||
return GBApplication.getActivityDatabaseHandler().getGBActivitySamples(tsFrom, tsTo, provider);
|
|
||||||
}
|
|
||||||
|
|
||||||
private ArrayList<GBActivitySample> getTestSamples(GBDevice device, int tsFrom, int tsTo) {
|
|
||||||
Calendar cal = Calendar.getInstance();
|
|
||||||
cal.clear();
|
|
||||||
cal.set(2015, Calendar.JUNE, 10, 6, 40);
|
|
||||||
// ignore provided date ranges
|
|
||||||
tsTo = (int) ((cal.getTimeInMillis() / 1000) & 0xffffffff);
|
|
||||||
tsFrom = tsTo - (24 * 60 * 60);
|
|
||||||
|
|
||||||
byte provider = getProvider(device);
|
|
||||||
return GBApplication.getActivityDatabaseHandler().getGBActivitySamples(tsFrom, tsTo, provider);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void refresh() {
|
private void refresh() {
|
||||||
if (mGBDevice == null) {
|
if (mGBDevice == null) {
|
||||||
return;
|
return;
|
||||||
|
@ -270,15 +197,15 @@ public class SleepChartActivity extends Activity {
|
||||||
if (type == GBActivitySample.TYPE_DEEP_SLEEP) {
|
if (type == GBActivitySample.TYPE_DEEP_SLEEP) {
|
||||||
// value = Y_VALUE_DEEP_SLEEP;
|
// value = Y_VALUE_DEEP_SLEEP;
|
||||||
value = ((float) movement) / movement_divisor;
|
value = ((float) movement) / movement_divisor;
|
||||||
value += Y_VALUE_DEEP_SLEEP;
|
value += SleepUtils.Y_VALUE_DEEP_SLEEP;
|
||||||
activityEntries.add(createEntry(value, i));
|
activityEntries.add(createBarEntry(value, i));
|
||||||
colors.add(akDeepSleep.color);
|
colors.add(akDeepSleep.color);
|
||||||
} else {
|
} else {
|
||||||
if (type == GBActivitySample.TYPE_LIGHT_SLEEP) {
|
if (type == GBActivitySample.TYPE_LIGHT_SLEEP) {
|
||||||
value = ((float) movement) / movement_divisor;
|
value = ((float) movement) / movement_divisor;
|
||||||
// value += Y_VALUE_LIGHT_SLEEP;
|
// value += SleepUtils.Y_VALUE_LIGHT_SLEEP;
|
||||||
// value = Math.min(1.0f, Y_VALUE_LIGHT_SLEEP);
|
// value = Math.min(1.0f, Y_VALUE_LIGHT_SLEEP);
|
||||||
activityEntries.add(createEntry(value, i));
|
activityEntries.add(createBarEntry(value, i));
|
||||||
colors.add(akLightSleep.color);
|
colors.add(akLightSleep.color);
|
||||||
} else {
|
} else {
|
||||||
byte steps = sample.getSteps();
|
byte steps = sample.getSteps();
|
||||||
|
@ -287,7 +214,7 @@ public class SleepChartActivity extends Activity {
|
||||||
movement = steps;
|
movement = steps;
|
||||||
}
|
}
|
||||||
value = ((float) movement) / movement_divisor;
|
value = ((float) movement) / movement_divisor;
|
||||||
activityEntries.add(createEntry(value, i));
|
activityEntries.add(createBarEntry(value, i));
|
||||||
colors.add(akActivity.color);
|
colors.add(akActivity.color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -343,16 +270,12 @@ public class SleepChartActivity extends Activity {
|
||||||
|
|
||||||
mChart.setData(data);
|
mChart.setData(data);
|
||||||
|
|
||||||
mChart.animateX(1000, Easing.EasingOption.EaseInOutQuart);
|
mChart.animateX(500, Easing.EasingOption.EaseInOutQuart);
|
||||||
|
|
||||||
// textView.setText(dateStringFrom + " to " + dateStringTo);
|
// textView.setText(dateStringFrom + " to " + dateStringTo);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isSleep(byte type) {
|
|
||||||
return type == GBActivitySample.TYPE_DEEP_SLEEP || type == GBActivitySample.TYPE_LIGHT_SLEEP;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setupLegend(BarLineChartBase chart) {
|
private void setupLegend(BarLineChartBase chart) {
|
||||||
List<Integer> legendColors = new ArrayList<>(3);
|
List<Integer> legendColors = new ArrayList<>(3);
|
||||||
List<String> legendLabels = new ArrayList<>(3);
|
List<String> legendLabels = new ArrayList<>(3);
|
||||||
|
@ -365,69 +288,4 @@ public class SleepChartActivity extends Activity {
|
||||||
chart.getLegend().setColors(legendColors);
|
chart.getLegend().setColors(legendColors);
|
||||||
chart.getLegend().setLabels(legendLabels);
|
chart.getLegend().setLabels(legendLabels);
|
||||||
}
|
}
|
||||||
|
|
||||||
private BarEntry createEntry(float value, int index) {
|
|
||||||
return new BarEntry(value, index);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onOptionsItemSelected(MenuItem item) {
|
|
||||||
switch (item.getItemId()) {
|
|
||||||
case android.R.id.home:
|
|
||||||
NavUtils.navigateUpFromSameTask(this);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return super.onOptionsItemSelected(item);
|
|
||||||
}
|
|
||||||
|
|
||||||
private BarDataSet createActivitySet(List<BarEntry> values, List<Integer> colors, String label) {
|
|
||||||
BarDataSet set1 = new BarDataSet(values, label);
|
|
||||||
set1.setColors(colors);
|
|
||||||
// set1.setDrawCubic(true);
|
|
||||||
// set1.setCubicIntensity(0.2f);
|
|
||||||
// //set1.setDrawFilled(true);
|
|
||||||
// set1.setDrawCircles(false);
|
|
||||||
// set1.setLineWidth(2f);
|
|
||||||
// set1.setCircleSize(5f);
|
|
||||||
// set1.setFillColor(ColorTemplate.getHoloBlue());
|
|
||||||
set1.setDrawValues(false);
|
|
||||||
// set1.setHighLightColor(Color.rgb(128, 0, 255));
|
|
||||||
// set1.setColor(Color.rgb(89, 178, 44));
|
|
||||||
set1.setValueTextColor(Color.WHITE);
|
|
||||||
return set1;
|
|
||||||
}
|
|
||||||
|
|
||||||
private BarDataSet createDeepSleepSet(List<BarEntry> values, String label) {
|
|
||||||
BarDataSet set1 = new BarDataSet(values, label);
|
|
||||||
// set1.setDrawCubic(true);
|
|
||||||
// set1.setCubicIntensity(0.2f);
|
|
||||||
// //set1.setDrawFilled(true);
|
|
||||||
// set1.setDrawCircles(false);
|
|
||||||
// set1.setLineWidth(2f);
|
|
||||||
// set1.setCircleSize(5f);
|
|
||||||
// set1.setFillColor(ColorTemplate.getHoloBlue());
|
|
||||||
set1.setDrawValues(false);
|
|
||||||
// set1.setHighLightColor(Color.rgb(244, 117, 117));
|
|
||||||
// set1.setColor(Color.rgb(76, 90, 255));
|
|
||||||
set1.setValueTextColor(Color.WHITE);
|
|
||||||
return set1;
|
|
||||||
}
|
|
||||||
|
|
||||||
private BarDataSet createLightSleepSet(List<BarEntry> values, String label) {
|
|
||||||
BarDataSet set1 = new BarDataSet(values, label);
|
|
||||||
|
|
||||||
// set1.setDrawCubic(true);
|
|
||||||
// set1.setCubicIntensity(0.2f);
|
|
||||||
// //set1.setDrawFilled(true);
|
|
||||||
// set1.setDrawCircles(false);
|
|
||||||
// set1.setLineWidth(2f);
|
|
||||||
// set1.setCircleSize(5f);
|
|
||||||
// set1.setFillColor(ColorTemplate.getHoloBlue());
|
|
||||||
set1.setDrawValues(false);
|
|
||||||
// set1.setHighLightColor(Color.rgb(244, 117, 117));
|
|
||||||
// set1.setColor(Color.rgb(182, 191, 255));
|
|
||||||
set1.setValueTextColor(Color.WHITE);
|
|
||||||
// set1.setColor(Color.CYAN);
|
|
||||||
return set1;
|
|
||||||
}
|
|
||||||
}
|
}
|
|
@ -51,29 +51,6 @@ public class ChartsActivity extends FragmentActivity {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onCreateOptionsMenu(Menu menu) {
|
|
||||||
// Inflate the menu; this adds items to the action bar if it is present.
|
|
||||||
getMenuInflater().inflate(R.menu.menu_charts, menu);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onOptionsItemSelected(MenuItem item) {
|
|
||||||
// Handle action bar item clicks here. The action bar will
|
|
||||||
// automatically handle clicks on the Home/Up button, so long
|
|
||||||
// as you specify a parent activity in AndroidManifest.xml.
|
|
||||||
int id = item.getItemId();
|
|
||||||
|
|
||||||
//noinspection SimplifiableIfStatement
|
|
||||||
if (id == R.id.action_settings) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return super.onOptionsItemSelected(item);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A {@link FragmentStatePagerAdapter} that returns a fragment corresponding to
|
* A {@link FragmentStatePagerAdapter} that returns a fragment corresponding to
|
||||||
* one of the sections/tabs/pages.
|
* one of the sections/tabs/pages.
|
||||||
|
@ -86,8 +63,8 @@ public class ChartsActivity extends FragmentActivity {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Fragment getItem(int position) {
|
public Fragment getItem(int position) {
|
||||||
if (position == 1) {
|
if (position == 0) {
|
||||||
return new SleepChartFragment();
|
return new ActivitySleepChartFragment();
|
||||||
}
|
}
|
||||||
|
|
||||||
// getItem is called to instantiate the fragment for the given page.
|
// getItem is called to instantiate the fragment for the given page.
|
||||||
|
@ -97,8 +74,9 @@ public class ChartsActivity extends FragmentActivity {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getCount() {
|
public int getCount() {
|
||||||
|
return 1;
|
||||||
// Show 3 total pages.
|
// Show 3 total pages.
|
||||||
return 3;
|
// return 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -34,27 +34,11 @@ import nodomain.freeyourgadget.gadgetbridge.GBActivitySample;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.GBDevice;
|
import nodomain.freeyourgadget.gadgetbridge.GBDevice;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.R;
|
import nodomain.freeyourgadget.gadgetbridge.R;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.charts.SleepUtils;
|
||||||
|
|
||||||
|
|
||||||
public class SleepChartFragment extends Fragment {
|
public class SleepChartFragment extends AbstractChartFragment {
|
||||||
private static final float Y_VALUE_DEEP_SLEEP = 0.01f;
|
protected static final Logger LOG = LoggerFactory.getLogger(ActivitySleepChartFragment.class);
|
||||||
private static final float Y_VALUE_LIGHT_SLEEP = 0.016f;
|
|
||||||
|
|
||||||
private static final class ActivityKind {
|
|
||||||
public final byte type;
|
|
||||||
public final String label;
|
|
||||||
public final Integer color;
|
|
||||||
|
|
||||||
public ActivityKind(byte type, String label, Integer color) {
|
|
||||||
this.type = type;
|
|
||||||
this.label = label;
|
|
||||||
this.color = color;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final String ACTION_REFRESH
|
|
||||||
= "nodomain.freeyourgadget.gadgetbride.chart.action.refresh";
|
|
||||||
protected static final Logger LOG = LoggerFactory.getLogger(SleepChartFragment.class);
|
|
||||||
|
|
||||||
private BarLineChartBase mChart;
|
private BarLineChartBase mChart;
|
||||||
|
|
||||||
|
@ -64,10 +48,6 @@ public class SleepChartFragment extends Fragment {
|
||||||
private int mSmartAlarmGoneOff = -1;
|
private int mSmartAlarmGoneOff = -1;
|
||||||
private GBDevice mGBDevice = null;
|
private GBDevice mGBDevice = null;
|
||||||
|
|
||||||
private ActivityKind akActivity = new ActivityKind(GBActivitySample.TYPE_UNKNOWN, "Activity", Color.rgb(89, 178, 44));
|
|
||||||
private ActivityKind akLightSleep = new ActivityKind(GBActivitySample.TYPE_LIGHT_SLEEP, "Light Sleep", Color.rgb(182, 191, 255));
|
|
||||||
private ActivityKind akDeepSleep = new ActivityKind(GBActivitySample.TYPE_DEEP_SLEEP, "Deep Sleep", Color.rgb(76, 90, 255));
|
|
||||||
|
|
||||||
private BroadcastReceiver mReceiver = new BroadcastReceiver() {
|
private BroadcastReceiver mReceiver = new BroadcastReceiver() {
|
||||||
@Override
|
@Override
|
||||||
public void onReceive(Context context, Intent intent) {
|
public void onReceive(Context context, Intent intent) {
|
||||||
|
@ -88,11 +68,9 @@ public class SleepChartFragment extends Fragment {
|
||||||
Bundle savedInstanceState) {
|
Bundle savedInstanceState) {
|
||||||
View rootView = inflater.inflate(R.layout.fragment_charts, container, false);
|
View rootView = inflater.inflate(R.layout.fragment_charts, container, false);
|
||||||
|
|
||||||
// setContentView(R.layout.activity_sleepmonitor2);
|
|
||||||
|
|
||||||
Bundle extras = getActivity().getIntent().getExtras();
|
Bundle extras = getActivity().getIntent().getExtras();
|
||||||
if (extras != null) {
|
if (extras != null) {
|
||||||
mGBDevice = extras.getParcelable("device");
|
mGBDevice = extras.getParcelable(GBDevice.EXTRA_DEVICE);
|
||||||
}
|
}
|
||||||
|
|
||||||
IntentFilter filter = new IntentFilter();
|
IntentFilter filter = new IntentFilter();
|
||||||
|
@ -109,34 +87,15 @@ public class SleepChartFragment extends Fragment {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setupChart() {
|
private void setupChart() {
|
||||||
mChart.setBackgroundColor(Color.rgb(24, 22, 24));
|
mChart.setBackgroundColor(BACKGROUND_COLOR);
|
||||||
mChart.setDescriptionColor(Color.WHITE);
|
mChart.setDescriptionColor(DESCRIPTION_COLOR);
|
||||||
|
|
||||||
// if enabled, the chart will always start at zero on the y-axis
|
|
||||||
|
|
||||||
// disable value highlighting
|
|
||||||
mChart.setHighlightEnabled(false);
|
|
||||||
|
|
||||||
// enable touch gestures
|
|
||||||
mChart.setTouchEnabled(true);
|
|
||||||
|
|
||||||
// enable scaling and dragging
|
|
||||||
mChart.setDragEnabled(true);
|
|
||||||
mChart.setScaleEnabled(true);
|
|
||||||
|
|
||||||
// if disabled, scaling can be done on x- and y-axis separately
|
|
||||||
// mChart.setPinchZoom(true);
|
|
||||||
|
|
||||||
mChart.setDrawGridBackground(false);
|
|
||||||
|
|
||||||
// tf = Typeface.createFromAsset(getAssets(), "OpenSans-Regular.ttf");
|
|
||||||
|
|
||||||
XAxis x = mChart.getXAxis();
|
XAxis x = mChart.getXAxis();
|
||||||
x.setDrawLabels(true);
|
x.setDrawLabels(true);
|
||||||
x.setDrawGridLines(false);
|
x.setDrawGridLines(false);
|
||||||
// x.setTypeface(tf);
|
|
||||||
x.setEnabled(true);
|
x.setEnabled(true);
|
||||||
x.setTextColor(Color.WHITE);
|
x.setTextColor(CHART_TEXT_COLOR);
|
||||||
x.setDrawLimitLinesBehindData(true);
|
x.setDrawLimitLinesBehindData(true);
|
||||||
|
|
||||||
YAxis y = mChart.getAxisLeft();
|
YAxis y = mChart.getAxisLeft();
|
||||||
|
@ -145,9 +104,8 @@ public class SleepChartFragment extends Fragment {
|
||||||
// TODO: make fixed max value optional
|
// TODO: make fixed max value optional
|
||||||
y.setAxisMaxValue(1f);
|
y.setAxisMaxValue(1f);
|
||||||
y.setDrawTopYLabelEntry(false);
|
y.setDrawTopYLabelEntry(false);
|
||||||
y.setTextColor(Color.WHITE);
|
y.setTextColor(CHART_TEXT_COLOR);
|
||||||
|
|
||||||
// y.setTypeface(tf);
|
|
||||||
// y.setLabelCount(5);
|
// y.setLabelCount(5);
|
||||||
y.setEnabled(true);
|
y.setEnabled(true);
|
||||||
|
|
||||||
|
@ -156,16 +114,16 @@ public class SleepChartFragment extends Fragment {
|
||||||
yAxisRight.setEnabled(false);
|
yAxisRight.setEnabled(false);
|
||||||
yAxisRight.setDrawLabels(false);
|
yAxisRight.setDrawLabels(false);
|
||||||
yAxisRight.setDrawTopYLabelEntry(false);
|
yAxisRight.setDrawTopYLabelEntry(false);
|
||||||
yAxisRight.setTextColor(Color.WHITE);
|
yAxisRight.setTextColor(CHART_TEXT_COLOR);
|
||||||
|
|
||||||
refresh();
|
refresh();
|
||||||
|
|
||||||
mChart.getLegend().setTextColor(Color.WHITE);
|
mChart.getLegend().setTextColor(LEGEND_TEXT_COLOR);
|
||||||
// mChart.getLegend().setEnabled(false);
|
// mChart.getLegend().setEnabled(false);
|
||||||
//
|
//
|
||||||
// mChart.animateXY(2000, 2000);
|
// mChart.animateXY(2000, 2000);
|
||||||
|
|
||||||
// dont forget to refresh the drawing
|
// don't forget to refresh the drawing
|
||||||
mChart.invalidate();
|
mChart.invalidate();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -175,48 +133,13 @@ public class SleepChartFragment extends Fragment {
|
||||||
super.onDestroy();
|
super.onDestroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
private byte getProvider(GBDevice device) {
|
|
||||||
byte provider = -1;
|
|
||||||
switch (device.getType()) {
|
|
||||||
case MIBAND:
|
|
||||||
provider = GBActivitySample.PROVIDER_MIBAND;
|
|
||||||
break;
|
|
||||||
case PEBBLE:
|
|
||||||
provider = GBActivitySample.PROVIDER_PEBBLE_MORPHEUZ; // FIXME
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return provider;
|
|
||||||
}
|
|
||||||
|
|
||||||
private ArrayList<GBActivitySample> getSamples(GBDevice device, int tsFrom, int tsTo) {
|
|
||||||
if (tsFrom == -1) {
|
|
||||||
long ts = System.currentTimeMillis();
|
|
||||||
tsFrom = (int) ((ts / 1000) - (24 * 60 * 60) & 0xffffffff); // -24 hours
|
|
||||||
}
|
|
||||||
|
|
||||||
byte provider = getProvider(device);
|
|
||||||
return GBApplication.getActivityDatabaseHandler().getGBActivitySamples(tsFrom, tsTo, provider);
|
|
||||||
}
|
|
||||||
|
|
||||||
private ArrayList<GBActivitySample> getTestSamples(GBDevice device, int tsFrom, int tsTo) {
|
|
||||||
Calendar cal = Calendar.getInstance();
|
|
||||||
cal.clear();
|
|
||||||
cal.set(2015, Calendar.JUNE, 10, 6, 40);
|
|
||||||
// ignore provided date ranges
|
|
||||||
tsTo = (int) ((cal.getTimeInMillis() / 1000) & 0xffffffff);
|
|
||||||
tsFrom = tsTo - (24 * 60 * 60);
|
|
||||||
|
|
||||||
byte provider = getProvider(device);
|
|
||||||
return GBApplication.getActivityDatabaseHandler().getGBActivitySamples(tsFrom, tsTo, provider);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void refresh() {
|
private void refresh() {
|
||||||
if (mGBDevice == null) {
|
if (mGBDevice == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ArrayList<GBActivitySample> samples = getTestSamples(mGBDevice, -1, -1);
|
// ArrayList<GBActivitySample> samples = getTestSamples(mGBDevice, -1, -1);
|
||||||
ArrayList<GBActivitySample> samples = getSamples(mGBDevice, -1, -1);
|
ArrayList<GBActivitySample> samples = getSleepSamples(mGBDevice, -1, -1);
|
||||||
|
|
||||||
Calendar cal = Calendar.getInstance();
|
Calendar cal = Calendar.getInstance();
|
||||||
cal.clear();
|
cal.clear();
|
||||||
|
@ -273,15 +196,15 @@ public class SleepChartFragment extends Fragment {
|
||||||
if (type == GBActivitySample.TYPE_DEEP_SLEEP) {
|
if (type == GBActivitySample.TYPE_DEEP_SLEEP) {
|
||||||
// value = Y_VALUE_DEEP_SLEEP;
|
// value = Y_VALUE_DEEP_SLEEP;
|
||||||
value = ((float) movement) / movement_divisor;
|
value = ((float) movement) / movement_divisor;
|
||||||
value += Y_VALUE_DEEP_SLEEP;
|
value += SleepUtils.Y_VALUE_DEEP_SLEEP;
|
||||||
activityEntries.add(createEntry(value, i));
|
activityEntries.add(createBarEntry(value, i));
|
||||||
colors.add(akDeepSleep.color);
|
colors.add(akDeepSleep.color);
|
||||||
} else {
|
} else {
|
||||||
if (type == GBActivitySample.TYPE_LIGHT_SLEEP) {
|
if (type == GBActivitySample.TYPE_LIGHT_SLEEP) {
|
||||||
value = ((float) movement) / movement_divisor;
|
value = ((float) movement) / movement_divisor;
|
||||||
// value += Y_VALUE_LIGHT_SLEEP;
|
// value += SleepUtils.Y_VALUE_LIGHT_SLEEP;
|
||||||
// value = Math.min(1.0f, Y_VALUE_LIGHT_SLEEP);
|
// value = Math.min(1.0f, Y_VALUE_LIGHT_SLEEP);
|
||||||
activityEntries.add(createEntry(value, i));
|
activityEntries.add(createBarEntry(value, i));
|
||||||
colors.add(akLightSleep.color);
|
colors.add(akLightSleep.color);
|
||||||
} else {
|
} else {
|
||||||
byte steps = sample.getSteps();
|
byte steps = sample.getSteps();
|
||||||
|
@ -290,7 +213,7 @@ public class SleepChartFragment extends Fragment {
|
||||||
movement = steps;
|
movement = steps;
|
||||||
}
|
}
|
||||||
value = ((float) movement) / movement_divisor;
|
value = ((float) movement) / movement_divisor;
|
||||||
activityEntries.add(createEntry(value, i));
|
activityEntries.add(createBarEntry(value, i));
|
||||||
colors.add(akActivity.color);
|
colors.add(akActivity.color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -346,16 +269,12 @@ public class SleepChartFragment extends Fragment {
|
||||||
|
|
||||||
mChart.setData(data);
|
mChart.setData(data);
|
||||||
|
|
||||||
mChart.animateX(1000, Easing.EasingOption.EaseInOutQuart);
|
mChart.animateX(500, Easing.EasingOption.EaseInOutQuart);
|
||||||
|
|
||||||
// textView.setText(dateStringFrom + " to " + dateStringTo);
|
// textView.setText(dateStringFrom + " to " + dateStringTo);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isSleep(byte type) {
|
|
||||||
return type == GBActivitySample.TYPE_DEEP_SLEEP || type == GBActivitySample.TYPE_LIGHT_SLEEP;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setupLegend(BarLineChartBase chart) {
|
private void setupLegend(BarLineChartBase chart) {
|
||||||
List<Integer> legendColors = new ArrayList<>(3);
|
List<Integer> legendColors = new ArrayList<>(3);
|
||||||
List<String> legendLabels = new ArrayList<>(3);
|
List<String> legendLabels = new ArrayList<>(3);
|
||||||
|
@ -368,59 +287,4 @@ public class SleepChartFragment extends Fragment {
|
||||||
chart.getLegend().setColors(legendColors);
|
chart.getLegend().setColors(legendColors);
|
||||||
chart.getLegend().setLabels(legendLabels);
|
chart.getLegend().setLabels(legendLabels);
|
||||||
}
|
}
|
||||||
|
|
||||||
private BarEntry createEntry(float value, int index) {
|
|
||||||
return new BarEntry(value, index);
|
|
||||||
}
|
|
||||||
|
|
||||||
private BarDataSet createActivitySet(List<BarEntry> values, List<Integer> colors, String label) {
|
|
||||||
BarDataSet set1 = new BarDataSet(values, label);
|
|
||||||
set1.setColors(colors);
|
|
||||||
// set1.setDrawCubic(true);
|
|
||||||
// set1.setCubicIntensity(0.2f);
|
|
||||||
// //set1.setDrawFilled(true);
|
|
||||||
// set1.setDrawCircles(false);
|
|
||||||
// set1.setLineWidth(2f);
|
|
||||||
// set1.setCircleSize(5f);
|
|
||||||
// set1.setFillColor(ColorTemplate.getHoloBlue());
|
|
||||||
set1.setDrawValues(false);
|
|
||||||
// set1.setHighLightColor(Color.rgb(128, 0, 255));
|
|
||||||
// set1.setColor(Color.rgb(89, 178, 44));
|
|
||||||
set1.setValueTextColor(Color.WHITE);
|
|
||||||
return set1;
|
|
||||||
}
|
|
||||||
|
|
||||||
private BarDataSet createDeepSleepSet(List<BarEntry> values, String label) {
|
|
||||||
BarDataSet set1 = new BarDataSet(values, label);
|
|
||||||
// set1.setDrawCubic(true);
|
|
||||||
// set1.setCubicIntensity(0.2f);
|
|
||||||
// //set1.setDrawFilled(true);
|
|
||||||
// set1.setDrawCircles(false);
|
|
||||||
// set1.setLineWidth(2f);
|
|
||||||
// set1.setCircleSize(5f);
|
|
||||||
// set1.setFillColor(ColorTemplate.getHoloBlue());
|
|
||||||
set1.setDrawValues(false);
|
|
||||||
// set1.setHighLightColor(Color.rgb(244, 117, 117));
|
|
||||||
// set1.setColor(Color.rgb(76, 90, 255));
|
|
||||||
set1.setValueTextColor(Color.WHITE);
|
|
||||||
return set1;
|
|
||||||
}
|
|
||||||
|
|
||||||
private BarDataSet createLightSleepSet(List<BarEntry> values, String label) {
|
|
||||||
BarDataSet set1 = new BarDataSet(values, label);
|
|
||||||
|
|
||||||
// set1.setDrawCubic(true);
|
|
||||||
// set1.setCubicIntensity(0.2f);
|
|
||||||
// //set1.setDrawFilled(true);
|
|
||||||
// set1.setDrawCircles(false);
|
|
||||||
// set1.setLineWidth(2f);
|
|
||||||
// set1.setCircleSize(5f);
|
|
||||||
// set1.setFillColor(ColorTemplate.getHoloBlue());
|
|
||||||
set1.setDrawValues(false);
|
|
||||||
// set1.setHighLightColor(Color.rgb(244, 117, 117));
|
|
||||||
// set1.setColor(Color.rgb(182, 191, 255));
|
|
||||||
set1.setValueTextColor(Color.WHITE);
|
|
||||||
// set1.setColor(Color.CYAN);
|
|
||||||
return set1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
package nodomain.freeyourgadget.gadgetbridge.charts;
|
||||||
|
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.GBActivitySample;
|
||||||
|
|
||||||
|
public class SleepUtils {
|
||||||
|
public static final float Y_VALUE_DEEP_SLEEP = 0.01f;
|
||||||
|
public static final float Y_VALUE_LIGHT_SLEEP = 0.016f;
|
||||||
|
|
||||||
|
public static final boolean isSleep(byte type) {
|
||||||
|
return type == GBActivitySample.TYPE_DEEP_SLEEP || type == GBActivitySample.TYPE_LIGHT_SLEEP;
|
||||||
|
}
|
||||||
|
}
|
|
@ -120,7 +120,7 @@ public class ActivityDatabaseHandler extends SQLiteOpenHelper {
|
||||||
String selectQuery = "SELECT * FROM " + TABLE_GBACTIVITYSAMPLES
|
String selectQuery = "SELECT * FROM " + TABLE_GBACTIVITYSAMPLES
|
||||||
+ " where (provider=" + provider + " and timestamp>=" + timestamp_from + " and timestamp<=" + timestamp_to + ") order by timestamp";
|
+ " where (provider=" + provider + " and timestamp>=" + timestamp_from + " and timestamp<=" + timestamp_to + ") order by timestamp";
|
||||||
|
|
||||||
try (SQLiteDatabase db = this.getWritableDatabase()) {
|
try (SQLiteDatabase db = this.getReadableDatabase()) {
|
||||||
Cursor cursor = db.rawQuery(selectQuery, null);
|
Cursor cursor = db.rawQuery(selectQuery, null);
|
||||||
|
|
||||||
if (cursor.moveToFirst()) {
|
if (cursor.moveToFirst()) {
|
||||||
|
|
|
@ -1,9 +1,6 @@
|
||||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
|
xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
|
android:layout_height="match_parent"
|
||||||
android:paddingRight="@dimen/activity_horizontal_margin"
|
|
||||||
android:paddingTop="@dimen/activity_vertical_margin"
|
|
||||||
android:paddingBottom="@dimen/activity_vertical_margin"
|
|
||||||
tools:context="nodomain.freeyourgadget.gadgetbridge.activities.ChartsActivity$PlaceholderFragment">
|
tools:context="nodomain.freeyourgadget.gadgetbridge.activities.ChartsActivity$PlaceholderFragment">
|
||||||
|
|
||||||
<nodomain.freeyourgadget.gadgetbridge.charts.CustomBarChart
|
<nodomain.freeyourgadget.gadgetbridge.charts.CustomBarChart
|
||||||
|
|
Loading…
Reference in New Issue