summaryrefslogtreecommitdiff
path: root/src/tangara/input/input_nav_buttons.cpp
diff options
context:
space:
mode:
authorcooljqln <cooljqln@noreply.codeberg.org>2025-01-17 02:23:42 +0000
committercooljqln <cooljqln@noreply.codeberg.org>2025-01-17 02:23:42 +0000
commit0180c9311db13281808976c2cc5e53994da4432f (patch)
tree928f9eb4e8df35bbefa0f2dee05394a6a4fdec58 /src/tangara/input/input_nav_buttons.cpp
parent3dd0887c1f88570f041e9b18f5c1416a74fd028d (diff)
parent6886c686d5b10ad8061e900aa0e7b326b0d5d04d (diff)
downloadtangara-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.cpp23
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