diff options
| author | jacqueline <me@jacqueline.id.au> | 2023-05-19 21:21:27 +1000 |
|---|---|---|
| committer | jacqueline <me@jacqueline.id.au> | 2023-05-19 21:21:27 +1000 |
| commit | a6ab1504058304012791281f9eb42c262745888f (patch) | |
| tree | f82379cd1e66a8ae2f1afbae5cf083a8ab7acc53 /src/ui/lvgl_task.cpp | |
| parent | b320a6a863cf1c10dc79254af41f573730935564 (diff) | |
| download | tangara-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.cpp | 31 |
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, |
