Casio2C2D: refactor CasioConstants.characteristicToByte

This commit is contained in:
Johannes Krude 2023-08-28 21:52:14 +02:00 committed by José Rebelo
parent ad7b50793a
commit b6ba421a62
9 changed files with 89 additions and 81 deletions

View File

@ -145,29 +145,4 @@ public final class CasioConstants {
public static final int CASIO_AUTOREMOVE_MESSAGE_DELAY = 10000; public static final int CASIO_AUTOREMOVE_MESSAGE_DELAY = 10000;
public static Map<String, Byte> characteristicToByte = new HashMap<String, Byte>() {
{
put("CASIO_WATCH_NAME", (byte) 0x23);
put("CASIO_APP_INFORMATION", (byte) 0x22);
put("CASIO_BLE_FEATURES", (byte) 0x10);
put("CASIO_SETTING_FOR_BLE", (byte) 0x11);
put("CASIO_ADVERTISE_PARAMETER_MANAGER", (byte) 0x3b);
put("CASIO_CONNECTION_PARAMETER_MANAGER", (byte) 0x3a);
put("CASIO_MODULE_ID", (byte) 0x26);
put("CASIO_WATCH_CONDITION", (byte) 0x28);
put("CASIO_VERSION_INFORMATION", (byte) 0x20);
put("CASIO_DST_WATCH_STATE", (byte) 0x1d);
put("CASIO_DST_SETTING", (byte) 0x1e);
put("CASIO_WORLD_CITY", (byte) 0x1f);
put("CASIO_SERVICE_DISCOVERY_MANAGER", (byte) 0x47);
put("CASIO_CURRENT_TIME", (byte) 0x09);
put("CASIO_SETTING_FOR_USER_PROFILE", (byte) 0x45);
put("CASIO_SETTING_FOR_TARGET_VALUE", (byte) 0x43);
put("ALERT_LEVEL", (byte) 0x0a);
put("CASIO_SETTING_FOR_ALM", (byte) 0x15);
put("CASIO_SETTING_FOR_ALM2", (byte) 0x16);
put("CASIO_SETTING_FOR_BASIC", (byte) 0x13);
put("CASIO_CURRENT_TIME_MANAGER", (byte) 0x39);
}
};
} }

View File

@ -30,6 +30,29 @@ import nodomain.freeyourgadget.gadgetbridge.devices.casio.CasioConstants;
public abstract class Casio2C2DSupport extends CasioSupport { public abstract class Casio2C2DSupport extends CasioSupport {
public static final byte FEATURE_CURRENT_TIME = 0x09;
public static final byte FEATURE_ALERT_LEVEL = 0x0a;
public static final byte FEATURE_BLE_FEATURES = 0x10;
public static final byte FEATURE_SETTING_FOR_BLE = 0x11;
public static final byte FEATURE_SETTING_FOR_BASIC = 0x13;
public static final byte FEATURE_SETTING_FOR_ALM = 0x15;
public static final byte FEATURE_SETTING_FOR_ALM2 = 0x16;
public static final byte FEATURE_VERSION_INFORMATION = 0x20;
public static final byte FEATURE_APP_INFORMATION = 0x22;
public static final byte FEATURE_WATCH_NAME = 0x23;
public static final byte FEATURE_MODULE_ID = 0x26;
public static final byte FEATURE_WATCH_CONDITION = 0x28;
public static final byte FEATURE_DST_WATCH_STATE = 0x1d;
public static final byte FEATURE_DST_SETTING = 0x1e;
public static final byte FEATURE_WORLD_CITY = 0x1f;
public static final byte FEATURE_CURRENT_TIME_MANAGER = 0x39;
public static final byte FEATURE_CONNECTION_PARAMETER_MANAGER = 0x3a;
public static final byte FEATURE_ADVERTISE_PARAMETER_MANAGER = 0x3b;
public static final byte FEATURE_SETTING_FOR_TARGET_VALUE = 0x43;
public static final byte FEATURE_SETTING_FOR_USER_PROFILE = 0x45;
public static final byte FEATURE_SERVICE_DISCOVERY_MANAGER = 0x47;
public Casio2C2DSupport(Logger logger) { public Casio2C2DSupport(Logger logger) {
super(logger); super(logger);
} }
@ -44,7 +67,7 @@ public abstract class Casio2C2DSupport extends CasioSupport {
public void writeCurrentTime(TransactionBuilder builder, ZonedDateTime time) { public void writeCurrentTime(TransactionBuilder builder, ZonedDateTime time) {
byte[] arr = new byte[11]; byte[] arr = new byte[11];
arr[0] = CasioConstants.characteristicToByte.get("CASIO_CURRENT_TIME"); arr[0] = FEATURE_CURRENT_TIME;
byte[] tmp = prepareCurrentTime(time); byte[] tmp = prepareCurrentTime(time);
System.arraycopy(tmp, 0, arr, 1, 10); System.arraycopy(tmp, 0, arr, 1, 10);

View File

@ -211,14 +211,14 @@ public class CasioGBX100DeviceSupport extends Casio2C2DSupport implements Shared
return true; return true;
if (characteristicUUID.equals(CasioConstants.CASIO_ALL_FEATURES_CHARACTERISTIC_UUID)) { if (characteristicUUID.equals(CasioConstants.CASIO_ALL_FEATURES_CHARACTERISTIC_UUID)) {
if(data[0] == CasioConstants.characteristicToByte.get("ALERT_LEVEL")) { if(data[0] == FEATURE_ALERT_LEVEL) {
if(data[1] == 0x02) { if(data[1] == 0x02) {
onReverseFindDevice(true); onReverseFindDevice(true);
} else { } else {
onReverseFindDevice(false); onReverseFindDevice(false);
} }
return true; return true;
} else if(data[0] == CasioConstants.characteristicToByte.get("CASIO_CURRENT_TIME_MANAGER")) { } else if(data[0] == FEATURE_CURRENT_TIME_MANAGER) {
if(data[1] == 0x00) { if(data[1] == 0x00) {
try { try {
TransactionBuilder builder = performInitialized("writeCurrentTime"); TransactionBuilder builder = performInitialized("writeCurrentTime");
@ -509,8 +509,8 @@ public class CasioGBX100DeviceSupport extends Casio2C2DSupport implements Shared
if(!isConnected()) if(!isConnected())
return; return;
data1[0] = CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_ALM"); data1[0] = FEATURE_SETTING_FOR_ALM;
data2[0] = CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_ALM2"); data2[0] = FEATURE_SETTING_FOR_ALM2;
for(int i=0; i<alarms.size(); i++) for(int i=0; i<alarms.size(); i++)
{ {

View File

@ -30,6 +30,7 @@ import nodomain.freeyourgadget.gadgetbridge.GBApplication;
import nodomain.freeyourgadget.gadgetbridge.devices.casio.CasioConstants; import nodomain.freeyourgadget.gadgetbridge.devices.casio.CasioConstants;
import nodomain.freeyourgadget.gadgetbridge.service.btle.AbstractBTLEOperation; import nodomain.freeyourgadget.gadgetbridge.service.btle.AbstractBTLEOperation;
import nodomain.freeyourgadget.gadgetbridge.service.btle.TransactionBuilder; import nodomain.freeyourgadget.gadgetbridge.service.btle.TransactionBuilder;
import nodomain.freeyourgadget.gadgetbridge.service.devices.casio.Casio2C2DSupport;
import nodomain.freeyourgadget.gadgetbridge.service.devices.casio.gbx100.CasioGBX100DeviceSupport; import nodomain.freeyourgadget.gadgetbridge.service.devices.casio.gbx100.CasioGBX100DeviceSupport;
import nodomain.freeyourgadget.gadgetbridge.service.devices.miband.operations.OperationStatus; import nodomain.freeyourgadget.gadgetbridge.service.devices.miband.operations.OperationStatus;
import nodomain.freeyourgadget.gadgetbridge.util.BcdUtil; import nodomain.freeyourgadget.gadgetbridge.util.BcdUtil;
@ -59,7 +60,7 @@ public class GetConfigurationOperation extends AbstractBTLEOperation<CasioGBX100
@Override @Override
protected void doPerform() throws IOException { protected void doPerform() throws IOException {
byte[] command = new byte[1]; byte[] command = new byte[1];
command[0] = CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_USER_PROFILE"); command[0] = Casio2C2DSupport.FEATURE_SETTING_FOR_USER_PROFILE;
TransactionBuilder builder = performInitialized("getConfiguration"); TransactionBuilder builder = performInitialized("getConfiguration");
builder.setCallback(this); builder.setCallback(this);
support.writeAllFeaturesRequest(builder, command); support.writeAllFeaturesRequest(builder, command);
@ -85,7 +86,7 @@ public class GetConfigurationOperation extends AbstractBTLEOperation<CasioGBX100
private void requestBasicSettings() { private void requestBasicSettings() {
byte[] command = new byte[1]; byte[] command = new byte[1];
command[0] = CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_BASIC"); command[0] = Casio2C2DSupport.FEATURE_SETTING_FOR_BASIC;
try { try {
TransactionBuilder builder = performInitialized("getConfiguration"); TransactionBuilder builder = performInitialized("getConfiguration");
builder.setCallback(this); builder.setCallback(this);
@ -106,7 +107,7 @@ public class GetConfigurationOperation extends AbstractBTLEOperation<CasioGBX100
return true; return true;
if (characteristicUUID.equals(CasioConstants.CASIO_ALL_FEATURES_CHARACTERISTIC_UUID)) { if (characteristicUUID.equals(CasioConstants.CASIO_ALL_FEATURES_CHARACTERISTIC_UUID)) {
if (data[0] == CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_USER_PROFILE")) { if (data[0] == Casio2C2DSupport.FEATURE_SETTING_FOR_USER_PROFILE) {
boolean female = ((data[1] & 0x01) == 0x01); boolean female = ((data[1] & 0x01) == 0x01);
boolean right = ((data[1] & 0x02) == 0x02); boolean right = ((data[1] & 0x02) == 0x02);
byte[] compData = new byte[data.length]; byte[] compData = new byte[data.length];
@ -129,7 +130,7 @@ public class GetConfigurationOperation extends AbstractBTLEOperation<CasioGBX100
requestBasicSettings(); requestBasicSettings();
return true; return true;
} else if (data[0] == CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_BASIC")) { } else if (data[0] == Casio2C2DSupport.FEATURE_SETTING_FOR_BASIC) {
boolean timeformat = ((data[1] & 0x01) == 0x01); boolean timeformat = ((data[1] & 0x01) == 0x01);
boolean autolight = ((data[1] & 0x04) == 0x00); boolean autolight = ((data[1] & 0x04) == 0x00);
boolean key_vibration = (data[10] == 0x01); boolean key_vibration = (data[10] == 0x01);

View File

@ -31,6 +31,8 @@ import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice;
import nodomain.freeyourgadget.gadgetbridge.service.btle.AbstractBTLEOperation; import nodomain.freeyourgadget.gadgetbridge.service.btle.AbstractBTLEOperation;
import nodomain.freeyourgadget.gadgetbridge.service.btle.TransactionBuilder; import nodomain.freeyourgadget.gadgetbridge.service.btle.TransactionBuilder;
import nodomain.freeyourgadget.gadgetbridge.service.btle.actions.SetDeviceStateAction; import nodomain.freeyourgadget.gadgetbridge.service.btle.actions.SetDeviceStateAction;
import nodomain.freeyourgadget.gadgetbridge.service.devices.casio.Casio2C2DSupport;
import nodomain.freeyourgadget.gadgetbridge.service.devices.casio.gbx100.CasioGBX100DeviceSupport;
public class InitOperation extends AbstractBTLEOperation<CasioGBX100DeviceSupport> { public class InitOperation extends AbstractBTLEOperation<CasioGBX100DeviceSupport> {
private static final Logger LOG = LoggerFactory.getLogger(InitOperation.class); private static final Logger LOG = LoggerFactory.getLogger(InitOperation.class);
@ -91,47 +93,47 @@ public class InitOperation extends AbstractBTLEOperation<CasioGBX100DeviceSuppor
} }
private void requestWatchName(TransactionBuilder builder) { private void requestWatchName(TransactionBuilder builder) {
support.writeAllFeaturesRequest(builder, new byte[]{CasioConstants.characteristicToByte.get("CASIO_WATCH_NAME")}); support.writeAllFeaturesRequest(builder, new byte[]{Casio2C2DSupport.FEATURE_WATCH_NAME});
} }
private void requestWatchName() { private void requestWatchName() {
writeAllFeaturesRequest(new byte[]{CasioConstants.characteristicToByte.get("CASIO_WATCH_NAME")}); writeAllFeaturesRequest(new byte[]{Casio2C2DSupport.FEATURE_WATCH_NAME});
} }
private void requestBleConfiguration() { private void requestBleConfiguration() {
writeAllFeaturesRequest(new byte[]{CasioConstants.characteristicToByte.get("CASIO_BLE_FEATURES")}); writeAllFeaturesRequest(new byte[]{Casio2C2DSupport.FEATURE_BLE_FEATURES});
} }
private void requestBleSettings() { private void requestBleSettings() {
writeAllFeaturesRequest(new byte[]{CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_BLE")}); writeAllFeaturesRequest(new byte[]{Casio2C2DSupport.FEATURE_SETTING_FOR_BLE});
} }
private void requestAdvertisingParameters() { private void requestAdvertisingParameters() {
writeAllFeaturesRequest(new byte[]{CasioConstants.characteristicToByte.get("CASIO_ADVERTISE_PARAMETER_MANAGER")}); writeAllFeaturesRequest(new byte[]{Casio2C2DSupport.FEATURE_ADVERTISE_PARAMETER_MANAGER});
} }
private void requestConnectionParameters() { private void requestConnectionParameters() {
writeAllFeaturesRequest(new byte[]{CasioConstants.characteristicToByte.get("CASIO_CONNECTION_PARAMETER_MANAGER")}); writeAllFeaturesRequest(new byte[]{Casio2C2DSupport.FEATURE_CONNECTION_PARAMETER_MANAGER});
} }
private void requestModuleId() { private void requestModuleId() {
writeAllFeaturesRequest(new byte[]{CasioConstants.characteristicToByte.get("CASIO_MODULE_ID")}); writeAllFeaturesRequest(new byte[]{Casio2C2DSupport.FEATURE_MODULE_ID});
} }
private void requestWatchCondition() { private void requestWatchCondition() {
writeAllFeaturesRequest(new byte[]{CasioConstants.characteristicToByte.get("CASIO_WATCH_CONDITION")}); writeAllFeaturesRequest(new byte[]{Casio2C2DSupport.FEATURE_WATCH_CONDITION});
} }
private void requestVersionInformation() { private void requestVersionInformation() {
writeAllFeaturesRequest(new byte[]{CasioConstants.characteristicToByte.get("CASIO_VERSION_INFORMATION")}); writeAllFeaturesRequest(new byte[]{Casio2C2DSupport.FEATURE_VERSION_INFORMATION});
} }
private void requestDstWatchState() { private void requestDstWatchState() {
writeAllFeaturesRequest(new byte[]{CasioConstants.characteristicToByte.get("CASIO_DST_WATCH_STATE")}); writeAllFeaturesRequest(new byte[]{Casio2C2DSupport.FEATURE_DST_WATCH_STATE});
} }
private void requestDstSetting() { private void requestDstSetting() {
writeAllFeaturesRequest(new byte[]{CasioConstants.characteristicToByte.get("CASIO_DST_SETTING")}); writeAllFeaturesRequest(new byte[]{Casio2C2DSupport.FEATURE_DST_SETTING});
} }
private void writeAppInformation() { private void writeAppInformation() {
@ -139,7 +141,7 @@ public class InitOperation extends AbstractBTLEOperation<CasioGBX100DeviceSuppor
// preferences instead of hard-coding it here // preferences instead of hard-coding it here
// CASIO_APP_INFORMATION: // CASIO_APP_INFORMATION:
byte arr[] = new byte[12]; byte arr[] = new byte[12];
arr[0] = CasioConstants.characteristicToByte.get("CASIO_APP_INFORMATION"); arr[0] = Casio2C2DSupport.FEATURE_APP_INFORMATION;
for(int i=0; i<10; i++) for(int i=0; i<10; i++)
arr[i+1] = (byte) (i & 0xff); arr[i+1] = (byte) (i & 0xff);
arr[11] = 2; arr[11] = 2;
@ -196,7 +198,7 @@ public class InitOperation extends AbstractBTLEOperation<CasioGBX100DeviceSuppor
// arr[18] = advertiseParamPeriodUntilSuspensionOfAutoAdvertise >> 8 & 0xff; // arr[18] = advertiseParamPeriodUntilSuspensionOfAutoAdvertise >> 8 & 0xff;
byte arr[] = new byte[20]; byte arr[] = new byte[20];
arr[0] = CasioConstants.characteristicToByte.get("CASIO_ADVERTISE_PARAMETER_MANAGER"); arr[0] = Casio2C2DSupport.FEATURE_ADVERTISE_PARAMETER_MANAGER;
arr[1] = (byte)0x50; arr[1] = (byte)0x50;
arr[2] = (byte)0x00; arr[2] = (byte)0x00;
arr[3] = (byte)0x0a; arr[3] = (byte)0x0a;
@ -236,7 +238,7 @@ public class InitOperation extends AbstractBTLEOperation<CasioGBX100DeviceSuppor
// arr[8] = connectionParamSupervisionTimeout >> 8 & 0xff; // arr[8] = connectionParamSupervisionTimeout >> 8 & 0xff;
byte[] arr = new byte[10]; byte[] arr = new byte[10];
arr[0] = CasioConstants.characteristicToByte.get("CASIO_CONNECTION_PARAMETER_MANAGER"); arr[0] = Casio2C2DSupport.FEATURE_CONNECTION_PARAMETER_MANAGER;
arr[1] = (byte)0x00; arr[1] = (byte)0x00;
arr[2] = (byte)0x34; arr[2] = (byte)0x34;
arr[3] = (byte)0x01; arr[3] = (byte)0x01;
@ -292,43 +294,43 @@ public class InitOperation extends AbstractBTLEOperation<CasioGBX100DeviceSuppor
} }
if(characteristicUUID.equals(CasioConstants.CASIO_ALL_FEATURES_CHARACTERISTIC_UUID)) { if(characteristicUUID.equals(CasioConstants.CASIO_ALL_FEATURES_CHARACTERISTIC_UUID)) {
if(data[0] == CasioConstants.characteristicToByte.get("CASIO_WATCH_NAME")) { if(data[0] == Casio2C2DSupport.FEATURE_WATCH_NAME) {
LOG.debug("Got watch name, requesting BLE features; should write CASIO_APP_INFORMATION"); LOG.debug("Got watch name, requesting BLE features; should write CASIO_APP_INFORMATION");
writeAppInformation(); writeAppInformation();
// The rest of the init sequence is not strictly needed; we keep // The rest of the init sequence is not strictly needed; we keep
// it here for future reference. // it here for future reference.
if(mFirstConnect) if(mFirstConnect)
requestBleConfiguration(); requestBleConfiguration();
} else if(data[0] == CasioConstants.characteristicToByte.get("CASIO_BLE_FEATURES")) { } else if(data[0] == Casio2C2DSupport.FEATURE_BLE_FEATURES) {
LOG.debug("Got BLE features, requesting BLE settings"); LOG.debug("Got BLE features, requesting BLE settings");
requestBleSettings(); requestBleSettings();
} else if(data[0] == CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_BLE")) { } else if(data[0] == Casio2C2DSupport.FEATURE_SETTING_FOR_BLE) {
LOG.debug("Got BLE settings, requesting advertisement parameters; should write BLE settings"); LOG.debug("Got BLE settings, requesting advertisement parameters; should write BLE settings");
writeBleSettings(data); writeBleSettings(data);
requestAdvertisingParameters(); requestAdvertisingParameters();
} else if(data[0] == CasioConstants.characteristicToByte.get("CASIO_ADVERTISE_PARAMETER_MANAGER")) { } else if(data[0] == Casio2C2DSupport.FEATURE_ADVERTISE_PARAMETER_MANAGER) {
LOG.debug("Got advertisement parameters, requesting connection parameters; should write advertisement parameters"); LOG.debug("Got advertisement parameters, requesting connection parameters; should write advertisement parameters");
writeAdvertisingParameters(); writeAdvertisingParameters();
requestConnectionParameters(); requestConnectionParameters();
} else if(data[0] == CasioConstants.characteristicToByte.get("CASIO_CONNECTION_PARAMETER_MANAGER")) { } else if(data[0] == Casio2C2DSupport.FEATURE_CONNECTION_PARAMETER_MANAGER) {
LOG.debug("Got connection parameters, requesting module ID; should write connection parameters"); LOG.debug("Got connection parameters, requesting module ID; should write connection parameters");
writeConnectionParameters(); writeConnectionParameters();
requestModuleId(); requestModuleId();
} else if(data[0] == CasioConstants.characteristicToByte.get("CASIO_MODULE_ID")) { } else if(data[0] == Casio2C2DSupport.FEATURE_MODULE_ID) {
LOG.debug("Got module ID, requesting watch condition"); LOG.debug("Got module ID, requesting watch condition");
requestWatchCondition(); requestWatchCondition();
} else if(data[0] == CasioConstants.characteristicToByte.get("CASIO_WATCH_CONDITION")) { } else if(data[0] == Casio2C2DSupport.FEATURE_WATCH_CONDITION) {
LOG.debug("Got watch condition, requesting version information"); LOG.debug("Got watch condition, requesting version information");
requestVersionInformation(); requestVersionInformation();
} else if(data[0] == CasioConstants.characteristicToByte.get("CASIO_VERSION_INFORMATION")) { } else if(data[0] == Casio2C2DSupport.FEATURE_VERSION_INFORMATION) {
LOG.debug("Got version information, requesting DST watch state"); LOG.debug("Got version information, requesting DST watch state");
requestDstWatchState(); requestDstWatchState();
} else if(data[0] == CasioConstants.characteristicToByte.get("CASIO_DST_WATCH_STATE")) { } else if(data[0] == Casio2C2DSupport.FEATURE_DST_WATCH_STATE) {
LOG.debug("Got DST watch state, requesting DST setting; should write DST watch state"); LOG.debug("Got DST watch state, requesting DST setting; should write DST watch state");
requestDstSetting(); requestDstSetting();
} else if(data[0] == CasioConstants.characteristicToByte.get("CASIO_DST_SETTING")) { } else if(data[0] == Casio2C2DSupport.FEATURE_DST_SETTING) {
LOG.debug("Got DST setting, waiting...; should write DST setting and location and radio information"); LOG.debug("Got DST setting, waiting...; should write DST setting and location and radio information");
} else if(data[0] == CasioConstants.characteristicToByte.get("CASIO_SERVICE_DISCOVERY_MANAGER")) { } else if(data[0] == Casio2C2DSupport.FEATURE_SERVICE_DISCOVERY_MANAGER) {
if(data[1] == 0x02) { if(data[1] == 0x02) {
// The writeAllFeaturesInit request triggers bonding. However, the transaction // The writeAllFeaturesInit request triggers bonding. However, the transaction
// never completes. Instead, the watch sends 0x4701 notification and we abort // never completes. Instead, the watch sends 0x4701 notification and we abort

View File

@ -33,6 +33,7 @@ import nodomain.freeyourgadget.gadgetbridge.devices.casio.CasioConstants;
import nodomain.freeyourgadget.gadgetbridge.model.ActivityUser; import nodomain.freeyourgadget.gadgetbridge.model.ActivityUser;
import nodomain.freeyourgadget.gadgetbridge.service.btle.AbstractBTLEOperation; import nodomain.freeyourgadget.gadgetbridge.service.btle.AbstractBTLEOperation;
import nodomain.freeyourgadget.gadgetbridge.service.btle.TransactionBuilder; import nodomain.freeyourgadget.gadgetbridge.service.btle.TransactionBuilder;
import nodomain.freeyourgadget.gadgetbridge.service.devices.casio.Casio2C2DSupport;
import nodomain.freeyourgadget.gadgetbridge.service.devices.casio.gbx100.CasioGBX100DeviceSupport; import nodomain.freeyourgadget.gadgetbridge.service.devices.casio.gbx100.CasioGBX100DeviceSupport;
import nodomain.freeyourgadget.gadgetbridge.service.devices.miband.operations.OperationStatus; import nodomain.freeyourgadget.gadgetbridge.service.devices.miband.operations.OperationStatus;
import nodomain.freeyourgadget.gadgetbridge.util.BcdUtil; import nodomain.freeyourgadget.gadgetbridge.util.BcdUtil;
@ -65,7 +66,7 @@ public class SetConfigurationOperation extends AbstractBTLEOperation<CasioGBX10
@Override @Override
protected void doPerform() throws IOException { protected void doPerform() throws IOException {
byte[] command = new byte[1]; byte[] command = new byte[1];
command[0] = CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_USER_PROFILE"); command[0] = Casio2C2DSupport.FEATURE_SETTING_FOR_USER_PROFILE;
TransactionBuilder builder = performInitialized("getConfiguration"); TransactionBuilder builder = performInitialized("getConfiguration");
builder.setCallback(this); builder.setCallback(this);
support.writeAllFeaturesRequest(builder, command); support.writeAllFeaturesRequest(builder, command);
@ -85,7 +86,7 @@ public class SetConfigurationOperation extends AbstractBTLEOperation<CasioGBX10
byte[] oldData = new byte[data.length]; byte[] oldData = new byte[data.length];
System.arraycopy(data, 0, oldData, 0, data.length); System.arraycopy(data, 0, oldData, 0, data.length);
if (data[0] == CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_USER_PROFILE")) { if (data[0] == Casio2C2DSupport.FEATURE_SETTING_FOR_USER_PROFILE) {
ActivityUser user = new ActivityUser(); ActivityUser user = new ActivityUser();
boolean all = (option == CasioConstants.ConfigurationOption.OPTION_ALL); boolean all = (option == CasioConstants.ConfigurationOption.OPTION_ALL);
@ -158,7 +159,7 @@ public class SetConfigurationOperation extends AbstractBTLEOperation<CasioGBX10
} }
} }
return true; return true;
} else if (data[0] == CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_TARGET_VALUE")) { } else if (data[0] == Casio2C2DSupport.FEATURE_SETTING_FOR_TARGET_VALUE) {
ActivityUser user = new ActivityUser(); ActivityUser user = new ActivityUser();
boolean all = (option == CasioConstants.ConfigurationOption.OPTION_ALL); boolean all = (option == CasioConstants.ConfigurationOption.OPTION_ALL);
@ -199,7 +200,7 @@ public class SetConfigurationOperation extends AbstractBTLEOperation<CasioGBX10
} }
} }
return true; return true;
} else if(data[0] == CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_BASIC")) { } else if(data[0] == Casio2C2DSupport.FEATURE_SETTING_FOR_BASIC) {
SharedPreferences sharedPreferences = GBApplication.getDeviceSpecificSharedPrefs(getDevice().getAddress()); SharedPreferences sharedPreferences = GBApplication.getDeviceSpecificSharedPrefs(getDevice().getAddress());
GBPrefs gbPrefs = new GBPrefs(new Prefs(GBApplication.getDeviceSpecificSharedPrefs(getDevice().getAddress()))); GBPrefs gbPrefs = new GBPrefs(new Prefs(GBApplication.getDeviceSpecificSharedPrefs(getDevice().getAddress())));
@ -274,7 +275,7 @@ public class SetConfigurationOperation extends AbstractBTLEOperation<CasioGBX10
private void requestBasicSettings() { private void requestBasicSettings() {
byte[] command = new byte[1]; byte[] command = new byte[1];
command[0] = CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_BASIC"); command[0] = Casio2C2DSupport.FEATURE_SETTING_FOR_BASIC;
try { try {
TransactionBuilder builder = performInitialized("getConfiguration"); TransactionBuilder builder = performInitialized("getConfiguration");
builder.setCallback(this); builder.setCallback(this);
@ -287,7 +288,7 @@ public class SetConfigurationOperation extends AbstractBTLEOperation<CasioGBX10
private void requestTargetSettings() { private void requestTargetSettings() {
byte[] command = new byte[1]; byte[] command = new byte[1];
command[0] = CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_TARGET_VALUE"); command[0] = Casio2C2DSupport.FEATURE_SETTING_FOR_TARGET_VALUE;
try { try {
TransactionBuilder builder = performInitialized("getConfiguration"); TransactionBuilder builder = performInitialized("getConfiguration");
builder.setCallback(this); builder.setCallback(this);
@ -308,15 +309,15 @@ public class SetConfigurationOperation extends AbstractBTLEOperation<CasioGBX10
return true; return true;
if (characteristicUUID.equals(CasioConstants.CASIO_ALL_FEATURES_CHARACTERISTIC_UUID)) { if (characteristicUUID.equals(CasioConstants.CASIO_ALL_FEATURES_CHARACTERISTIC_UUID)) {
if(data[0] == CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_USER_PROFILE")) { if(data[0] == Casio2C2DSupport.FEATURE_SETTING_FOR_USER_PROFILE) {
requestTargetSettings(); requestTargetSettings();
return true; return true;
} }
if(data[0] == CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_TARGET_VALUE")) { if(data[0] == Casio2C2DSupport.FEATURE_SETTING_FOR_TARGET_VALUE) {
requestBasicSettings(); requestBasicSettings();
return true; return true;
} }
if(data[0] == CasioConstants.characteristicToByte.get("CASIO_SETTING_FOR_BASIC")) { if(data[0] == Casio2C2DSupport.FEATURE_SETTING_FOR_BASIC) {
operationFinished(); operationFinished();
return true; return true;
} }

View File

@ -69,4 +69,5 @@ public class CasioGWB5600DeviceSupport extends Casio2C2DSupport {
return builder; return builder;
} }
} }

View File

@ -30,7 +30,8 @@ import java.time.zone.ZoneRules;
import java.util.Arrays; import java.util.Arrays;
import java.util.List; import java.util.List;
import nodomain.freeyourgadget.gadgetbridge.devices.casio.CasioConstants; import nodomain.freeyourgadget.gadgetbridge.service.devices.casio.Casio2C2DSupport;
public class CasioGWB5600TimeZone { public class CasioGWB5600TimeZone {
@ -130,13 +131,13 @@ PONTA DELGADA E4 00 FC 04 02
static public byte[] dstWatchStateRequest(int slot) { static public byte[] dstWatchStateRequest(int slot) {
// request only even slots, the response will also contain the next odd slot // request only even slots, the response will also contain the next odd slot
return new byte[] { return new byte[] {
CasioConstants.characteristicToByte.get("CASIO_DST_WATCH_STATE"), Casio2C2DSupport.FEATURE_DST_WATCH_STATE,
(byte) slot}; (byte) slot};
} }
static public byte[] dstWatchStateBytes(int slotA, CasioGWB5600TimeZone zoneA, int slotB, CasioGWB5600TimeZone zoneB) { static public byte[] dstWatchStateBytes(int slotA, CasioGWB5600TimeZone zoneA, int slotB, CasioGWB5600TimeZone zoneB) {
return new byte[] { return new byte[] {
CasioConstants.characteristicToByte.get("CASIO_DST_WATCH_STATE"), Casio2C2DSupport.FEATURE_DST_WATCH_STATE,
(byte) slotA, (byte) slotA,
(byte) slotB, (byte) slotB,
zoneA.dstSetting, zoneA.dstSetting,
@ -150,13 +151,13 @@ PONTA DELGADA E4 00 FC 04 02
static public byte[] dstSettingRequest(int slot) { static public byte[] dstSettingRequest(int slot) {
return new byte[] { return new byte[] {
CasioConstants.characteristicToByte.get("CASIO_DST_SETTING"), Casio2C2DSupport.FEATURE_DST_SETTING,
(byte) slot}; (byte) slot};
} }
public byte[] dstSettingBytes(int slot) { public byte[] dstSettingBytes(int slot) {
return new byte[] { return new byte[] {
CasioConstants.characteristicToByte.get("CASIO_DST_SETTING"), Casio2C2DSupport.FEATURE_DST_SETTING,
(byte) slot, (byte) slot,
number[0], number[0],
number[1], number[1],
@ -167,13 +168,13 @@ PONTA DELGADA E4 00 FC 04 02
static public byte[] worldCityRequest(int slot) { static public byte[] worldCityRequest(int slot) {
return new byte[] { return new byte[] {
CasioConstants.characteristicToByte.get("CASIO_WORLD_CITY"), Casio2C2DSupport.FEATURE_WORLD_CITY,
(byte) slot}; (byte) slot};
} }
public byte[] worldCityBytes(int slot) { public byte[] worldCityBytes(int slot) {
byte[] bytes = { byte[] bytes = {
CasioConstants.characteristicToByte.get("CASIO_WORLD_CITY"), Casio2C2DSupport.FEATURE_WORLD_CITY,
(byte) slot, (byte) slot,
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}; 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
System.arraycopy(name, 0, bytes, 2, Math.min(name.length, 18)); System.arraycopy(name, 0, bytes, 2, Math.min(name.length, 18));
@ -189,7 +190,7 @@ PONTA DELGADA E4 00 FC 04 02
byte dstSetting = 0; byte dstSetting = 0;
for (byte[] response: responses) { for (byte[] response: responses) {
if (response[0] == CasioConstants.characteristicToByte.get("CASIO_DST_WATCH_STATE") && response.length >= 9) { if (response[0] == Casio2C2DSupport.FEATURE_DST_WATCH_STATE && response.length >= 9) {
if (response[1] == slot) { if (response[1] == slot) {
dstSetting = response[3]; dstSetting = response[3];
number = new byte[] {response[5], response[6]}; number = new byte[] {response[5], response[6]};
@ -198,12 +199,12 @@ PONTA DELGADA E4 00 FC 04 02
dstSetting = response[4]; dstSetting = response[4];
number = new byte[] {response[7], response[8]}; number = new byte[] {response[7], response[8]};
} }
} else if (response[0] == CasioConstants.characteristicToByte.get("CASIO_DST_SETTING") && response.length >= 7 && response[1] == slot) { } else if (response[0] == Casio2C2DSupport.FEATURE_DST_SETTING && response.length >= 7 && response[1] == slot) {
number = new byte[] {response[2], response[3]}; number = new byte[] {response[2], response[3]};
offset = response[4]; offset = response[4];
dstOffset = response[5]; dstOffset = response[5];
dstRules = response[6]; dstRules = response[6];
} else if (response[0] == CasioConstants.characteristicToByte.get("CASIO_WORLD_CITY") && response.length >= 2 && response[1] == slot) { } else if (response[0] == Casio2C2DSupport.FEATURE_WORLD_CITY && response.length >= 2 && response[1] == slot) {
int size; int size;
for (size = 0; size < response.length-2; size++) { for (size = 0; size < response.length-2; size++) {
if (response[2+size] == 0) { if (response[2+size] == 0) {

View File

@ -39,6 +39,10 @@ import nodomain.freeyourgadget.gadgetbridge.service.btle.AbstractBTLEOperation;
import nodomain.freeyourgadget.gadgetbridge.service.btle.TransactionBuilder; import nodomain.freeyourgadget.gadgetbridge.service.btle.TransactionBuilder;
import nodomain.freeyourgadget.gadgetbridge.service.btle.actions.SetDeviceStateAction; import nodomain.freeyourgadget.gadgetbridge.service.btle.actions.SetDeviceStateAction;
import nodomain.freeyourgadget.gadgetbridge.service.devices.miband.operations.OperationStatus; import nodomain.freeyourgadget.gadgetbridge.service.devices.miband.operations.OperationStatus;
import nodomain.freeyourgadget.gadgetbridge.devices.casio.CasioConstants;
import nodomain.freeyourgadget.gadgetbridge.service.devices.casio.Casio2C2DSupport;
import nodomain.freeyourgadget.gadgetbridge.service.devices.casio.gwb5600.CasioGWB5600DeviceSupport;
import nodomain.freeyourgadget.gadgetbridge.service.devices.casio.gwb5600.CasioGWB5600TimeZone;
public class InitOperation extends AbstractBTLEOperation<CasioGWB5600DeviceSupport> { public class InitOperation extends AbstractBTLEOperation<CasioGWB5600DeviceSupport> {
private static final Logger LOG = LoggerFactory.getLogger(InitOperation.class); private static final Logger LOG = LoggerFactory.getLogger(InitOperation.class);
@ -79,9 +83,9 @@ public class InitOperation extends AbstractBTLEOperation<CasioGWB5600DeviceSuppo
byte[] data = characteristic.getValue(); byte[] data = characteristic.getValue();
if (characteristicUUID.equals(CasioConstants.CASIO_ALL_FEATURES_CHARACTERISTIC_UUID) && data.length > 0 && if (characteristicUUID.equals(CasioConstants.CASIO_ALL_FEATURES_CHARACTERISTIC_UUID) && data.length > 0 &&
(data[0] == CasioConstants.characteristicToByte.get("CASIO_DST_WATCH_STATE") || (data[0] == Casio2C2DSupport.FEATURE_DST_WATCH_STATE ||
data[0] == CasioConstants.characteristicToByte.get("CASIO_DST_SETTING") || data[0] == Casio2C2DSupport.FEATURE_DST_SETTING ||
data[0] == CasioConstants.characteristicToByte.get("CASIO_WORLD_CITY"))) { data[0] == Casio2C2DSupport.FEATURE_WORLD_CITY)) {
responses.add(data); responses.add(data);
if (responses.size() == 13) { if (responses.size() == 13) {
TransactionBuilder builder = createTransactionBuilder("setClocks"); TransactionBuilder builder = createTransactionBuilder("setClocks");