From 1573a8c4cde1cd9528b422b2dcc598e37ffe94a7 Mon Sep 17 00:00:00 2001 From: jacqueline Date: Thu, 2 May 2024 19:12:26 +1000 Subject: WIP merge cyclically dependent components into one big component --- src/tangara/input/input_nav_buttons.cpp | 35 +++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 src/tangara/input/input_nav_buttons.cpp (limited to 'src/tangara/input/input_nav_buttons.cpp') diff --git a/src/tangara/input/input_nav_buttons.cpp b/src/tangara/input/input_nav_buttons.cpp new file mode 100644 index 00000000..61d80075 --- /dev/null +++ b/src/tangara/input/input_nav_buttons.cpp @@ -0,0 +1,35 @@ +/* + * Copyright 2024 jacqueline + * + * SPDX-License-Identifier: GPL-3.0-only + */ + +#include "input_nav_buttons.hpp" + +#include "event_queue.hpp" +#include "gpios.hpp" +#include "hal/lv_hal_indev.h" +#include "input_hook_actions.hpp" + +namespace input { + +NavButtons::NavButtons(drivers::IGpios& gpios) + : gpios_(gpios), + up_("upper", {}, actions::scrollUp(), actions::select(), {}), + down_("lower", {}, actions::scrollDown(), actions::select(), {}) {} + +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); +} + +auto NavButtons::name() -> std::string { + return "buttons"; +} + +auto NavButtons::triggers() + -> std::vector> { + return {up_, down_}; +} + +} // namespace input -- cgit v1.2.3