diff options
| author | cooljqln <cooljqln@noreply.codeberg.org> | 2025-01-17 02:23:42 +0000 |
|---|---|---|
| committer | cooljqln <cooljqln@noreply.codeberg.org> | 2025-01-17 02:23:42 +0000 |
| commit | 0180c9311db13281808976c2cc5e53994da4432f (patch) | |
| tree | 928f9eb4e8df35bbefa0f2dee05394a6a4fdec58 /src/tangara/input/input_nav_buttons.cpp | |
| parent | 3dd0887c1f88570f041e9b18f5c1416a74fd028d (diff) | |
| parent | 6886c686d5b10ad8061e900aa0e7b326b0d5d04d (diff) | |
| download | tangara-fw-0180c9311db13281808976c2cc5e53994da4432f.tar.gz | |
Merge pull request 'Add an input sequence for hard rebooting' (#185) from jqln/hard-reset into main
Reviewed-on: https://codeberg.org/cool-tech-zone/tangara-fw/pulls/185
Diffstat (limited to 'src/tangara/input/input_nav_buttons.cpp')
| -rw-r--r-- | src/tangara/input/input_nav_buttons.cpp | 23 |
1 files changed, 20 insertions, 3 deletions
diff --git a/src/tangara/input/input_nav_buttons.cpp b/src/tangara/input/input_nav_buttons.cpp index 0c904a84..54bef7a6 100644 --- a/src/tangara/input/input_nav_buttons.cpp +++ b/src/tangara/input/input_nav_buttons.cpp @@ -17,11 +17,20 @@ namespace input { NavButtons::NavButtons(drivers::IGpios& gpios) : gpios_(gpios), up_("upper", {}, actions::scrollUp(), actions::select(), {}), - down_("lower", {}, actions::scrollDown(), actions::select(), {}) {} + down_("lower", {}, actions::scrollDown(), actions::select(), {}), + locked_(false) {} auto NavButtons::read(lv_indev_data_t* data) -> void { - up_.update(!gpios_.Get(drivers::IGpios::Pin::kKeyUp), data); - down_.update(!gpios_.Get(drivers::IGpios::Pin::kKeyDown), data); + bool up = !gpios_.Get(drivers::IGpios::Pin::kKeyUp); + bool down = !gpios_.Get(drivers::IGpios::Pin::kKeyDown); + + if ((up && down) || locked_) { + up = false; + down = false; + } + + up_.update(up, data); + down_.update(down, data); } auto NavButtons::name() -> std::string { @@ -33,4 +42,12 @@ auto NavButtons::triggers() return {up_, down_}; } +auto NavButtons::onLock() -> void { + locked_ = true; +} + +auto NavButtons::onUnlock() -> void { + locked_ = false; +} + } // namespace input |
