mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge.git
synced 2025-01-25 16:15:55 +01:00
Xiaomi: Implement sending current weather
TODO: Support °F, find out about unknown values Tested on Mi Watch Lite
This commit is contained in:
parent
cab63b2c98
commit
929ea7ae57
@ -19,14 +19,14 @@ package nodomain.freeyourgadget.gadgetbridge.service.devices.xiaomi.services;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
||||
import nodomain.freeyourgadget.gadgetbridge.R;
|
||||
import java.text.SimpleDateFormat;
|
||||
import java.util.Date;
|
||||
import java.util.Locale;
|
||||
|
||||
import nodomain.freeyourgadget.gadgetbridge.activities.SettingsActivity;
|
||||
import nodomain.freeyourgadget.gadgetbridge.devices.huami.HuamiCoordinator;
|
||||
import nodomain.freeyourgadget.gadgetbridge.devices.miband.MiBandConst;
|
||||
import nodomain.freeyourgadget.gadgetbridge.devices.huami.HuamiWeatherConditions;
|
||||
import nodomain.freeyourgadget.gadgetbridge.model.WeatherSpec;
|
||||
import nodomain.freeyourgadget.gadgetbridge.proto.xiaomi.XiaomiProto;
|
||||
import nodomain.freeyourgadget.gadgetbridge.service.btle.TransactionBuilder;
|
||||
import nodomain.freeyourgadget.gadgetbridge.service.devices.xiaomi.XiaomiSupport;
|
||||
import nodomain.freeyourgadget.gadgetbridge.util.Prefs;
|
||||
|
||||
@ -37,6 +37,7 @@ public class XiaomiWeatherService extends AbstractXiaomiService {
|
||||
|
||||
private static final int CMD_TEMPERATURE_UNIT_GET = 9;
|
||||
private static final int CMD_TEMPERATURE_UNIT_SET = 10;
|
||||
private static final int CMD_SET_CURRENT_WEATHER = 0;
|
||||
|
||||
public XiaomiWeatherService(final XiaomiSupport support) {
|
||||
super(support);
|
||||
@ -64,7 +65,57 @@ public class XiaomiWeatherService extends AbstractXiaomiService {
|
||||
}
|
||||
|
||||
public void onSendWeather(final WeatherSpec weatherSpec) {
|
||||
// TODO
|
||||
String timestamp = new StringBuilder(
|
||||
new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ssZ", Locale.US)
|
||||
.format(new Date(weatherSpec.timestamp * 1000L)))
|
||||
.insert(22, ':') // FIXME: I bet this fails for some, but all this java date craps sucks
|
||||
.toString();
|
||||
|
||||
|
||||
getSupport().sendCommand(
|
||||
"set current weather",
|
||||
XiaomiProto.Command.newBuilder()
|
||||
.setType(COMMAND_TYPE)
|
||||
.setSubtype(CMD_SET_CURRENT_WEATHER)
|
||||
.setWeather(XiaomiProto.Weather.newBuilder().setCurrent(
|
||||
XiaomiProto.WeatherCurrent.newBuilder()
|
||||
.setTimeLocation(XiaomiProto.WeatherCurrentTimeLocation.newBuilder()
|
||||
.setTimestamp(timestamp)
|
||||
.setUnk2("")
|
||||
.setCurrentLocationString(weatherSpec.location)
|
||||
)
|
||||
.setWeatherCondition(HuamiWeatherConditions.mapToAmazfitBipWeatherCode(weatherSpec.currentConditionCode)) // *SEEMS* to work
|
||||
.setTemperature(XiaomiProto.WeatherCurrentTemperature.newBuilder()
|
||||
.setDegrees(weatherSpec.currentTemp - 273) // TODO: support inches for weather
|
||||
.setSymbol("℃")
|
||||
)
|
||||
.setHumidity(XiaomiProto.WeatherCurrentHumidity.newBuilder()
|
||||
.setHumidity(weatherSpec.currentHumidity)
|
||||
.setSymbol("%")
|
||||
)
|
||||
.setUnk5(XiaomiProto.WeatherCurrentUnk5.newBuilder()
|
||||
.setUnk1("")
|
||||
.setUnk2(0)
|
||||
)
|
||||
.setUnk6(XiaomiProto.WeatherCurrentUnk6.newBuilder()
|
||||
.setUnk1("")
|
||||
.setUnk2(0)
|
||||
)
|
||||
.setUnk7(XiaomiProto.WeatherCurrentUnk7.newBuilder()
|
||||
.setUnk1("")
|
||||
.setUnk2(0)
|
||||
)
|
||||
.setWarning(XiaomiProto.WeatherCurrentWarning.newBuilder()
|
||||
.setCurrentWarning1(XiaomiProto.WeatherCurrentWarning1.newBuilder()
|
||||
.setCurrentWarningText("")
|
||||
.setCurrentWarningSeverityText("")
|
||||
)
|
||||
)
|
||||
.setPressure(weatherSpec.pressure)
|
||||
|
||||
))
|
||||
.build()
|
||||
);
|
||||
}
|
||||
|
||||
private void setMeasurementSystem() {
|
||||
|
@ -635,7 +635,56 @@ message Weather {
|
||||
}
|
||||
|
||||
message WeatherCurrent {
|
||||
optional WeatherCurrentTimeLocation timeLocation = 1;
|
||||
optional uint32 weatherCondition = 2;
|
||||
optional WeatherCurrentTemperature temperature = 3;
|
||||
optional WeatherCurrentHumidity humidity= 4;
|
||||
optional WeatherCurrentUnk5 unk5 = 5;
|
||||
optional WeatherCurrentUnk6 unk6 = 6;
|
||||
optional WeatherCurrentUnk7 unk7 = 7;
|
||||
optional WeatherCurrentWarning warning = 8; // Seems to be an array?
|
||||
optional float pressure = 9;
|
||||
}
|
||||
message WeatherCurrentTimeLocation {
|
||||
optional string timestamp = 1;
|
||||
optional string unk2 = 2;
|
||||
optional string currentLocationString = 3;
|
||||
}
|
||||
|
||||
message WeatherCurrentTemperature {
|
||||
optional string symbol = 1;
|
||||
optional sint32 degrees = 2;
|
||||
}
|
||||
|
||||
message WeatherCurrentHumidity {
|
||||
optional string symbol = 1;
|
||||
optional sint32 humidity = 2;
|
||||
}
|
||||
|
||||
message WeatherCurrentUnk5 {
|
||||
optional string unk1 = 1;
|
||||
optional uint32 unk2 = 2;
|
||||
}
|
||||
|
||||
message WeatherCurrentUnk6 {
|
||||
optional string unk1 = 1;
|
||||
optional uint32 unk2 = 2;
|
||||
}
|
||||
|
||||
message WeatherCurrentUnk7 {
|
||||
optional string unk1 = 1;
|
||||
optional uint32 unk2 = 2;
|
||||
}
|
||||
|
||||
message WeatherCurrentWarning {
|
||||
optional WeatherCurrentWarning1 currentWarning1 = 1; // FIXME: this is probably an array
|
||||
}
|
||||
|
||||
message WeatherCurrentWarning1 {
|
||||
optional string currentWarningText = 1;
|
||||
optional string currentWarningSeverityText = 2;
|
||||
}
|
||||
|
||||
|
||||
message WeatherDaily {
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user