1
0
mirror of https://codeberg.org/Freeyourgadget/Gadgetbridge synced 2024-11-28 21:06:50 +01:00

Changed notification timestamp format to be implemented specifically for GBD-200

This commit is contained in:
foxstidious 2023-10-05 19:43:19 -04:00 committed by José Rebelo
parent 6be7f7c9cc
commit 11bf0acf32
2 changed files with 65 additions and 25 deletions

View File

@ -47,11 +47,23 @@ import nodomain.freeyourgadget.gadgetbridge.service.DeviceSupport;
import nodomain.freeyourgadget.gadgetbridge.service.devices.casio.gbx100.CasioGBX100DeviceSupport;
public class CasioGBX100DeviceCoordinator extends CasioDeviceCoordinator {
/** CASIO brand identifier in GB Device name */
public static final String CASIO_IDENTIFIER = "CASIO";
/** Sub-model string for GBX-100 in GB Device name */
public static final String GBX_100_SUB_MODEL = "GBX-100";
/** Sub-model string for GBD-200 in GB Device name */
public static final String GBD_200_SUB_MODEL = "GBD-200";
/** Sub-model string for GBD-100 in GB Device name */
public static final String GBD_100_SUB_MODEL = "GBD-100";
/** Sub-model string for GBD-H1000 in GB Device name */
public static final String GBD_H1000_SUB_MODEL = "GBD-H1000";
protected static final Logger LOG = LoggerFactory.getLogger(CasioGBX100DeviceCoordinator.class);
@Override
protected Pattern getSupportedDeviceName() {
return Pattern.compile("CASIO.*(GBX-100|GBD-100|GBD-200|GBD-H1000)");
return Pattern.compile("CASIO.*(" + GBX_100_SUB_MODEL + "|" + GBD_100_SUB_MODEL + "|" + GBD_200_SUB_MODEL + "|" + GBD_H1000_SUB_MODEL + ")");
}
@Override

View File

@ -48,6 +48,7 @@ import nodomain.freeyourgadget.gadgetbridge.database.DBHandler;
import nodomain.freeyourgadget.gadgetbridge.database.DBHelper;
import nodomain.freeyourgadget.gadgetbridge.deviceevents.GBDeviceEventFindPhone;
import nodomain.freeyourgadget.gadgetbridge.devices.casio.CasioConstants;
import nodomain.freeyourgadget.gadgetbridge.devices.casio.gbx100.CasioGBX100DeviceCoordinator;
import nodomain.freeyourgadget.gadgetbridge.devices.casio.gbx100.CasioGBX100SampleProvider;
import nodomain.freeyourgadget.gadgetbridge.devices.makibeshr3.MakibesHR3Constants;
import nodomain.freeyourgadget.gadgetbridge.entities.CasioGBX100ActivitySample;
@ -286,13 +287,18 @@ public class CasioGBX100DeviceSupport extends Casio2C2DSupport implements Shared
arr[5] = (byte) 0x01; // Set to 0x00 to not vibrate/ring for this notification
arr[6] = icon;
// Unknonwn what these bytes are for
ZonedDateTime timestamp = ZonedDateTime.now();
String deviceName = getDevice().getName();
// It seems that GBD-200 has a different timestamp format than other variants.
if (deviceName.endsWith(CasioGBX100DeviceCoordinator.GBD_200_SUB_MODEL)) {
// These bytes are likely for designating year, but GBD-200 does not display them
// For now leave as 0's until exact encoding can be verified
arr[7] = (byte) 0x00;
arr[8] = (byte) 0x00;
arr[9] = (byte) 0x00;
arr[10] = (byte) 0x00;
ZonedDateTime timestamp = ZonedDateTime.now();
// Bytes 11 - 19 are timestamp
// Encode the timestamp of the notification
// Month
@ -310,8 +316,30 @@ public class CasioGBX100DeviceSupport extends Casio2C2DSupport implements Shared
arr[18] = (byte) (timestamp.getMinute() / 10 + 3);// Tens digit, but offset by 3 for some reason
arr[19] = (byte) (timestamp.getMinute() % 10);
// Thes bytes are likely for designating seconds, but GBD-200 does not display them.
// For now leave as 0's until exact encoding can be verified.
arr[20] = (byte) 0x00;
arr[21] = (byte) 0x00;
} else {
// Other devices appear to use ASCII from initial investigation, information below
// These bytes contain a timestamp, not yet decoded / implemented
// ASCII Codes:
/*arr[7] = (byte) 0x32; // 2
arr[8] = (byte) 0x30; // 0
arr[9] = (byte) 0x32; // 2
arr[10] = (byte) 0x30; // 0
arr[11] = (byte) 0x31; // 1
arr[12] = (byte) 0x31; // 1
arr[13] = (byte) 0x31; // 1
arr[14] = (byte) 0x33; // 3
arr[15] = (byte) 0x54; // T
arr[16] = (byte) 0x30; // 0
arr[17] = (byte) 0x39; // 9
arr[18] = (byte) 0x33; // 3
arr[19] = (byte) 0x31; // 1
arr[20] = (byte) 0x35; // 5
arr[21] = (byte) 0x33;*/// 3
}
byte[] copy = Arrays.copyOf(arr, arr.length + 2);
copy[copy.length-2] = 0;