From fc98d3809e0db36d634f290417b9152f87f83e3e Mon Sep 17 00:00:00 2001 From: Uros Majstorovic Date: Sun, 4 Sep 2022 18:37:42 +0200 Subject: new phone firmware --- fw/fe310/phone/app/status.c | 68 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 68 insertions(+) create mode 100644 fw/fe310/phone/app/status.c (limited to 'fw/fe310/phone/app/status.c') diff --git a/fw/fe310/phone/app/status.c b/fw/fe310/phone/app/status.c new file mode 100644 index 0000000..fec391b --- /dev/null +++ b/fw/fe310/phone/app/status.c @@ -0,0 +1,68 @@ +#include +#include +#include +#include + +#include +#include +#include + +#include +#include +#include + +#include +#include +#include + +#include "app.h" +#include "status.h" + +void app_status_init(EVEView *view, EVEWindow *win) { + eve_view_init(view, win, app_status_draw, app_status_touch, NULL, NULL); + eve_view_set_color_bg(view, 0x20, 0x20, 0x20); +} + +int app_status_touch(EVEView *view, EVETouch *touch, uint16_t evt, uint8_t tag0) { + unsigned char state = 0; + int8_t touch_idx; + + /* only first touch */ + touch_idx = eve_touch_get_idx(touch); + if (touch_idx != 0) return 0; + + evt = eve_touch_evt(touch, evt, tag0, view->tag, 2); + if (evt & EVE_TOUCH_ETYPE_POINT_UP) { + view->param = NULL; + return 1; + } + return 0; +} + +uint8_t app_status_draw(EVEView *view, uint8_t tag0) { + uint8_t tag_opt = EVE_TOUCH_OPT_TRACK | EVE_TOUCH_OPT_TRACK_XY; + char *status_msg = view->param; + + tag0 = eve_view_clear(view, tag0, tag_opt); + + if (tag0 != EVE_NOTAG) { + eve_touch_set_opt(tag0, eve_touch_get_opt(tag0) | tag_opt); + eve_cmd_dl(TAG(tag0)); + tag0++; + } + + if (status_msg) eve_cmd(CMD_TEXT, "hhhhs", 0, 0, 31, 0, status_msg); + + return tag0; +} + +void app_status_set_msg(char *msg) { + EVEView *status; + + status = app_search_view("status"); + if (status == NULL) return; + + status->param = msg; + + if (!eve_selected()) app_refresh(); +} -- cgit v1.2.3