From ed82063af5f83530afa5cfb5bf5bd516f3d05f2a Mon Sep 17 00:00:00 2001 From: jacqueline Date: Wed, 10 Apr 2024 16:56:10 +1000 Subject: WIP decompose our giant LVGL driver into smaller classes --- src/input/input_volume_buttons.cpp | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 src/input/input_volume_buttons.cpp (limited to 'src/input/input_volume_buttons.cpp') diff --git a/src/input/input_volume_buttons.cpp b/src/input/input_volume_buttons.cpp new file mode 100644 index 00000000..bf79ed55 --- /dev/null +++ b/src/input/input_volume_buttons.cpp @@ -0,0 +1,26 @@ +/* + * Copyright 2024 jacqueline + * + * SPDX-License-Identifier: GPL-3.0-only + */ + +#include "input_volume_buttons.hpp" +#include "gpios.hpp" + +namespace input { + +VolumeButtons::VolumeButtons(drivers::IGpios& gpios) : gpios_(gpios) {} + +auto VolumeButtons::read(lv_indev_data_t* data) -> void { + bool vol_up = gpios_.Get(drivers::IGpios::Pin::kKeyUp); + if (!vol_up) { + ESP_LOGI("volume", "vol up"); + } + + bool vol_down = gpios_.Get(drivers::IGpios::Pin::kKeyDown); + if (!vol_down) { + ESP_LOGI("volume", "vol down"); + } +} + +} // namespace input -- cgit v1.2.3 From 33919e9e3f419e13318fa6b8217d8c8dcd86c1eb Mon Sep 17 00:00:00 2001 From: jacqueline Date: Thu, 11 Apr 2024 15:16:35 +1000 Subject: Migrate all existing control schemes to the cool new world --- src/input/input_volume_buttons.cpp | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) (limited to 'src/input/input_volume_buttons.cpp') diff --git a/src/input/input_volume_buttons.cpp b/src/input/input_volume_buttons.cpp index bf79ed55..0413222c 100644 --- a/src/input/input_volume_buttons.cpp +++ b/src/input/input_volume_buttons.cpp @@ -5,6 +5,7 @@ */ #include "input_volume_buttons.hpp" +#include "event_queue.hpp" #include "gpios.hpp" namespace input { @@ -13,13 +14,21 @@ VolumeButtons::VolumeButtons(drivers::IGpios& gpios) : gpios_(gpios) {} auto VolumeButtons::read(lv_indev_data_t* data) -> void { bool vol_up = gpios_.Get(drivers::IGpios::Pin::kKeyUp); - if (!vol_up) { - ESP_LOGI("volume", "vol up"); + switch (up_.update(!vol_up)) { + case Trigger::State::kNone: + break; + default: + events::Audio().Dispatch(audio::StepUpVolume{}); + break; } bool vol_down = gpios_.Get(drivers::IGpios::Pin::kKeyDown); - if (!vol_down) { - ESP_LOGI("volume", "vol down"); + switch (down_.update(!vol_down)) { + case Trigger::State::kNone: + break; + default: + events::Audio().Dispatch(audio::StepDownVolume{}); + break; } } -- cgit v1.2.3