mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge
synced 2024-12-01 14:32:54 +01:00
WIP: support for live display of activity data
This commit is contained in:
parent
536b2bd8a0
commit
ab8982e7f2
@ -208,6 +208,8 @@ public class ChartsActivity extends AbstractGBFragmentActivity implements Charts
|
|||||||
return new SleepChartFragment();
|
return new SleepChartFragment();
|
||||||
case 2:
|
case 2:
|
||||||
return new WeekStepsChartFragment();
|
return new WeekStepsChartFragment();
|
||||||
|
case 3:
|
||||||
|
return new LiveActivityFragment();
|
||||||
|
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
@ -216,7 +218,7 @@ public class ChartsActivity extends AbstractGBFragmentActivity implements Charts
|
|||||||
@Override
|
@Override
|
||||||
public int getCount() {
|
public int getCount() {
|
||||||
// Show 3 total pages.
|
// Show 3 total pages.
|
||||||
return 3;
|
return 4;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,154 @@
|
|||||||
|
package nodomain.freeyourgadget.gadgetbridge.activities.charts;
|
||||||
|
|
||||||
|
import android.content.BroadcastReceiver;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.content.IntentFilter;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.support.annotation.Nullable;
|
||||||
|
import android.support.v4.content.LocalBroadcastManager;
|
||||||
|
import android.view.LayoutInflater;
|
||||||
|
import android.view.View;
|
||||||
|
import android.view.ViewGroup;
|
||||||
|
|
||||||
|
import com.github.mikephil.charting.charts.BarLineChartBase;
|
||||||
|
import com.github.mikephil.charting.charts.Chart;
|
||||||
|
import com.github.mikephil.charting.charts.PieChart;
|
||||||
|
import com.github.mikephil.charting.components.XAxis;
|
||||||
|
import com.github.mikephil.charting.components.YAxis;
|
||||||
|
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.R;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.database.DBHandler;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.model.ActivitySample;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.model.DeviceService;
|
||||||
|
|
||||||
|
public class LiveActivityFragment extends AbstractChartFragment {
|
||||||
|
private static final Logger LOG = LoggerFactory.getLogger(LiveActivityFragment.class);
|
||||||
|
|
||||||
|
private BarLineChartBase mStepsPerMinuteHistoryChart;
|
||||||
|
private PieChart mStepsPerMinuteCurrentChart;
|
||||||
|
|
||||||
|
private BroadcastReceiver mReceiver = new BroadcastReceiver() {
|
||||||
|
@Override
|
||||||
|
public void onReceive(Context context, Intent intent) {
|
||||||
|
String action = intent.getAction();
|
||||||
|
switch (action) {
|
||||||
|
case DeviceService.ACTION_REALTIME_STEPS:
|
||||||
|
int steps = intent.getIntExtra(DeviceService.EXTRA_REALTIME_STEPS, 0);
|
||||||
|
updateCurrentSteps(steps);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private void updateCurrentSteps(int steps) {
|
||||||
|
LOG.warn("STEPS: " + steps);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
@Override
|
||||||
|
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
|
||||||
|
IntentFilter filterLocal = new IntentFilter();
|
||||||
|
filterLocal.addAction(DeviceService.ACTION_ENABLE_REALTIME_STEPS);
|
||||||
|
LocalBroadcastManager.getInstance(getActivity()).registerReceiver(mReceiver, filterLocal);
|
||||||
|
|
||||||
|
View rootView = inflater.inflate(R.layout.fragment_live_activity, container, false);
|
||||||
|
|
||||||
|
mStepsPerMinuteHistoryChart = (BarLineChartBase) rootView.findViewById(R.id.livechart_steps_per_minute_history);
|
||||||
|
mStepsPerMinuteCurrentChart = (PieChart) rootView.findViewById(R.id.livechart_steps_per_minute_current);
|
||||||
|
|
||||||
|
setupHistoryChart(mStepsPerMinuteHistoryChart);
|
||||||
|
setupCurrentChart(mStepsPerMinuteCurrentChart);
|
||||||
|
|
||||||
|
return rootView;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onStart() {
|
||||||
|
super.onStart();
|
||||||
|
GBApplication.deviceService().onEnableRealtimeSteps(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onStop() {
|
||||||
|
super.onStop();
|
||||||
|
GBApplication.deviceService().onEnableRealtimeSteps(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onDestroyView() {
|
||||||
|
LocalBroadcastManager.getInstance(getActivity()).unregisterReceiver(mReceiver);
|
||||||
|
super.onDestroyView();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setupCurrentChart(PieChart chart) {
|
||||||
|
chart.setBackgroundColor(BACKGROUND_COLOR);
|
||||||
|
chart.setDescriptionColor(DESCRIPTION_COLOR);
|
||||||
|
chart.setDescription("");
|
||||||
|
chart.setNoDataTextDescription("");
|
||||||
|
chart.setNoDataText("");
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setupHistoryChart(BarLineChartBase chart) {
|
||||||
|
chart.setBackgroundColor(BACKGROUND_COLOR);
|
||||||
|
chart.setDescriptionColor(DESCRIPTION_COLOR);
|
||||||
|
chart.setDescription("");
|
||||||
|
|
||||||
|
configureBarLineChartDefaults(chart);
|
||||||
|
|
||||||
|
XAxis x = chart.getXAxis();
|
||||||
|
x.setDrawLabels(true);
|
||||||
|
x.setDrawGridLines(false);
|
||||||
|
x.setEnabled(true);
|
||||||
|
x.setTextColor(CHART_TEXT_COLOR);
|
||||||
|
x.setDrawLimitLinesBehindData(true);
|
||||||
|
|
||||||
|
YAxis y = chart.getAxisLeft();
|
||||||
|
y.setDrawGridLines(false);
|
||||||
|
y.setDrawTopYLabelEntry(false);
|
||||||
|
y.setTextColor(CHART_TEXT_COLOR);
|
||||||
|
|
||||||
|
y.setEnabled(true);
|
||||||
|
|
||||||
|
YAxis yAxisRight = chart.getAxisRight();
|
||||||
|
yAxisRight.setDrawGridLines(false);
|
||||||
|
yAxisRight.setEnabled(false);
|
||||||
|
yAxisRight.setDrawLabels(false);
|
||||||
|
yAxisRight.setDrawTopYLabelEntry(false);
|
||||||
|
yAxisRight.setTextColor(CHART_TEXT_COLOR);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getTitle() {
|
||||||
|
return getContext().getString(R.string.liveactivity_live_activity);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void refreshInBackground(DBHandler db, GBDevice device) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void renderCharts() {
|
||||||
|
mStepsPerMinuteCurrentChart.animateXY(50, 50);
|
||||||
|
mStepsPerMinuteHistoryChart.invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected List<ActivitySample> getSamples(DBHandler db, GBDevice device, int tsFrom, int tsTo) {
|
||||||
|
throw new UnsupportedOperationException("no db access supported for live activity");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void setupLegend(Chart chart) {
|
||||||
|
// no legend
|
||||||
|
}
|
||||||
|
}
|
@ -185,7 +185,6 @@ public class WeekStepsChartFragment extends AbstractChartFragment {
|
|||||||
yAxisRight.setDrawLabels(false);
|
yAxisRight.setDrawLabels(false);
|
||||||
yAxisRight.setDrawTopYLabelEntry(false);
|
yAxisRight.setDrawTopYLabelEntry(false);
|
||||||
yAxisRight.setTextColor(CHART_TEXT_COLOR);
|
yAxisRight.setTextColor(CHART_TEXT_COLOR);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void setupLegend(Chart chart) {
|
protected void setupLegend(Chart chart) {
|
||||||
|
@ -29,6 +29,8 @@ public interface EventHandler {
|
|||||||
|
|
||||||
void onSetMusicInfo(String artist, String album, String track);
|
void onSetMusicInfo(String artist, String album, String track);
|
||||||
|
|
||||||
|
void onEnableRealtimeSteps(boolean enable);
|
||||||
|
|
||||||
void onInstallApp(Uri uri);
|
void onInstallApp(Uri uri);
|
||||||
|
|
||||||
void onAppInfoReq();
|
void onAppInfoReq();
|
||||||
|
@ -150,16 +150,17 @@ public class MiBandService {
|
|||||||
|
|
||||||
public static final byte COMMAND_STOP_MOTOR_VIBRATE = 0x13;
|
public static final byte COMMAND_STOP_MOTOR_VIBRATE = 0x13;
|
||||||
|
|
||||||
|
public static final byte COMMAND_SET_REALTIME_STEPS_NOTIFICATION = 0x3;
|
||||||
|
|
||||||
|
public static final byte COMMAND_SET_REALTIME_STEP = 0x10;
|
||||||
|
|
||||||
/* FURTHER COMMANDS: unchecked therefore left commented
|
/* FURTHER COMMANDS: unchecked therefore left commented
|
||||||
|
|
||||||
public static final COMMAND_SET_REALTIME_STEPS_NOTIFICATION = 0x3t
|
|
||||||
|
|
||||||
public static final byte COMMAND_FACTORY_RESET = 0x9t;
|
public static final byte COMMAND_FACTORY_RESET = 0x9t;
|
||||||
|
|
||||||
public static final int COMMAND_SET_COLOR_THEME = et;
|
public static final int COMMAND_SET_COLOR_THEME = et;
|
||||||
|
|
||||||
public static final COMMAND_SET_REALTIME_STEP = 0x10t
|
|
||||||
|
|
||||||
public static final COMMAND_STOP_SYNC_DATA = 0x11t
|
public static final COMMAND_STOP_SYNC_DATA = 0x11t
|
||||||
|
|
||||||
public static final byte COMMAND_GET_SENSOR_DATA = 0x12t
|
public static final byte COMMAND_GET_SENSOR_DATA = 0x12t
|
||||||
|
@ -185,4 +185,11 @@ public class GBDeviceService implements DeviceService {
|
|||||||
Intent intent = createIntent().setAction(ACTION_REQUEST_SCREENSHOT);
|
Intent intent = createIntent().setAction(ACTION_REQUEST_SCREENSHOT);
|
||||||
invokeService(intent);
|
invokeService(intent);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onEnableRealtimeSteps(boolean enable) {
|
||||||
|
Intent intent = createIntent().setAction(ACTION_ENABLE_REALTIME_STEPS)
|
||||||
|
.putExtra(EXTRA_ENABLE_REALTIME_STEPS, enable);
|
||||||
|
invokeService(intent);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,6 +30,8 @@ public interface DeviceService extends EventHandler {
|
|||||||
static final String ACTION_DISCONNECT = PREFIX + ".action.disconnect";
|
static final String ACTION_DISCONNECT = PREFIX + ".action.disconnect";
|
||||||
static final String ACTION_FIND_DEVICE = PREFIX + ".action.find_device";
|
static final String ACTION_FIND_DEVICE = PREFIX + ".action.find_device";
|
||||||
static final String ACTION_SET_ALARMS = PREFIX + ".action.set_alarms";
|
static final String ACTION_SET_ALARMS = PREFIX + ".action.set_alarms";
|
||||||
|
static final String ACTION_ENABLE_REALTIME_STEPS = PREFIX + ".action.enable_realtime_steps";
|
||||||
|
static final String ACTION_REALTIME_STEPS = PREFIX + ".action.realtime_steps";
|
||||||
|
|
||||||
static final String EXTRA_DEVICE_ADDRESS = "device_address";
|
static final String EXTRA_DEVICE_ADDRESS = "device_address";
|
||||||
static final String EXTRA_NOTIFICATION_TITLE = "notification_title";
|
static final String EXTRA_NOTIFICATION_TITLE = "notification_title";
|
||||||
@ -47,7 +49,8 @@ public interface DeviceService extends EventHandler {
|
|||||||
static final String EXTRA_URI = "uri";
|
static final String EXTRA_URI = "uri";
|
||||||
static final String EXTRA_ALARMS = "alarms";
|
static final String EXTRA_ALARMS = "alarms";
|
||||||
static final String EXTRA_PERFORM_PAIR = "perform_pair";
|
static final String EXTRA_PERFORM_PAIR = "perform_pair";
|
||||||
|
static final String EXTRA_ENABLE_REALTIME_STEPS = "enable_realtime_steps";
|
||||||
|
static final String EXTRA_REALTIME_STEPS = "realtime_steps";
|
||||||
|
|
||||||
|
|
||||||
void start();
|
void start();
|
||||||
|
@ -34,6 +34,7 @@ import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_CA
|
|||||||
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_CONNECT;
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_CONNECT;
|
||||||
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_DELETEAPP;
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_DELETEAPP;
|
||||||
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_DISCONNECT;
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_DISCONNECT;
|
||||||
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_ENABLE_REALTIME_STEPS;
|
||||||
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_FETCH_ACTIVITY_DATA;
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_FETCH_ACTIVITY_DATA;
|
||||||
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_FIND_DEVICE;
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_FIND_DEVICE;
|
||||||
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_INSTALL;
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_INSTALL;
|
||||||
@ -54,6 +55,7 @@ import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_APP
|
|||||||
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_CALL_COMMAND;
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_CALL_COMMAND;
|
||||||
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_CALL_PHONENUMBER;
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_CALL_PHONENUMBER;
|
||||||
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_DEVICE_ADDRESS;
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_DEVICE_ADDRESS;
|
||||||
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_ENABLE_REALTIME_STEPS;
|
||||||
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_FIND_START;
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_FIND_START;
|
||||||
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_MUSIC_ALBUM;
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_MUSIC_ALBUM;
|
||||||
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_MUSIC_ARTIST;
|
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.EXTRA_MUSIC_ARTIST;
|
||||||
@ -263,6 +265,10 @@ public class DeviceCommunicationService extends Service {
|
|||||||
ArrayList<Alarm> alarms = intent.getParcelableArrayListExtra(EXTRA_ALARMS);
|
ArrayList<Alarm> alarms = intent.getParcelableArrayListExtra(EXTRA_ALARMS);
|
||||||
mDeviceSupport.onSetAlarms(alarms);
|
mDeviceSupport.onSetAlarms(alarms);
|
||||||
break;
|
break;
|
||||||
|
case ACTION_ENABLE_REALTIME_STEPS:
|
||||||
|
boolean enable = intent.getBooleanExtra(EXTRA_ENABLE_REALTIME_STEPS, false);
|
||||||
|
mDeviceSupport.onEnableRealtimeSteps(enable);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return START_STICKY;
|
return START_STICKY;
|
||||||
|
@ -231,4 +231,12 @@ public class ServiceDeviceSupport implements DeviceSupport {
|
|||||||
}
|
}
|
||||||
delegate.onSetAlarms(alarms);
|
delegate.onSetAlarms(alarms);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onEnableRealtimeSteps(boolean enable) {
|
||||||
|
if (checkBusy("enable realtime steps: " + enable)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
delegate.onEnableRealtimeSteps(enable);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,9 +2,11 @@ package nodomain.freeyourgadget.gadgetbridge.service.devices.miband;
|
|||||||
|
|
||||||
import android.bluetooth.BluetoothGatt;
|
import android.bluetooth.BluetoothGatt;
|
||||||
import android.bluetooth.BluetoothGattCharacteristic;
|
import android.bluetooth.BluetoothGattCharacteristic;
|
||||||
|
import android.content.Intent;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.preference.PreferenceManager;
|
import android.preference.PreferenceManager;
|
||||||
|
import android.support.v4.content.LocalBroadcastManager;
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
@ -26,7 +28,9 @@ import nodomain.freeyourgadget.gadgetbridge.devices.miband.MiBandService;
|
|||||||
import nodomain.freeyourgadget.gadgetbridge.devices.miband.VibrationProfile;
|
import nodomain.freeyourgadget.gadgetbridge.devices.miband.VibrationProfile;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice.State;
|
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice.State;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.model.Alarm;
|
import nodomain.freeyourgadget.gadgetbridge.model.Alarm;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.model.DeviceService;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.model.ServiceCommand;
|
import nodomain.freeyourgadget.gadgetbridge.model.ServiceCommand;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.service.DeviceSupport;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.service.btle.AbstractBTLEDeviceSupport;
|
import nodomain.freeyourgadget.gadgetbridge.service.btle.AbstractBTLEDeviceSupport;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.service.btle.BtLEAction;
|
import nodomain.freeyourgadget.gadgetbridge.service.btle.BtLEAction;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.service.btle.TransactionBuilder;
|
import nodomain.freeyourgadget.gadgetbridge.service.btle.TransactionBuilder;
|
||||||
@ -207,9 +211,11 @@ public class MiBandSupport extends AbstractBTLEDeviceSupport {
|
|||||||
private static final byte[] startVibrate = new byte[]{MiBandService.COMMAND_SEND_NOTIFICATION, 1};
|
private static final byte[] startVibrate = new byte[]{MiBandService.COMMAND_SEND_NOTIFICATION, 1};
|
||||||
private static final byte[] stopVibrate = new byte[]{MiBandService.COMMAND_STOP_MOTOR_VIBRATE};
|
private static final byte[] stopVibrate = new byte[]{MiBandService.COMMAND_STOP_MOTOR_VIBRATE};
|
||||||
private static final byte[] reboot = new byte[]{MiBandService.COMMAND_REBOOT};
|
private static final byte[] reboot = new byte[]{MiBandService.COMMAND_REBOOT};
|
||||||
|
private static final byte[] startRealTimeStepsNotifications = new byte[]{MiBandService.COMMAND_SET_REALTIME_STEPS_NOTIFICATION, 1};
|
||||||
|
private static final byte[] stopRealTimeStepsNotifications = new byte[]{MiBandService.COMMAND_SET_REALTIME_STEPS_NOTIFICATION, 0};
|
||||||
|
|
||||||
private byte[] getNotification(long vibrateDuration, int vibrateTimes, int flashTimes, int flashColour, int originalColour, long flashDuration) {
|
private byte[] getNotification(long vibrateDuration, int vibrateTimes, int flashTimes, int flashColour, int originalColour, long flashDuration) {
|
||||||
byte[] vibrate = new byte[]{MiBandService.COMMAND_SEND_NOTIFICATION, (byte) 1};
|
byte[] vibrate = startVibrate;
|
||||||
byte r = 6;
|
byte r = 6;
|
||||||
byte g = 0;
|
byte g = 0;
|
||||||
byte b = 6;
|
byte b = 6;
|
||||||
@ -514,6 +520,17 @@ public class MiBandSupport extends AbstractBTLEDeviceSupport {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onEnableRealtimeSteps(boolean enable) {
|
||||||
|
try {
|
||||||
|
BluetoothGattCharacteristic controlPoint = getCharacteristic(MiBandService.UUID_CHARACTERISTIC_CONTROL_POINT);
|
||||||
|
performInitialized(enable ? "Enabling realtime steps notifications" : "Disabling realtime steps notifications")
|
||||||
|
.write(controlPoint, enable ? startRealTimeStepsNotifications : stopRealTimeStepsNotifications).queue(getQueue());
|
||||||
|
} catch (IOException e) {
|
||||||
|
LOG.error("Unable to change realtime steps notification to: " + enable, e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private byte[] getHighLatency() {
|
private byte[] getHighLatency() {
|
||||||
int minConnectionInterval = 460;
|
int minConnectionInterval = 460;
|
||||||
int maxConnectionInterval = 500;
|
int maxConnectionInterval = 500;
|
||||||
@ -591,9 +608,19 @@ public class MiBandSupport extends AbstractBTLEDeviceSupport {
|
|||||||
handleBatteryInfo(characteristic.getValue(), BluetoothGatt.GATT_SUCCESS);
|
handleBatteryInfo(characteristic.getValue(), BluetoothGatt.GATT_SUCCESS);
|
||||||
} else if (MiBandService.UUID_CHARACTERISTIC_NOTIFICATION.equals(characteristicUUID)) {
|
} else if (MiBandService.UUID_CHARACTERISTIC_NOTIFICATION.equals(characteristicUUID)) {
|
||||||
handleNotificationNotif(characteristic.getValue());
|
handleNotificationNotif(characteristic.getValue());
|
||||||
|
} else if (MiBandService.UUID_CHARACTERISTIC_REALTIME_STEPS.equals(characteristicUUID)) {
|
||||||
|
handleRealtimeSteps(characteristic.getValue());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void handleRealtimeSteps(byte[] value) {
|
||||||
|
int steps = 0xff & value[0] | (0xff & value[1]) << 8;
|
||||||
|
LOG.debug("realtime steps: " + steps);
|
||||||
|
Intent intent = new Intent(DeviceService.ACTION_REALTIME_STEPS)
|
||||||
|
.putExtra(DeviceService.EXTRA_REALTIME_STEPS, steps);
|
||||||
|
LocalBroadcastManager.getInstance(getContext()).sendBroadcast(intent);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCharacteristicRead(BluetoothGatt gatt,
|
public void onCharacteristicRead(BluetoothGatt gatt,
|
||||||
BluetoothGattCharacteristic characteristic, int status) {
|
BluetoothGattCharacteristic characteristic, int status) {
|
||||||
|
@ -182,4 +182,10 @@ public abstract class AbstractSerialDeviceSupport extends AbstractDeviceSupport
|
|||||||
byte[] bytes = gbDeviceProtocol.encodeScreenshotReq();
|
byte[] bytes = gbDeviceProtocol.encodeScreenshotReq();
|
||||||
sendToDevice(bytes);
|
sendToDevice(bytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onEnableRealtimeSteps(boolean enable) {
|
||||||
|
byte[] bytes = gbDeviceProtocol.encodeEnableRealtimeSteps(enable);
|
||||||
|
sendToDevice(bytes);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -63,7 +63,12 @@ public abstract class GBDeviceProtocol {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public byte[] encodeEnableRealtimeSteps(boolean enable) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
public GBDeviceEvent[] decodeResponse(byte[] responseData) {
|
public GBDeviceEvent[] decodeResponse(byte[] responseData) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
20
app/src/main/res/layout/fragment_live_activity.xml
Normal file
20
app/src/main/res/layout/fragment_live_activity.xml
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:orientation="vertical" android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
|
<com.github.mikephil.charting.charts.LineChart
|
||||||
|
android:id="@+id/livechart_steps_per_minute_history"
|
||||||
|
android:layout_width="fill_parent"
|
||||||
|
android:layout_height="fill_parent"
|
||||||
|
android:layout_weight="20">
|
||||||
|
</com.github.mikephil.charting.charts.LineChart>
|
||||||
|
|
||||||
|
<com.github.mikephil.charting.charts.PieChart
|
||||||
|
android:id="@+id/livechart_steps_per_minute_current"
|
||||||
|
android:layout_width="fill_parent"
|
||||||
|
android:layout_height="fill_parent"
|
||||||
|
android:layout_weight="20">
|
||||||
|
</com.github.mikephil.charting.charts.PieChart>
|
||||||
|
|
||||||
|
</LinearLayout>
|
@ -185,4 +185,6 @@
|
|||||||
<string name="updatefirmwareoperation_update_complete_rebooting">Firmware installation complete, rebooting device…</string>
|
<string name="updatefirmwareoperation_update_complete_rebooting">Firmware installation complete, rebooting device…</string>
|
||||||
<string name="updatefirmwareoperation_write_failed">Firmware write failed</string>
|
<string name="updatefirmwareoperation_write_failed">Firmware write failed</string>
|
||||||
<string name="chart_steps">Steps</string>
|
<string name="chart_steps">Steps</string>
|
||||||
|
<string name="liveactivity_live_activity">Live Activity</string>
|
||||||
|
<string name="weeksteps_today_steps_description">Steps today, target: %1$s</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
@ -121,4 +121,9 @@ public class TestDeviceSupport extends AbstractDeviceSupport {
|
|||||||
public void onScreenshotReq() {
|
public void onScreenshotReq() {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onEnableRealtimeSteps(boolean enable) {
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user