mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge
synced 2025-01-13 19:27:33 +01:00
Xiaomi: improve battery level and charger status processing
Because the reporting of battery state is inconsistent between different models, the device's battery state was not correctly processed in GB. For at least the firmware on the Xiaomi Watch S1 Active, the charger state is broadcast through a separate message from the message containing the battery level. Even though the battery level was requested by GB upon receiving this broadcast, the charger state got discarded as it was expected to also be included in the result of the subsequent request. This patch changes the name of the `Charger` message to `DeviceState` and includes more fields that may be presented by some device models. Furthemore, the broadcast is cached so that the charger state can be processed from this cache instead of the battery level response message.
This commit is contained in:
parent
405596d960
commit
b902ee96c3
@ -74,10 +74,11 @@ public class XiaomiSystemService extends AbstractXiaomiService implements Xiaomi
|
|||||||
public static final int CMD_PASSWORD_SET = 21;
|
public static final int CMD_PASSWORD_SET = 21;
|
||||||
public static final int CMD_DISPLAY_ITEMS_GET = 29;
|
public static final int CMD_DISPLAY_ITEMS_GET = 29;
|
||||||
public static final int CMD_DISPLAY_ITEMS_SET = 30;
|
public static final int CMD_DISPLAY_ITEMS_SET = 30;
|
||||||
public static final int CMD_CHARGER = 79;
|
public static final int CMD_DEVICE_STATE = 79;
|
||||||
|
|
||||||
// Not null if we're installing a firmware
|
// Not null if we're installing a firmware
|
||||||
private XiaomiFWHelper fwHelper = null;
|
private XiaomiFWHelper fwHelper = null;
|
||||||
|
private XiaomiProto.DeviceState cachedDeviceState = null;
|
||||||
|
|
||||||
public XiaomiSystemService(final XiaomiSupport support) {
|
public XiaomiSystemService(final XiaomiSupport support) {
|
||||||
super(support);
|
super(support);
|
||||||
@ -129,8 +130,13 @@ public class XiaomiSystemService extends AbstractXiaomiService implements Xiaomi
|
|||||||
case CMD_DISPLAY_ITEMS_GET:
|
case CMD_DISPLAY_ITEMS_GET:
|
||||||
handleDisplayItems(cmd.getSystem().getDisplayItems());
|
handleDisplayItems(cmd.getSystem().getDisplayItems());
|
||||||
return;
|
return;
|
||||||
case CMD_CHARGER:
|
case CMD_DEVICE_STATE:
|
||||||
// charger event, request battery state
|
// some devices (e.g. Xiaomi Watch S1 Active) only broadcast the charger state through
|
||||||
|
// this message, so this will need to be kept cached to process when the battery levels
|
||||||
|
// get requested
|
||||||
|
cachedDeviceState = cmd.getSystem().getDeviceState();
|
||||||
|
|
||||||
|
// request battery state to request battery level and charger state on supported models
|
||||||
getSupport().sendCommand("request battery state", COMMAND_TYPE, CMD_BATTERY);
|
getSupport().sendCommand("request battery state", COMMAND_TYPE, CMD_BATTERY);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -250,7 +256,16 @@ public class XiaomiSystemService extends AbstractXiaomiService implements Xiaomi
|
|||||||
final GBDeviceEventBatteryInfo batteryInfo = new GBDeviceEventBatteryInfo();
|
final GBDeviceEventBatteryInfo batteryInfo = new GBDeviceEventBatteryInfo();
|
||||||
batteryInfo.batteryIndex = 0;
|
batteryInfo.batteryIndex = 0;
|
||||||
batteryInfo.level = battery.getLevel();
|
batteryInfo.level = battery.getLevel();
|
||||||
switch (battery.getState()) {
|
|
||||||
|
int chargerState = battery.getState();
|
||||||
|
|
||||||
|
// if device state is cached and the charging state there is set, take the charger status
|
||||||
|
// from there
|
||||||
|
if (cachedDeviceState != null && cachedDeviceState.hasChargingState()) {
|
||||||
|
chargerState = cachedDeviceState.getChargingState();
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (chargerState) {
|
||||||
case 1:
|
case 1:
|
||||||
batteryInfo.state = BatteryState.BATTERY_CHARGING;
|
batteryInfo.state = BatteryState.BATTERY_CHARGING;
|
||||||
break;
|
break;
|
||||||
|
@ -130,7 +130,7 @@ message System {
|
|||||||
optional VibrationPatternAck vibrationPatternAck = 43;
|
optional VibrationPatternAck vibrationPatternAck = 43;
|
||||||
|
|
||||||
// 2, 79
|
// 2, 79
|
||||||
optional Charger charger = 49;
|
optional DeviceState deviceState = 49;
|
||||||
}
|
}
|
||||||
|
|
||||||
message Power {
|
message Power {
|
||||||
@ -299,8 +299,17 @@ message Vibration {
|
|||||||
optional uint32 ms = 2;
|
optional uint32 ms = 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
message Charger {
|
message DeviceActivityState {
|
||||||
optional uint32 state = 1; // 1 charging, 2 not charging
|
optional uint32 activityType = 1;
|
||||||
|
optional uint32 currentActivityState = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message DeviceState {
|
||||||
|
optional uint32 chargingState = 1; // 1 charging, 2 not charging
|
||||||
|
optional uint32 wearingState = 2; // 1 wearing, 2 not wearing
|
||||||
|
optional uint32 sleepState = 3; // 1 sleep detected, 2 no sleep detected
|
||||||
|
optional uint32 warningState = 4; // ?
|
||||||
|
optional DeviceActivityState activityState = 5;
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
Loading…
x
Reference in New Issue
Block a user