summaryrefslogtreecommitdiff
path: root/src/ui/lvgl_task.cpp
diff options
context:
space:
mode:
authorjacqueline <me@jacqueline.id.au>2023-05-19 21:21:27 +1000
committerjacqueline <me@jacqueline.id.au>2023-05-19 21:21:27 +1000
commita6ab1504058304012791281f9eb42c262745888f (patch)
treef82379cd1e66a8ae2f1afbae5cf083a8ab7acc53 /src/ui/lvgl_task.cpp
parentb320a6a863cf1c10dc79254af41f573730935564 (diff)
downloadtangara-fw-a6ab1504058304012791281f9eb42c262745888f.tar.gz
Add tinyfsm, start converting core functions to an FSM-based event loop
Diffstat (limited to 'src/ui/lvgl_task.cpp')
-rw-r--r--src/ui/lvgl_task.cpp31
1 files changed, 14 insertions, 17 deletions
diff --git a/src/ui/lvgl_task.cpp b/src/ui/lvgl_task.cpp
index 12dfd34e..70df9f72 100644
--- a/src/ui/lvgl_task.cpp
+++ b/src/ui/lvgl_task.cpp
@@ -23,10 +23,10 @@
#include "misc/lv_color.h"
#include "misc/lv_style.h"
#include "misc/lv_timer.h"
+#include "touchwheel.hpp"
#include "widgets/lv_label.h"
#include "display.hpp"
-#include "driver_cache.hpp"
#include "gpio_expander.hpp"
namespace ui {
@@ -38,27 +38,23 @@ auto tick_hook(TimerHandle_t xTimer) -> void {
}
struct LvglArgs {
- drivers::DriverCache* drivers;
+ std::weak_ptr<drivers::TouchWheel> touch_wheel;
+ std::weak_ptr<drivers::Display> display;
std::atomic<bool>* quit;
};
void LvglMain(void* voidArgs) {
LvglArgs* args = reinterpret_cast<LvglArgs*>(voidArgs);
- drivers::DriverCache* drivers = args->drivers;
+ std::weak_ptr<drivers::TouchWheel> weak_touch_wheel = args->touch_wheel;
+ std::weak_ptr<drivers::Display> weak_display = args->display;
+
std::atomic<bool>* quit = args->quit;
delete args;
{
- ESP_LOGI(kTag, "init lvgl");
- lv_init();
-
- // LVGL has been initialised, so we can now start reporting ticks to it.
TimerHandle_t tick_timer =
xTimerCreate("lv_tick", pdMS_TO_TICKS(1), pdTRUE, NULL, &tick_hook);
- ESP_LOGI(kTag, "init display");
- std::shared_ptr<drivers::Display> display = drivers->AcquireDisplay();
-
lv_style_t style;
lv_style_init(&style);
lv_style_set_text_color(&style, LV_COLOR_MAKE(0xFF, 0, 0));
@@ -74,7 +70,9 @@ void LvglMain(void* voidArgs) {
while (!quit->load()) {
lv_timer_handler();
- vTaskDelay(pdMS_TO_TICKS(10));
+ // 30 FPS
+ // TODO(jacqueline): make this dynamic
+ vTaskDelay(pdMS_TO_TICKS(33));
}
// TODO(robin? daniel?): De-init the UI stack here.
@@ -82,8 +80,6 @@ void LvglMain(void* voidArgs) {
lv_style_reset(&style);
xTimerDelete(tick_timer, portMAX_DELAY);
-
- lv_deinit();
}
vTaskDelete(NULL);
@@ -93,11 +89,12 @@ static const size_t kLvglStackSize = 8 * 1024;
static StaticTask_t sLvglTaskBuffer = {};
static StackType_t sLvglStack[kLvglStackSize] = {0};
-auto StartLvgl(drivers::DriverCache* drivers,
- std::atomic<bool>* quit,
- TaskHandle_t* handle) -> bool {
+auto StartLvgl(std::weak_ptr<drivers::TouchWheel> touch_wheel,
+ std::weak_ptr<drivers::Display> display,
+ std::atomic<bool>* quit) -> bool {
LvglArgs* args = new LvglArgs();
- args->drivers = drivers;
+ args->touch_wheel = touch_wheel;
+ args->display = display;
args->quit = quit;
return xTaskCreateStaticPinnedToCore(&LvglMain, "LVGL", kLvglStackSize,