diff options
| author | cooljqln <cooljqln@noreply.codeberg.org> | 2024-02-13 00:47:53 +0000 |
|---|---|---|
| committer | cooljqln <cooljqln@noreply.codeberg.org> | 2024-02-13 00:47:53 +0000 |
| commit | e466522c25758670da335195d60a5d599ed56177 (patch) | |
| tree | 8a7d29a07c3045b3e6a666468bcad63a7c0ba697 /src/ui/ui_fsm.cpp | |
| parent | cb379f4bc3c51eacf80b786566ab3c2675191164 (diff) | |
| parent | ffa0894e380874774fb13986b3ff1a48696d304e (diff) | |
| download | tangara-fw-e466522c25758670da335195d60a5d599ed56177.tar.gz | |
Merge pull request 'scroll-sensitivity' (#36) from scroll-sensitivity into main
Reviewed-on: https://codeberg.org/cool-tech-zone/tangara-fw/pulls/36
Reviewed-by: cooljqln <cooljqln@noreply.codeberg.org>
Diffstat (limited to 'src/ui/ui_fsm.cpp')
| -rw-r--r-- | src/ui/ui_fsm.cpp | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/src/ui/ui_fsm.cpp b/src/ui/ui_fsm.cpp index 728c9756..24145ead 100644 --- a/src/ui/ui_fsm.cpp +++ b/src/ui/ui_fsm.cpp @@ -242,6 +242,25 @@ lua::Property UiState::sControlsScheme{ return true; }}; +lua::Property UiState::sScrollSensitivity{ + 0, [](const lua::LuaValue& val) { + std::optional<int> sensitivity = 0; + std::visit( + [&](auto&& v) { + using T = std::decay_t<decltype(v)>; + if constexpr (std::is_same_v<T, int>) { + sensitivity = v; + } + }, + val); + if (!sensitivity) { + return false; + } + sInput->scroll_sensitivity(*sensitivity); + sServices->nvs().ScrollSensitivity(*sensitivity); + return true; + }}; + lua::Property UiState::sDatabaseUpdating{false}; auto UiState::InitBootSplash(drivers::IGpios& gpios) -> bool { @@ -403,6 +422,10 @@ void Splash::react(const system_fsm::BootComplete& ev) { sInput->mode(mode); sControlsScheme.Update(static_cast<int>(mode)); + auto sensitivity = sServices->nvs().ScrollSensitivity(); + sInput->scroll_sensitivity(sensitivity); + sScrollSensitivity.Update(static_cast<int>(sensitivity)); + sTask->input(sInput); } else { ESP_LOGE(kTag, "no input devices initialised!"); @@ -466,6 +489,7 @@ void Lua::entry() { sLua->bridge().AddPropertyModule("controls", { {"scheme", &sControlsScheme}, + {"scroll_sensitivity", &sScrollSensitivity}, }); sLua->bridge().AddPropertyModule( |
