Mi Band 3/Amazfit Bip/Amazfit Cor: Send Fahrenheit if units are set to imperial

Closes #1315
This commit is contained in:
Andreas Shimokawa 2018-11-03 20:44:30 +01:00
parent 7108cd53b1
commit 61872b7bbd
2 changed files with 32 additions and 5 deletions

View File

@ -4,6 +4,7 @@
* Pebble: Send all wearable notification actions (not only reply) * Pebble: Send all wearable notification actions (not only reply)
* Pebble: Always allow reply action even if untested features are turned off * Pebble: Always allow reply action even if untested features are turned off
* Amazfit Bip: Allow flashing latest gps firmware (Mili_dth.gps) * Amazfit Bip: Allow flashing latest gps firmware (Mili_dth.gps)
* Mi Band 3/Amazfit Bip/Amazfit Cor: Send Fahrenheit if units are set to imperial
* Roidmi 3: Fix and enable support * Roidmi 3: Fix and enable support
* Mi Band 3/Amazfit Bip: fix find phone crash * Mi Band 3/Amazfit Bip: fix find phone crash
* Prevent re-sending old notifications to the wearable * Prevent re-sending old notifications to the wearable

View File

@ -34,12 +34,15 @@ import java.util.Set;
import java.util.SimpleTimeZone; import java.util.SimpleTimeZone;
import java.util.UUID; import java.util.UUID;
import cyanogenmod.weather.util.WeatherUtils;
import nodomain.freeyourgadget.gadgetbridge.GBApplication; import nodomain.freeyourgadget.gadgetbridge.GBApplication;
import nodomain.freeyourgadget.gadgetbridge.devices.huami.HuamiCoordinator;
import nodomain.freeyourgadget.gadgetbridge.devices.huami.HuamiFWHelper; import nodomain.freeyourgadget.gadgetbridge.devices.huami.HuamiFWHelper;
import nodomain.freeyourgadget.gadgetbridge.devices.huami.HuamiService; import nodomain.freeyourgadget.gadgetbridge.devices.huami.HuamiService;
import nodomain.freeyourgadget.gadgetbridge.devices.huami.HuamiWeatherConditions; import nodomain.freeyourgadget.gadgetbridge.devices.huami.HuamiWeatherConditions;
import nodomain.freeyourgadget.gadgetbridge.devices.huami.amazfitbip.AmazfitBipFWHelper; import nodomain.freeyourgadget.gadgetbridge.devices.huami.amazfitbip.AmazfitBipFWHelper;
import nodomain.freeyourgadget.gadgetbridge.devices.huami.amazfitbip.AmazfitBipService; import nodomain.freeyourgadget.gadgetbridge.devices.huami.amazfitbip.AmazfitBipService;
import nodomain.freeyourgadget.gadgetbridge.devices.miband.MiBandConst;
import nodomain.freeyourgadget.gadgetbridge.model.CallSpec; import nodomain.freeyourgadget.gadgetbridge.model.CallSpec;
import nodomain.freeyourgadget.gadgetbridge.model.DeviceType; import nodomain.freeyourgadget.gadgetbridge.model.DeviceType;
import nodomain.freeyourgadget.gadgetbridge.model.NotificationSpec; import nodomain.freeyourgadget.gadgetbridge.model.NotificationSpec;
@ -258,6 +261,8 @@ public class AmazfitBipSupport extends HuamiSupport {
if (version.compareTo(new Version("0.0.8.74")) >= 0) { if (version.compareTo(new Version("0.0.8.74")) >= 0) {
supportsConditionString = true; supportsConditionString = true;
} }
MiBandConst.DistanceUnit unit = HuamiCoordinator.getDistanceUnit();
int tz_offset_hours = SimpleTimeZone.getDefault().getOffset(weatherSpec.timestamp * 1000L) / (1000 * 60 * 60); int tz_offset_hours = SimpleTimeZone.getDefault().getOffset(weatherSpec.timestamp * 1000L) / (1000 * 60 * 60);
try { try {
TransactionBuilder builder; TransactionBuilder builder;
@ -276,7 +281,12 @@ public class AmazfitBipSupport extends HuamiSupport {
buf.putInt(weatherSpec.timestamp); buf.putInt(weatherSpec.timestamp);
buf.put((byte) (tz_offset_hours * 4)); buf.put((byte) (tz_offset_hours * 4));
buf.put(condition); buf.put(condition);
buf.put((byte) (weatherSpec.currentTemp - 273));
int currentTemp = weatherSpec.currentTemp - 273;
if (unit == MiBandConst.DistanceUnit.IMPERIAL) {
currentTemp = (int) WeatherUtils.celsiusToFahrenheit(currentTemp);
}
buf.put((byte) currentTemp);
if (supportsConditionString) { if (supportsConditionString) {
buf.put(weatherSpec.currentCondition.getBytes()); buf.put(weatherSpec.currentCondition.getBytes());
@ -354,8 +364,16 @@ public class AmazfitBipSupport extends HuamiSupport {
byte condition = HuamiWeatherConditions.mapToAmazfitBipWeatherCode(weatherSpec.currentConditionCode); byte condition = HuamiWeatherConditions.mapToAmazfitBipWeatherCode(weatherSpec.currentConditionCode);
buf.put(condition); buf.put(condition);
buf.put(condition); buf.put(condition);
buf.put((byte) (weatherSpec.todayMaxTemp - 273));
buf.put((byte) (weatherSpec.todayMinTemp - 273)); int todayMaxTemp = weatherSpec.todayMaxTemp - 273;
int todayMinTemp = weatherSpec.todayMinTemp - 273;
if (unit == MiBandConst.DistanceUnit.IMPERIAL) {
todayMaxTemp = (int) WeatherUtils.celsiusToFahrenheit(todayMaxTemp);
todayMinTemp = (int) WeatherUtils.celsiusToFahrenheit(todayMinTemp);
}
buf.put((byte) todayMaxTemp);
buf.put((byte) todayMinTemp);
if (supportsConditionString) { if (supportsConditionString) {
buf.put(weatherSpec.currentCondition.getBytes()); buf.put(weatherSpec.currentCondition.getBytes());
buf.put((byte) 0); buf.put((byte) 0);
@ -365,8 +383,16 @@ public class AmazfitBipSupport extends HuamiSupport {
condition = HuamiWeatherConditions.mapToAmazfitBipWeatherCode(forecast.conditionCode); condition = HuamiWeatherConditions.mapToAmazfitBipWeatherCode(forecast.conditionCode);
buf.put(condition); buf.put(condition);
buf.put(condition); buf.put(condition);
buf.put((byte) (forecast.maxTemp - 273));
buf.put((byte) (forecast.minTemp - 273)); int forecastMaxTemp = forecast.maxTemp - 273;
int forecastMinTemp = forecast.minTemp - 273;
if (unit == MiBandConst.DistanceUnit.IMPERIAL) {
forecastMaxTemp = (int) WeatherUtils.celsiusToFahrenheit(forecastMaxTemp);
forecastMinTemp = (int) WeatherUtils.celsiusToFahrenheit(forecastMinTemp);
}
buf.put((byte) forecastMaxTemp);
buf.put((byte) forecastMinTemp);
if (supportsConditionString) { if (supportsConditionString) {
buf.put(Weather.getConditionString(forecast.conditionCode).getBytes()); buf.put(Weather.getConditionString(forecast.conditionCode).getBytes());
buf.put((byte) 0); buf.put((byte) 0);