mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge.git
synced 2025-01-25 16:15:55 +01:00
Mi Band 3/Amazfit Bip/Amazfit Cor: Send Fahrenheit if units are set to imperial
Closes #1315
This commit is contained in:
parent
7108cd53b1
commit
61872b7bbd
@ -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
|
||||||
|
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user