added focusable ability to rssi field

This commit is contained in:
GullCode 2023-03-13 22:55:48 +01:00
parent 6a61b9528e
commit 37cfcb0d5c
2 changed files with 125 additions and 70 deletions

View File

@ -162,6 +162,14 @@ namespace ui {
if (pitch_rssi_enabled) { if (pitch_rssi_enabled) {
baseband::set_pitch_rssi((avg_ - raw_min) * 2000 / raw_delta, true); baseband::set_pitch_rssi((avg_ - raw_min) * 2000 / raw_delta, true);
} }
if( has_focus() || highlighted() )
{
const Rect r6 { r.left(), r.top(), r.width(), r.height() };
painter.draw_rectangle(
r6,
Color::white()
);
}
} }
int32_t RSSI::get_min() int32_t RSSI::get_min()
@ -317,4 +325,43 @@ namespace ui {
set_dirty(); set_dirty();
} }
void RSSI::on_focus() {
if( on_highlight )
on_highlight(*this);
}
bool RSSI::on_key(const KeyEvent key) {
if( key == KeyEvent::Select ) {
if( on_select ) {
on_select(*this);
return true;
}
} else {
if( on_dir ) {
return on_dir(*this, key);
}
}
return false;
}
bool RSSI::on_touch(const TouchEvent event) {
switch(event.type) {
case TouchEvent::Type::Start:
set_highlighted(true);
set_dirty();
if( on_touch_press) {
on_touch_press(*this);
}
return true;
case TouchEvent::Type::End:
set_highlighted(false);
set_dirty();
if( on_touch_release) {
on_touch_release(*this);
}
return true;
default:
return false;
}
}
} /* namespace ui */ } /* namespace ui */

View File

@ -25,88 +25,96 @@
#include "ui.hpp" #include "ui.hpp"
#include "ui_widget.hpp" #include "ui_widget.hpp"
#include "ui_painter.hpp" #include "ui_painter.hpp"
#include "event_m0.hpp" #include "event_m0.hpp"
#include "message.hpp" #include "message.hpp"
#include <cstdint> #include <cstdint>
namespace ui { namespace ui {
class RSSI : public Widget { class RSSI : public Widget {
public: public:
RSSI( std::function<void(RSSI&)> on_select { };
const Rect parent_rect std::function<void(RSSI&)> on_touch_release { }; // Executed when releasing touch, after on_select.
) : Widget { parent_rect }, std::function<void(RSSI&)> on_touch_press { }; // Executed when touching, before on_select.
min_ { 0 }, std::function<bool(RSSI&, KeyEvent)> on_dir { };
avg_ { 0 }, std::function<void(RSSI&)> on_highlight { };
max_ { 0 }
{
}
void paint(Painter& painter) override; RSSI(
int32_t get_min(); const Rect parent_rect
int32_t get_avg(); ) : Widget { parent_rect },
int32_t get_max(); min_ { 0 },
int32_t get_delta(); avg_ { 0 },
void set_vertical_rssi(bool enabled); max_ { 0 }
void set_peak(bool enabled, size_t duration); {
}
private: int32_t get_min();
int32_t min_; int32_t get_avg();
int32_t avg_; int32_t get_max();
int32_t max_; int32_t get_delta();
int32_t peak_ = 0 ; void set_vertical_rssi(bool enabled);
size_t peak_duration_ = 0 ; void set_peak(bool enabled, size_t duration);
bool pitch_rssi_enabled = false; void paint(Painter& painter) override;
bool vertical_rssi_enabled = false; // scale [vertically/from bottom to top] void on_focus() override;
// instead of [horizontally/from left to right] bool on_key(const KeyEvent key) override;
bool peak_enabled = false; bool on_touch(const TouchEvent event) override;
size_t peak_duration = 1000; // peak duration in msec before being reset to actual max_rssi
MessageHandlerRegistration message_handler_stats { private:
Message::ID::RSSIStatistics, int32_t min_;
[this](const Message* const p) { int32_t avg_;
this->on_statistics_update(static_cast<const RSSIStatisticsMessage*>(p)->statistics); int32_t max_;
} int32_t peak_ = 0 ;
}; size_t peak_duration_ = 0 ;
bool instant_exec_ { false };
MessageHandlerRegistration message_handler_pitch_rssi { bool pitch_rssi_enabled = false;
Message::ID::PitchRSSIConfigure, bool vertical_rssi_enabled = false; // scale [vertically/from bottom to top]
[this](const Message* const p) { // instead of [horizontally/from left to right]
const auto message = *reinterpret_cast<const PitchRSSIConfigureMessage*>(p); bool peak_enabled = false;
this->set_pitch_rssi(message.enabled); size_t peak_duration = 1000; // peak duration in msec before being reset to actual max_rssi
}
};
void on_statistics_update(const RSSIStatistics& statistics); MessageHandlerRegistration message_handler_stats {
void set_pitch_rssi(bool enabled); Message::ID::RSSIStatistics,
}; [this](const Message* const p) {
this->on_statistics_update(static_cast<const RSSIStatisticsMessage*>(p)->statistics);
}
};
struct RSSIGraph_entry { MessageHandlerRegistration message_handler_pitch_rssi {
int32_t rssi_min { 0 }; Message::ID::PitchRSSIConfigure,
int32_t rssi_avg { 0 }; [this](const Message* const p) {
int32_t rssi_max { 0 }; const auto message = *reinterpret_cast<const PitchRSSIConfigureMessage*>(p);
int32_t db { 0 }; this->set_pitch_rssi(message.enabled);
}; }
};
using RSSIGraphList = std::vector<RSSIGraph_entry>; void on_statistics_update(const RSSIStatistics& statistics);
void set_pitch_rssi(bool enabled);
};
class RSSIGraph : public Widget { struct RSSIGraph_entry {
public: int32_t rssi_min { 0 };
RSSIGraph( int32_t rssi_avg { 0 };
const Rect parent_rect int32_t rssi_max { 0 };
) : Widget { parent_rect } int32_t db { 0 };
{ };
}
void paint(Painter& painter) override;
void add_values(int32_t rssi_min, int32_t rssi_avg, int32_t rssi_max, int32_t db );
private: using RSSIGraphList = std::vector<RSSIGraph_entry>;
RSSIGraphList graph_list { } ;
}; class RSSIGraph : public Widget {
public:
RSSIGraph(
const Rect parent_rect
) : Widget { parent_rect }
{
}
void paint(Painter& painter) override;
void add_values(int32_t rssi_min, int32_t rssi_avg, int32_t rssi_max, int32_t db );
private:
RSSIGraphList graph_list { } ;
};
} }