1
0
mirror of https://codeberg.org/Freeyourgadget/Gadgetbridge synced 2025-01-14 11:47:32 +01:00

Zepp OS: Improve weather code mapping

This commit is contained in:
José Rebelo 2023-08-23 15:48:26 +01:00
parent fe58d64192
commit da779e9864

View File

@ -198,7 +198,7 @@ public class Huami2021Weather {
// First one is for the current day // First one is for the current day
temperature.add(new Range(weatherSpec.todayMinTemp - 273, weatherSpec.todayMaxTemp - 273)); temperature.add(new Range(weatherSpec.todayMinTemp - 273, weatherSpec.todayMaxTemp - 273));
final String currentWeatherCode = String.valueOf(HuamiWeatherConditions.mapToAmazfitBipWeatherCode(weatherSpec.currentConditionCode) & 0xff); final String currentWeatherCode = String.valueOf(mapToZeppOsWeatherCode(weatherSpec.currentConditionCode));
weather.add(new Range(currentWeatherCode, currentWeatherCode)); weather.add(new Range(currentWeatherCode, currentWeatherCode));
sunRiseSet.add(getSunriseSunset(sunriseDate, lastKnownLocation)); sunRiseSet.add(getSunriseSunset(sunriseDate, lastKnownLocation));
sunriseDate.add(Calendar.DAY_OF_MONTH, 1); sunriseDate.add(Calendar.DAY_OF_MONTH, 1);
@ -208,7 +208,7 @@ public class Huami2021Weather {
for (int i = 0; i < actualDays; i++) { for (int i = 0; i < actualDays; i++) {
final WeatherSpec.Forecast forecast = weatherSpec.forecasts.get(i); final WeatherSpec.Forecast forecast = weatherSpec.forecasts.get(i);
temperature.add(new Range(forecast.minTemp - 273, forecast.maxTemp - 273)); temperature.add(new Range(forecast.minTemp - 273, forecast.maxTemp - 273));
final String weatherCode = String.valueOf(HuamiWeatherConditions.mapToAmazfitBipWeatherCode(forecast.conditionCode) & 0xff); final String weatherCode = String.valueOf(mapToZeppOsWeatherCode(forecast.conditionCode));
weather.add(new Range(weatherCode, weatherCode)); weather.add(new Range(weatherCode, weatherCode));
sunRiseSet.add(getSunriseSunset(sunriseDate, lastKnownLocation)); sunRiseSet.add(getSunriseSunset(sunriseDate, lastKnownLocation));
@ -385,7 +385,7 @@ public class Huami2021Weather {
temperature = new UnitValue(Unit.TEMPERATURE_C, weatherSpec.currentTemp - 273); temperature = new UnitValue(Unit.TEMPERATURE_C, weatherSpec.currentTemp - 273);
uvIndex = String.valueOf(weatherSpec.uvIndex); uvIndex = String.valueOf(weatherSpec.uvIndex);
visibility = new UnitValue(Unit.KM, ""); visibility = new UnitValue(Unit.KM, "");
weather = String.valueOf(HuamiWeatherConditions.mapToAmazfitBipWeatherCode(weatherSpec.currentConditionCode) & 0xff); weather = String.valueOf(mapToZeppOsWeatherCode(weatherSpec.currentConditionCode));
wind = new Wind(weatherSpec.windDirection, Math.round(weatherSpec.windSpeed)); wind = new Wind(weatherSpec.windDirection, Math.round(weatherSpec.windSpeed));
} }
@ -667,4 +667,58 @@ public class Huami2021Weather {
return new JsonPrimitive(src.format(DateTimeFormatter.ISO_LOCAL_DATE)); return new JsonPrimitive(src.format(DateTimeFormatter.ISO_LOCAL_DATE));
} }
} }
public static final int SUNNY = 0;
public static final int SOME_CLOUDS = 1;
public static final int CLOUDY = 2;
public static final int RAIN_WITH_SUN = 3;
public static final int THUNDERSTORM = 4;
public static final int HAIL = 5;
public static final int SLEET = 6;
public static final int LIGHT_RAIN = 7;
public static final int MODERATE_RAIN = 8;
public static final int HEAVY_RAIN = 9;
public static final int RAINSTORM = 10;
public static final int HEAVY_RAINSTORM = 11;
public static final int EXTRAORDINARY_RAINSTORM = 12;
public static final int SNOW_SHOWER_WITH_SOME_SUN = 13;
public static final int LIGHT_SNOW = 14;
public static final int MODERATE_SNOW = 15;
public static final int HEAVY_SNOW = 16;
public static final int SNOWSTORM = 17;
public static final int FOG = 18;
public static final int FREEZING_RAIN = 19;
public static final int SANDSTORM = 20;
public static final int LIGHT_TO_MODERATE_RAIN = 21;
public static final int MODERATE_TO_HEAVY_RAIN = 22;
public static final int HEAVY_RAIN_TO_RAINSTORM = 23;
public static final int RAINSTORM_TO_HEAVY_RAIN = 24;
public static final int HEAVY_TO_SEVERE_STORM = 25;
public static final int LIGHT_TO_MODERATE_SNOW = 26;
public static final int MODERATE_TO_HEAVY_SNOW = 27;
public static final int HEAVY_SNOW_TO_SNOWSTORM = 28;
public static final int DUST = 29;
public static final int SAND_BLOWING = 30;
public static final int STRONG_SANDSTORM = 31;
public static final int DENSE_FOG = 32;
public static final int SNOW = 33;
public static int mapToZeppOsWeatherCode(final int openWeatherMapCondition) {
// openweathermap.org conditions:
// http://openweathermap.org/weather-conditions
switch (openWeatherMapCondition) {
case 511: //freezing rain: //13d
return FREEZING_RAIN;
case 731: //sand/dust whirls: //50d
case 751: //sand: //50d
return SAND_BLOWING;
case 761: //dust: //50d
case 762: //volcanic ash: //50d
return DUST;
case 741: //fog: //50d
return DENSE_FOG;
default:
return HuamiWeatherConditions.mapToAmazfitBipWeatherCode(openWeatherMapCondition) & 0xff;
}
}
} }