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

Reading the device preferences from the watch and set them in the ZeTime menu.

This commit is contained in:
Sebastian Kranz 2019-02-20 14:09:21 +01:00
parent 6b82340093
commit a7553188f9
20 changed files with 818 additions and 411 deletions

View File

@ -96,6 +96,13 @@ public interface EventHandler {
*/ */
void onSendConfiguration(String config); void onSendConfiguration(String config);
/**
* Gets the given option from the device, sets the values in the preferences.
* The config name is device specific.
* @param config the device specific option to get from the device
*/
void onReadConfiguration(String config);
void onTestNewFunction(); void onTestNewFunction();
void onSendWeather(WeatherSpec weatherSpec); void onSendWeather(WeatherSpec weatherSpec);

View File

@ -137,6 +137,7 @@ public class ZeTimeConstants {
public static final String PREF_ZETIME_HEARTRATE_ALARM = "zetime_heartrate_alarm_enable"; public static final String PREF_ZETIME_HEARTRATE_ALARM = "zetime_heartrate_alarm_enable";
public static final String PREF_ZETIME_MAX_HEARTRATE = "alarm_max_heart_rate"; public static final String PREF_ZETIME_MAX_HEARTRATE = "alarm_max_heart_rate";
public static final String PREF_ZETIME_MIN_HEARTRATE = "alarm_min_heart_rate"; public static final String PREF_ZETIME_MIN_HEARTRATE = "alarm_min_heart_rate";
public static final String PREF_ZETIME_HEARTRATE_INTERVAL = "heartrate_measurement_interval";
public static final String PREF_DO_NOT_DISTURB = "zetime_do_not_disturb"; public static final String PREF_DO_NOT_DISTURB = "zetime_do_not_disturb";
public static final String PREF_DO_NOT_DISTURB_START = "zetime_do_not_disturb_start"; public static final String PREF_DO_NOT_DISTURB_START = "zetime_do_not_disturb_start";

View File

@ -23,7 +23,7 @@ public class ZeTimePreferenceActivity extends AbstractSettingsActivity {
Prefs prefs = GBApplication.getPrefs(); Prefs prefs = GBApplication.getPrefs();
final Preference heartrateMeasurementInterval = findPreference("heartrate_measurement_interval"); final Preference heartrateMeasurementInterval = findPreference(ZeTimeConstants.PREF_ZETIME_HEARTRATE_INTERVAL);
heartrateMeasurementInterval.setOnPreferenceChangeListener(new Preference.OnPreferenceChangeListener() { heartrateMeasurementInterval.setOnPreferenceChangeListener(new Preference.OnPreferenceChangeListener() {
@Override @Override
public boolean onPreferenceChange(Preference preference, Object newVal) { public boolean onPreferenceChange(Preference preference, Object newVal) {
@ -357,6 +357,8 @@ public class ZeTimePreferenceActivity extends AbstractSettingsActivity {
return true; return true;
} }
}); });
GBApplication.deviceService().onReadConfiguration("do_it");
} }
/** /**

View File

@ -377,6 +377,13 @@ public class GBDeviceService implements DeviceService {
invokeService(intent); invokeService(intent);
} }
@Override
public void onReadConfiguration(String config) {
Intent intent = createIntent().setAction(ACTION_READ_CONFIGURATION)
.putExtra(EXTRA_CONFIG, config);
invokeService(intent);
}
@Override @Override
public void onTestNewFunction() { public void onTestNewFunction() {
Intent intent = createIntent().setAction(ACTION_TEST_NEW_FUNCTION); Intent intent = createIntent().setAction(ACTION_TEST_NEW_FUNCTION);

View File

@ -63,6 +63,7 @@ public interface DeviceService extends EventHandler {
String ACTION_ADD_CALENDAREVENT = PREFIX + ".action.add_calendarevent"; String ACTION_ADD_CALENDAREVENT = PREFIX + ".action.add_calendarevent";
String ACTION_DELETE_CALENDAREVENT = PREFIX + ".action.delete_calendarevent"; String ACTION_DELETE_CALENDAREVENT = PREFIX + ".action.delete_calendarevent";
String ACTION_SEND_CONFIGURATION = PREFIX + ".action.send_configuration"; String ACTION_SEND_CONFIGURATION = PREFIX + ".action.send_configuration";
String ACTION_READ_CONFIGURATION = PREFIX + ".action.read_configuration";
String ACTION_SEND_WEATHER = PREFIX + ".action.send_weather"; String ACTION_SEND_WEATHER = PREFIX + ".action.send_weather";
String ACTION_TEST_NEW_FUNCTION = PREFIX + ".action.test_new_function"; String ACTION_TEST_NEW_FUNCTION = PREFIX + ".action.test_new_function";
String ACTION_SET_FM_FREQUENCY = PREFIX + ".action.set_fm_frequency"; String ACTION_SET_FM_FREQUENCY = PREFIX + ".action.set_fm_frequency";

View File

@ -99,6 +99,7 @@ import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_RE
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_REQUEST_DEVICEINFO; import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_REQUEST_DEVICEINFO;
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_REQUEST_SCREENSHOT; import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_REQUEST_SCREENSHOT;
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_SEND_CONFIGURATION; import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_SEND_CONFIGURATION;
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_READ_CONFIGURATION;
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_SEND_WEATHER; import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_SEND_WEATHER;
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_SETCANNEDMESSAGES; import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_SETCANNEDMESSAGES;
import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_SETMUSICINFO; import static nodomain.freeyourgadget.gadgetbridge.model.DeviceService.ACTION_SETMUSICINFO;
@ -556,6 +557,11 @@ public class DeviceCommunicationService extends Service implements SharedPrefere
mDeviceSupport.onSendConfiguration(config); mDeviceSupport.onSendConfiguration(config);
break; break;
} }
case ACTION_READ_CONFIGURATION: {
String config = intent.getStringExtra(EXTRA_CONFIG);
mDeviceSupport.onReadConfiguration(config);
break;
}
case ACTION_TEST_NEW_FUNCTION: { case ACTION_TEST_NEW_FUNCTION: {
mDeviceSupport.onTestNewFunction(); mDeviceSupport.onTestNewFunction();
break; break;

View File

@ -359,6 +359,14 @@ public class ServiceDeviceSupport implements DeviceSupport {
delegate.onSendConfiguration(config); delegate.onSendConfiguration(config);
} }
@Override
public void onReadConfiguration(String config) {
if (checkBusy("read configuration: " + config)) {
return;
}
delegate.onReadConfiguration(config);
}
@Override @Override
public void onTestNewFunction() { public void onTestNewFunction() {
if (checkBusy("test new function event")) { if (checkBusy("test new function event")) {

View File

@ -642,6 +642,11 @@ public class HPlusSupport extends AbstractBTLEDeviceSupport {
} }
} }
@Override
public void onReadConfiguration(String config) {
}
@Override @Override
public void onTestNewFunction() { public void onTestNewFunction() {
LOG.info("Test New Function"); LOG.info("Test New Function");

View File

@ -1532,6 +1532,11 @@ public class HuamiSupport extends AbstractBTLEDeviceSupport {
} }
} }
@Override
public void onReadConfiguration(String config) {
}
@Override @Override
public void onTestNewFunction() { public void onTestNewFunction() {
try { try {

View File

@ -248,6 +248,11 @@ public class ID115Support extends AbstractBTLEDeviceSupport {
} }
@Override
public void onReadConfiguration(String config) {
}
@Override @Override
public void onTestNewFunction() { public void onTestNewFunction() {

View File

@ -449,6 +449,11 @@ public class TeclastH30Support extends AbstractBTLEDeviceSupport {
} }
@Override
public void onReadConfiguration(String config) {
}
@Override @Override
public void onTestNewFunction() { public void onTestNewFunction() {

View File

@ -124,4 +124,9 @@ public class LiveviewSupport extends AbstractSerialDeviceSupport {
public void onTestNewFunction() { public void onTestNewFunction() {
//nothing to do ATM //nothing to do ATM
} }
@Override
public void onReadConfiguration(String config) {
}
} }

View File

@ -1249,6 +1249,11 @@ public class MiBandSupport extends AbstractBTLEDeviceSupport {
// nothing yet // nothing yet
} }
@Override
public void onReadConfiguration(String config) {
}
@Override @Override
public void onTestNewFunction() { public void onTestNewFunction() {
try { try {

View File

@ -373,6 +373,11 @@ public class No1F1Support extends AbstractBTLEDeviceSupport {
} }
} }
@Override
public void onReadConfiguration(String config) {
}
@Override @Override
public void onTestNewFunction() { public void onTestNewFunction() {

View File

@ -238,6 +238,11 @@ public class PebbleSupport extends AbstractSerialDeviceSupport {
} }
} }
@Override
public void onReadConfiguration(String config) {
}
@Override @Override
public void onTestNewFunction() { public void onTestNewFunction() {
if (reconnect()) { if (reconnect()) {

View File

@ -124,6 +124,11 @@ public class RoidmiSupport extends AbstractSerialDeviceSupport {
} }
} }
@Override
public void onReadConfiguration(String config) {
}
@Override @Override
protected GBDeviceIoThread createDeviceIOThread() { protected GBDeviceIoThread createDeviceIOThread() {
return new RoidmiIoThread(getDevice(), getContext(), (RoidmiProtocol) getDeviceProtocol(), RoidmiSupport.this, getBluetoothAdapter()); return new RoidmiIoThread(getDevice(), getContext(), (RoidmiProtocol) getDeviceProtocol(), RoidmiSupport.this, getBluetoothAdapter());

View File

@ -284,6 +284,11 @@ public class VibratissimoSupport extends AbstractBTLEDeviceSupport {
} }
@Override
public void onReadConfiguration(String config) {
}
@Override @Override
public void onTestNewFunction() { public void onTestNewFunction() {

View File

@ -505,6 +505,11 @@ public class Watch9DeviceSupport extends AbstractBTLEDeviceSupport {
} }
} }
@Override
public void onReadConfiguration(String config) {
}
@Override @Override
public void onTestNewFunction() { public void onTestNewFunction() {

View File

@ -371,6 +371,11 @@ public class XWatchSupport extends AbstractBTLEDeviceSupport {
// nothing yet // nothing yet
} }
@Override
public void onReadConfiguration(String config) {
}
@Override @Override
public void onTestNewFunction() { public void onTestNewFunction() {
//Not supported //Not supported

View File

@ -19,6 +19,7 @@ package nodomain.freeyourgadget.gadgetbridge.service.devices.zetime;
import android.bluetooth.BluetoothGatt; import android.bluetooth.BluetoothGatt;
import android.bluetooth.BluetoothGattCharacteristic; import android.bluetooth.BluetoothGattCharacteristic;
import android.content.SharedPreferences;
import android.net.Uri; import android.net.Uri;
import android.widget.Toast; import android.widget.Toast;
@ -438,22 +439,22 @@ public class ZeTimeDeviceSupport extends AbstractBTLEDeviceSupport {
@Override @Override
public void onTestNewFunction() { public void onTestNewFunction() {
byte[] strength = { // byte[] strength = {
ZeTimeConstants.CMD_PREAMBLE, // ZeTimeConstants.CMD_PREAMBLE,
ZeTimeConstants.CMD_SHOCK_STRENGTH, // ZeTimeConstants.CMD_SHOCK_STRENGTH,
ZeTimeConstants.CMD_REQUEST, // ZeTimeConstants.CMD_REQUEST,
(byte)0x1, // (byte)0x1,
(byte)0x0, // (byte)0x0,
(byte)0x0, // (byte)0x0,
ZeTimeConstants.CMD_END // ZeTimeConstants.CMD_END
}; // };
try { // try {
TransactionBuilder builder = performInitialized("testNewFunction"); // TransactionBuilder builder = performInitialized("testNewFunction");
sendMsgToWatch(builder, strength); // sendMsgToWatch(builder, strength);
builder.queue(getQueue()); // builder.queue(getQueue());
} catch (IOException e) { // } catch (IOException e) {
GB.toast(getContext(), "Error on testing new function: " + e.getLocalizedMessage(), Toast.LENGTH_LONG, GB.ERROR); // GB.toast(getContext(), "Error on testing new function: " + e.getLocalizedMessage(), Toast.LENGTH_LONG, GB.ERROR);
} // }
} }
@Override @Override
@ -775,8 +776,6 @@ public class ZeTimeDeviceSupport extends AbstractBTLEDeviceSupport {
case ZeTimeConstants.CMD_BATTERY_POWER: case ZeTimeConstants.CMD_BATTERY_POWER:
handleBatteryInfo(data); handleBatteryInfo(data);
break; break;
case ZeTimeConstants.CMD_SHOCK_STRENGTH:
break;
case ZeTimeConstants.CMD_AVAIABLE_DATA: case ZeTimeConstants.CMD_AVAIABLE_DATA:
handleActivityFetching(data); handleActivityFetching(data);
break; break;
@ -792,6 +791,42 @@ public class ZeTimeDeviceSupport extends AbstractBTLEDeviceSupport {
case ZeTimeConstants.CMD_MUSIC_CONTROL: case ZeTimeConstants.CMD_MUSIC_CONTROL:
handleMusicControl(data); handleMusicControl(data);
break; break;
case ZeTimeConstants.CMD_TIME_SURFACE_SETTINGS:
getDateTimeFormat(data);
break;
case ZeTimeConstants.CMD_SHOCK_MODE:
getSignaling(data);
break;
case ZeTimeConstants.CMD_DO_NOT_DISTURB:
getDoNotDisturb(data);
break;
case ZeTimeConstants.CMD_ANALOG_MODE:
getAnalogMode(data);
break;
case ZeTimeConstants.CMD_CONTROL_DEVICE:
getActivityTracking(data);
break;
case ZeTimeConstants.CMD_DISPLAY_TIMEOUT:
getScreenTime(data);
break;
case ZeTimeConstants.CMD_USAGE_HABITS:
getWrist(data);
break;
case ZeTimeConstants.CMD_AUTO_HEARTRATE:
getHeartRateMeasurement(data);
break;
case ZeTimeConstants.CMD_HEARTRATE_ALARM_LIMITS:
getHeartRateLimits(data);
break;
case ZeTimeConstants.CMD_INACTIVITY_ALERT:
getInactivityAlert(data);
break;
case ZeTimeConstants.CMD_CALORIES_TYPE:
getCaloriesType(data);
break;
case ZeTimeConstants.CMD_SWITCH_SETTINGS:
getDisplayOnMovement(data);
break;
} }
} }
return true; return true;
@ -1661,7 +1696,7 @@ public class ZeTimeDeviceSupport extends AbstractBTLEDeviceSupport {
private void setDateFormate(TransactionBuilder builder) private void setDateFormate(TransactionBuilder builder)
{ {
Prefs prefs = GBApplication.getPrefs(); Prefs prefs = GBApplication.getPrefs();
int type = prefs.getInt(ZeTimeConstants.PREF_TIME_FORMAT, 0); int type = prefs.getInt(ZeTimeConstants.PREF_DATE_FORMAT, 0);
byte[] dateformat = {ZeTimeConstants.CMD_PREAMBLE, byte[] dateformat = {ZeTimeConstants.CMD_PREAMBLE,
ZeTimeConstants.CMD_TIME_SURFACE_SETTINGS, ZeTimeConstants.CMD_TIME_SURFACE_SETTINGS,
@ -1817,4 +1852,284 @@ public class ZeTimeDeviceSupport extends AbstractBTLEDeviceSupport {
sendMsgToWatch(builder, signaling); sendMsgToWatch(builder, signaling);
} }
@Override
public void onReadConfiguration(String config) {
try {
TransactionBuilder builder = performInitialized("readConfiguration");
if (!getDevice().isBusy()) {
getDevice().setBusyTask("readConfiguration");
}
byte[] configRead1 = {
ZeTimeConstants.CMD_PREAMBLE,
ZeTimeConstants.CMD_TIME_SURFACE_SETTINGS,
ZeTimeConstants.CMD_REQUEST,
(byte)0x1,
(byte)0x0,
(byte)0x0,
ZeTimeConstants.CMD_END
};
sendMsgToWatch(builder, configRead1);
byte[] configRead2 = new byte[configRead1.length];
System.arraycopy(configRead1, 0, configRead2, 0, configRead1.length);
configRead2[1] = ZeTimeConstants.CMD_SHOCK_MODE;
sendMsgToWatch(builder, configRead2);
byte[] configRead3 = new byte[configRead1.length];
System.arraycopy(configRead1, 0, configRead3, 0, configRead1.length);
configRead3[1] = ZeTimeConstants.CMD_DO_NOT_DISTURB;
sendMsgToWatch(builder, configRead3);
byte[] configRead4 = new byte[configRead1.length];
System.arraycopy(configRead1, 0, configRead4, 0, configRead1.length);
configRead4[1] = ZeTimeConstants.CMD_ANALOG_MODE;
sendMsgToWatch(builder, configRead4);
byte[] configRead5 = new byte[configRead1.length];
System.arraycopy(configRead1, 0, configRead5, 0, configRead1.length);
configRead5[1] = ZeTimeConstants.CMD_CONTROL_DEVICE;
sendMsgToWatch(builder, configRead5);
byte[] configRead6 = new byte[configRead1.length];
System.arraycopy(configRead1, 0, configRead6, 0, configRead1.length);
configRead6[1] = ZeTimeConstants.CMD_DISPLAY_TIMEOUT;
sendMsgToWatch(builder, configRead6);
byte[] configRead7 = new byte[configRead1.length];
System.arraycopy(configRead1, 0, configRead7, 0, configRead1.length);
configRead7[1] = ZeTimeConstants.CMD_USAGE_HABITS;
sendMsgToWatch(builder, configRead7);
byte[] configRead8 = new byte[configRead1.length];
System.arraycopy(configRead1, 0, configRead8, 0, configRead1.length);
configRead8[1] = ZeTimeConstants.CMD_AUTO_HEARTRATE;
sendMsgToWatch(builder, configRead8);
byte[] configRead9 = new byte[configRead1.length];
System.arraycopy(configRead1, 0, configRead9, 0, configRead1.length);
configRead9[1] = ZeTimeConstants.CMD_HEARTRATE_ALARM_LIMITS;
sendMsgToWatch(builder, configRead9);
byte[] configRead10 = new byte[configRead1.length];
System.arraycopy(configRead1, 0, configRead10, 0, configRead1.length);
configRead10[1] = ZeTimeConstants.CMD_INACTIVITY_ALERT;
sendMsgToWatch(builder, configRead10);
byte[] configRead11 = new byte[configRead1.length];
System.arraycopy(configRead1, 0, configRead11, 0, configRead1.length);
configRead11[1] = ZeTimeConstants.CMD_CALORIES_TYPE;
sendMsgToWatch(builder, configRead11);
byte[] configRead12 = new byte[configRead1.length];
System.arraycopy(configRead1, 0, configRead12, 0, configRead1.length);
configRead12[1] = ZeTimeConstants.CMD_SWITCH_SETTINGS;
sendMsgToWatch(builder, configRead12);
builder.queue(getQueue());
} catch (IOException e) {
GB.toast(getContext(), "Error reading configuration: " + e.getLocalizedMessage(), Toast.LENGTH_LONG, GB.ERROR);
}
}
private void onReadReminders() {
try {
TransactionBuilder builder = performInitialized("readReminders");
byte[] reminders = {
ZeTimeConstants.CMD_PREAMBLE,
ZeTimeConstants.CMD_REMINDERS,
ZeTimeConstants.CMD_REQUEST,
(byte)0x1,
(byte)0x0,
(byte)0x0,
ZeTimeConstants.CMD_END
};
sendMsgToWatch(builder, reminders);
builder.queue(getQueue());
} catch (IOException e) {
GB.toast(getContext(), "Error reading reminders: " + e.getLocalizedMessage(), Toast.LENGTH_LONG, GB.ERROR);
}
}
private void getDateTimeFormat(byte[] msg)
{
SharedPreferences.Editor prefs = GBApplication.getPrefs().getPreferences().edit();
prefs.putString(ZeTimeConstants.PREF_DATE_FORMAT, Integer.toString(msg[5]));
prefs.putString(ZeTimeConstants.PREF_TIME_FORMAT, Integer.toString(msg[6]));
prefs.apply();
}
private void getSignaling(byte[] msg)
{
SharedPreferences.Editor prefs = GBApplication.getPrefs().getPreferences().edit();
prefs.putString(ZeTimeConstants.PREF_ANTI_LOSS_SIGNALING, Integer.toString(msg[5]));
prefs.putString(ZeTimeConstants.PREF_CALL_SIGNALING, Integer.toString(msg[7]));
prefs.putString(ZeTimeConstants.PREF_MISSED_CALL_SIGNALING, Integer.toString(msg[8]));
prefs.putString(ZeTimeConstants.PREF_SMS_SIGNALING, Integer.toString(msg[9]));
prefs.putString(ZeTimeConstants.PREF_SOCIAL_SIGNALING, Integer.toString(msg[10]));
prefs.putString(ZeTimeConstants.PREF_EMAIL_SIGNALING, Integer.toString(msg[11]));
prefs.putString(ZeTimeConstants.PREF_CALENDAR_SIGNALING, Integer.toString(msg[12]));
prefs.putString(ZeTimeConstants.PREF_INACTIVITY_SIGNALING, Integer.toString(msg[13]));
prefs.putString(ZeTimeConstants.PREF_LOW_POWER_SIGNALING, Integer.toString(msg[14]));
prefs.apply();
}
private void getDoNotDisturb(byte[] msg)
{
SharedPreferences.Editor prefs = GBApplication.getPrefs().getPreferences().edit();
String starttime = String.format("%02d:%02d", msg[6], msg[7]);
String endtime = String.format("%02d:%02d", msg[8], msg[9]);
if(0x1 == msg[5]) {
prefs.putString(ZeTimeConstants.PREF_DO_NOT_DISTURB, "scheduled");
} else {
prefs.putString(ZeTimeConstants.PREF_DO_NOT_DISTURB, "off");
}
prefs.putString(ZeTimeConstants.PREF_DO_NOT_DISTURB_START, starttime);
prefs.putString(ZeTimeConstants.PREF_DO_NOT_DISTURB_END, endtime);
prefs.apply();
}
private void getAnalogMode(byte[] msg)
{
SharedPreferences.Editor prefs = GBApplication.getPrefs().getPreferences().edit();
prefs.putString(ZeTimeConstants.PREF_ANALOG_MODE, Integer.toString(msg[5]));
prefs.apply();
}
private void getActivityTracking(byte[] msg)
{
SharedPreferences.Editor prefs = GBApplication.getPrefs().getPreferences().edit();
if(0x1 == msg[6])
{
prefs.putBoolean(ZeTimeConstants.PREF_ACTIVITY_TRACKING, false);
} else
{
prefs.putBoolean(ZeTimeConstants.PREF_ACTIVITY_TRACKING, true);
}
prefs.apply();
}
private void getScreenTime(byte[] msg)
{
SharedPreferences.Editor prefs = GBApplication.getPrefs().getPreferences().edit();
prefs.putString(ZeTimeConstants.PREF_SCREENTIME, Integer.toString((msg[5] | (msg[6] << 8))));
prefs.apply();
}
private void getWrist(byte[] msg)
{
SharedPreferences.Editor prefs = GBApplication.getPrefs().getPreferences().edit();
if(ZeTimeConstants.WEAR_ON_LEFT_WRIST == msg[5]) {
prefs.putString(ZeTimeConstants.PREF_WRIST, "left");
} else if(ZeTimeConstants.WEAR_ON_RIGHT_WRIST == msg[5]) {
prefs.putString(ZeTimeConstants.PREF_WRIST, "right");
}
prefs.apply();
}
private void getHeartRateMeasurement(byte[] msg)
{
SharedPreferences.Editor prefs = GBApplication.getPrefs().getPreferences().edit();
prefs.putString(ZeTimeConstants.PREF_ZETIME_HEARTRATE_INTERVAL, Integer.toString((msg[5]*60))); // multiply with 60 because of the conversion from minutes to seconds
prefs.apply();
}
private void getHeartRateLimits(byte[] msg)
{
SharedPreferences.Editor prefs = GBApplication.getPrefs().getPreferences().edit();
prefs.apply();
}
private void getInactivityAlert(byte[] msg)
{
SharedPreferences.Editor prefs = GBApplication.getPrefs().getPreferences().edit();
String starttime = String.format("%02d:%02d", msg[7], msg[8]);
String endtime = String.format("%02d:%02d", msg[9], msg[10]);
prefs.putString(ZeTimeConstants.PREF_INACTIVITY_THRESHOLD, Integer.toString(msg[6]));
if(0 != msg[5])
{
prefs.putBoolean(ZeTimeConstants.PREF_INACTIVITY_ENABLE, true);
prefs.putString(ZeTimeConstants.PREF_INACTIVITY_START, starttime);
prefs.putString(ZeTimeConstants.PREF_INACTIVITY_END, endtime);
if(0 != (msg[5] & (1 << 0))) {
prefs.putBoolean(ZeTimeConstants.PREF_INACTIVITY_MO, true);
} else
{
prefs.putBoolean(ZeTimeConstants.PREF_INACTIVITY_MO, false);
}
if(0 != (msg[5] & (1 << 1))) {
prefs.putBoolean(ZeTimeConstants.PREF_INACTIVITY_TU, true);
} else
{
prefs.putBoolean(ZeTimeConstants.PREF_INACTIVITY_TU, false);
}
if(0 != (msg[5] & (1 << 2))) {
prefs.putBoolean(ZeTimeConstants.PREF_INACTIVITY_WE, true);
} else
{
prefs.putBoolean(ZeTimeConstants.PREF_INACTIVITY_WE, false);
}
if(0 != (msg[5] & (1 << 3))) {
prefs.putBoolean(ZeTimeConstants.PREF_INACTIVITY_TH, true);
} else
{
prefs.putBoolean(ZeTimeConstants.PREF_INACTIVITY_TH, false);
}
if(0 != (msg[5] & (1 << 4))) {
prefs.putBoolean(ZeTimeConstants.PREF_INACTIVITY_FR, true);
} else
{
prefs.putBoolean(ZeTimeConstants.PREF_INACTIVITY_FR, false);
}
if(0 != (msg[5] & (1 << 5))) {
prefs.putBoolean(ZeTimeConstants.PREF_INACTIVITY_SA, true);
} else
{
prefs.putBoolean(ZeTimeConstants.PREF_INACTIVITY_SA, false);
}
if(0 != (msg[5] & (1 << 6))) {
prefs.putBoolean(ZeTimeConstants.PREF_INACTIVITY_SU, true);
} else
{
prefs.putBoolean(ZeTimeConstants.PREF_INACTIVITY_SU, false);
}
}
prefs.apply();
}
private void getCaloriesType(byte[] msg)
{
SharedPreferences prefs = GBApplication.getPrefs().getPreferences();
SharedPreferences.Editor myedit = prefs.edit();
myedit.putString(ZeTimeConstants.PREF_CALORIES_TYPE, Integer.toString(msg[5]));
myedit.apply();
}
private void getDisplayOnMovement(byte[] msg)
{
SharedPreferences.Editor prefs = GBApplication.getPrefs().getPreferences().edit();
if(0 != (msg[6] & (1 << 6))) {
prefs.putBoolean(ZeTimeConstants.PREF_HANDMOVE_DISPLAY, true);
} else {
prefs.putBoolean(ZeTimeConstants.PREF_HANDMOVE_DISPLAY, false);
}
prefs.apply();
if (getDevice().isBusy()) {
getDevice().unsetBusyTask();
getDevice().sendDeviceUpdateIntent(getContext());
}
}
} }