Fossil Hybrid HR: Play around with the weather app

This commit is contained in:
Andreas Shimokawa 2020-02-18 00:31:43 +01:00
parent a90e8de040
commit fe7c4d5290
2 changed files with 63 additions and 9 deletions

View File

@ -18,6 +18,7 @@ import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.nio.BufferOverflowException; import java.nio.BufferOverflowException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date; import java.util.Date;
import java.util.GregorianCalendar; import java.util.GregorianCalendar;
import java.util.HashMap; import java.util.HashMap;
@ -517,13 +518,65 @@ public class FossilHRWatchAdapter extends FossilWatchAdapter {
.put("alive", ts + 60 * 60) .put("alive", ts + 60 * 60)
.put("unit", "c") // FIXME: do not hardcode .put("unit", "c") // FIXME: do not hardcode
.put("temp", weatherSpec.currentTemp - 273) .put("temp", weatherSpec.currentTemp - 273)
.put("cond_id", getIconForConditionCode(weatherSpec.currentConditionCode, false)) // FIXME do not hardcode 2=cloudy .put("cond_id", getIconForConditionCode(weatherSpec.currentConditionCode, false)) // FIXME do not assume daylight
) )
) )
); );
queueWrite(new JsonPutRequest(responseObject, this)); queueWrite(new JsonPutRequest(responseObject, this));
JSONArray forecastWeekArray = new JSONArray();
final String[] weekdays = {"", "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"};
Calendar cal = Calendar.getInstance();
cal.setTimeInMillis(weatherSpec.timestamp * 1000L);
int i = 0;
for (WeatherSpec.Forecast forecast : weatherSpec.forecasts) {
cal.add(Calendar.DATE, 1);
int dayOfWeek = cal.get(Calendar.DAY_OF_WEEK);
forecastWeekArray.put(new JSONObject()
.put("day", weekdays[dayOfWeek])
.put("cond_id", getIconForConditionCode(forecast.conditionCode, false)) // FIXME do not assume daylight
.put("high", forecast.maxTemp - 273)
.put("low", forecast.minTemp - 273)
);
if (++i == 3) break; // max 3
}
JSONArray forecastDayArray = new JSONArray();
final int[] hours = {0, 0, 0};
for (int hour : hours) {
forecastDayArray.put(new JSONObject()
.put("hour", hour)
.put("cond_id", 0)
.put("temp", 0)
);
}
JSONObject forecastResponseObject = new JSONObject()
.put("res", new JSONObject()
.put("id", 0)
.put("set", new JSONObject()
.put("weatherApp._.config.locations", new JSONArray()
.put(new JSONObject()
.put("alive", ts + 60 * 60)
.put("city", weatherSpec.location)
.put("unit", "c") // FIXME: do not hardcode
.put("temp", weatherSpec.currentTemp - 273)
.put("high", weatherSpec.todayMaxTemp - 273)
.put("low", weatherSpec.todayMinTemp - 273)
.put("rain", 0)
.put("cond_id", getIconForConditionCode(weatherSpec.currentConditionCode, false)) // FIXME do not assume daylight
.put("forecast_day", forecastDayArray)
.put("forecast_week", forecastWeekArray)
)
)
)
);
queueWrite(new JsonPutRequest(forecastResponseObject, this));
} catch (JSONException e) { } catch (JSONException e) {
logger.error("JSON exception: ", e); logger.error("JSON exception: ", e);
} }
@ -640,10 +693,11 @@ public class FossilHRWatchAdapter extends FossilWatchAdapter {
logger.info(jsonString); logger.info(jsonString);
JSONObject requestJson = new JSONObject(jsonString); JSONObject requestJson = new JSONObject(jsonString);
int requestId = requestJson.getJSONObject("req").getInt("id"); JSONObject request = requestJson.getJSONObject("req");
int requestId = request.getInt("id");
if (requestJson.getJSONObject("req").has("ringMyPhone")) { if (request.has("ringMyPhone")) {
String action = requestJson.getJSONObject("req").getJSONObject("ringMyPhone").getString("action"); String action = request.getJSONObject("ringMyPhone").getString("action");
logger.info("got ringMyPhone request; " + action); logger.info("got ringMyPhone request; " + action);
GBDeviceEventFindPhone findPhoneEvent = new GBDeviceEventFindPhone(); GBDeviceEventFindPhone findPhoneEvent = new GBDeviceEventFindPhone();
@ -675,7 +729,7 @@ public class FossilHRWatchAdapter extends FossilWatchAdapter {
.put("result", "off"); .put("result", "off");
queueWrite(new JsonPutRequest(responseObject, this)); queueWrite(new JsonPutRequest(responseObject, this));
} }
} else if (requestJson.getJSONObject("req").has("weatherInfo")) { } else if (request.has("weatherInfo") || request.has("weatherApp._.config.locations")) {
logger.info("Got weatherInfo request"); logger.info("Got weatherInfo request");
WeatherSpec weatherSpec = Weather.getInstance().getWeatherSpec(); WeatherSpec weatherSpec = Weather.getInstance().getWeatherSpec();
if (weatherSpec != null) { if (weatherSpec != null) {
@ -683,11 +737,11 @@ public class FossilHRWatchAdapter extends FossilWatchAdapter {
} else { } else {
logger.info("no weather data available - ignoring request"); logger.info("no weather data available - ignoring request");
} }
} else if (requestJson.getJSONObject("req").has("commuteApp._.config.commute_info")) { } else if (request.has("commuteApp._.config.commute_info")) {
String action = requestJson.getJSONObject("req").getJSONObject("commuteApp._.config.commute_info") String action = request.getJSONObject("commuteApp._.config.commute_info")
.getString("dest"); .getString("dest");
String startStop = requestJson.getJSONObject("req").getJSONObject("commuteApp._.config.commute_info") String startStop = request.getJSONObject("commuteApp._.config.commute_info")
.getString("action"); .getString("action");
if (startStop.equals("stop")) { if (startStop.equals("stop")) {

View File

@ -24,7 +24,7 @@ public class ButtonConfigurationPutRequest extends JsonPutRequest {
.put("commuteApp._.config.destinations", new JSONArray(menuItems)) .put("commuteApp._.config.destinations", new JSONArray(menuItems))
.put("master._.config.buttons", new JSONArray() .put("master._.config.buttons", new JSONArray()
.put(new JSONObject() .put(new JSONObject()
.put("name", "commuteApp") .put("name", "weatherApp")
.put("button_evt", "top_short_press_release") .put("button_evt", "top_short_press_release")
) )
.put(new JSONObject() .put(new JSONObject()