summaryrefslogtreecommitdiff
path: root/src/ui
diff options
context:
space:
mode:
authorailurux <ailuruxx@gmail.com>2024-02-12 17:44:55 +1100
committerailurux <ailuruxx@gmail.com>2024-02-12 17:44:55 +1100
commit0426d245c8d863f18babdfbaf21c8673b0746feb (patch)
tree32c78617d954ca6546b0225de68e0acc299e7bca /src/ui
parent527374c72e1ec52e1d5814dbee3587ae100631dd (diff)
downloadtangara-fw-0426d245c8d863f18babdfbaf21c8673b0746feb.tar.gz
Scroll sensitivity configurable, but inverted
Diffstat (limited to 'src/ui')
-rw-r--r--src/ui/encoder_input.cpp6
-rw-r--r--src/ui/include/encoder_input.hpp2
-rw-r--r--src/ui/include/ui_fsm.hpp2
-rw-r--r--src/ui/ui_fsm.cpp24
4 files changed, 33 insertions, 1 deletions
diff --git a/src/ui/encoder_input.cpp b/src/ui/encoder_input.cpp
index 5a46cd05..3eebe16e 100644
--- a/src/ui/encoder_input.cpp
+++ b/src/ui/encoder_input.cpp
@@ -50,6 +50,7 @@ EncoderInput::EncoderInput(drivers::IGpios& gpios, drivers::TouchWheel& wheel)
scroller_(std::make_unique<Scroller>()),
mode_(drivers::NvsStorage::InputModes::kRotatingWheel),
is_locked_(false),
+ scroll_sensitivity_(10),
is_scrolling_wheel_(false) {
lv_indev_drv_init(&driver_);
driver_.type = LV_INDEV_TYPE_ENCODER;
@@ -272,6 +273,11 @@ auto EncoderInput::Read(lv_indev_data_t* data) -> void {
}
}
+auto EncoderInput::scroll_sensitivity(uint8_t val) -> void {
+ scroll_sensitivity_ = val;
+ relative_wheel_->SetThreshold(scroll_sensitivity_);
+}
+
auto EncoderInput::UpdateKeyState(Keys key, uint64_t ms, bool clicked) -> void {
if (clicked) {
if (!touch_time_ms_.contains(key)) {
diff --git a/src/ui/include/encoder_input.hpp b/src/ui/include/encoder_input.hpp
index fbd57f32..17e278b2 100644
--- a/src/ui/include/encoder_input.hpp
+++ b/src/ui/include/encoder_input.hpp
@@ -38,6 +38,7 @@ class EncoderInput {
auto registration() -> lv_indev_t* { return registration_; }
auto mode(drivers::NvsStorage::InputModes mode) { mode_ = mode; }
+ auto scroll_sensitivity(uint8_t val) -> void;
auto lock(bool l) -> void { is_locked_ = l; }
private:
@@ -51,6 +52,7 @@ class EncoderInput {
drivers::NvsStorage::InputModes mode_;
bool is_locked_;
+ uint8_t scroll_sensitivity_;
// Every kind of distinct input that we could map to an action.
enum class Keys {
diff --git a/src/ui/include/ui_fsm.hpp b/src/ui/include/ui_fsm.hpp
index 52ab77a5..ffaff0bb 100644
--- a/src/ui/include/ui_fsm.hpp
+++ b/src/ui/include/ui_fsm.hpp
@@ -128,7 +128,7 @@ class UiState : public tinyfsm::Fsm<UiState> {
static lua::Property sDisplayBrightness;
static lua::Property sControlsScheme;
- static lua::Property sControlSensitivity;
+ static lua::Property sScrollSensitivity;
static lua::Property sDatabaseUpdating;
};
diff --git a/src/ui/ui_fsm.cpp b/src/ui/ui_fsm.cpp
index 6e4bbe6f..da8d8999 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 {
@@ -397,6 +416,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!");
@@ -460,6 +483,7 @@ void Lua::entry() {
sLua->bridge().AddPropertyModule("controls",
{
{"scheme", &sControlsScheme},
+ {"scroll_sensitivity", &sScrollSensitivity},
});
sLua->bridge().AddPropertyModule(