mirror of
https://github.com/portapack-mayhem/mayhem-firmware.git
synced 2025-01-08 22:07:40 +00:00
RSSI draw/ Level app opt (#2403)
* change peak from green to orange * add db
This commit is contained in:
parent
498369b77d
commit
ac89ca2a2a
@ -187,6 +187,7 @@ void LevelView::on_statistics_update(const ChannelStatistics& statistics) {
|
|||||||
if (last_max_db != statistics.max_db) {
|
if (last_max_db != statistics.max_db) {
|
||||||
last_max_db = statistics.max_db;
|
last_max_db = statistics.max_db;
|
||||||
freq_stats_db.set("Power: " + to_string_dec_int(statistics.max_db) + " db");
|
freq_stats_db.set("Power: " + to_string_dec_int(statistics.max_db) + " db");
|
||||||
|
rssi.set_db(statistics.max_db);
|
||||||
}
|
}
|
||||||
// refresh rssi
|
// refresh rssi
|
||||||
if (last_min_rssi != rssi_graph.get_graph_min() || last_avg_rssi != rssi_graph.get_graph_avg() || last_max_rssi != rssi_graph.get_graph_max()) {
|
if (last_min_rssi != rssi_graph.get_graph_min() || last_avg_rssi != rssi_graph.get_graph_avg() || last_max_rssi != rssi_graph.get_graph_max()) {
|
||||||
|
@ -100,8 +100,19 @@ void RSSI::paint(Painter& painter) {
|
|||||||
const Rect r5{r.left() + peak - 3, r.top(), 3, r.height()};
|
const Rect r5{r.left() + peak - 3, r.top(), 3, r.height()};
|
||||||
painter.fill_rectangle(
|
painter.fill_rectangle(
|
||||||
r5,
|
r5,
|
||||||
Theme::getInstance()->fg_green->foreground);
|
Theme::getInstance()->fg_orange->foreground);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// dB - x
|
||||||
|
constexpr int db_min = -80;
|
||||||
|
constexpr int db_max = 10;
|
||||||
|
constexpr int db_delta = db_max - db_min;
|
||||||
|
const range_t<int> x_db_range{0, r.width() - 1};
|
||||||
|
const int16_t x_db = x_db_range.clip((db_ - db_min) * r.width() / db_delta);
|
||||||
|
|
||||||
|
const Rect r_db{r.left() + x_db, r.top(), 1, r.height()};
|
||||||
|
|
||||||
|
if (db_) painter.fill_rectangle(r_db, Color::green());
|
||||||
} else {
|
} else {
|
||||||
// vertical bottom to top level meters
|
// vertical bottom to top level meters
|
||||||
const range_t<int> y_avg_range{0, r.height() - 1};
|
const range_t<int> y_avg_range{0, r.height() - 1};
|
||||||
@ -115,7 +126,7 @@ void RSSI::paint(Painter& painter) {
|
|||||||
|
|
||||||
// y_min
|
// y_min
|
||||||
const Rect r0{r.left(), r.bottom() - y_min, r.width(), y_min};
|
const Rect r0{r.left(), r.bottom() - y_min, r.width(), y_min};
|
||||||
painter.fill_rectangle(
|
painter.fill_rectangle( // TODO: the blue plot is broken in vertical bars, not from the dB PR (#2403)
|
||||||
r0,
|
r0,
|
||||||
Color::blue());
|
Color::blue());
|
||||||
|
|
||||||
@ -149,8 +160,18 @@ void RSSI::paint(Painter& painter) {
|
|||||||
const Rect r5{r.left(), r.bottom() - peak - 3, r.width(), 3};
|
const Rect r5{r.left(), r.bottom() - peak - 3, r.width(), 3};
|
||||||
painter.fill_rectangle(
|
painter.fill_rectangle(
|
||||||
r5,
|
r5,
|
||||||
Color::green());
|
Color::orange());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// dB - y
|
||||||
|
constexpr int db_min = -80;
|
||||||
|
constexpr int db_max = 10;
|
||||||
|
constexpr int db_delta = db_max - db_min;
|
||||||
|
const range_t<int> y_db_range{0, r.height() - 1};
|
||||||
|
const int16_t y_db = y_db_range.clip((db_ - db_min) * r.height() / db_delta);
|
||||||
|
|
||||||
|
const Rect r_db{r.left(), r.bottom() - y_db, r.width(), 3};
|
||||||
|
if (db_) painter.fill_rectangle(r_db, Color::green());
|
||||||
}
|
}
|
||||||
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);
|
||||||
@ -159,7 +180,7 @@ void RSSI::paint(Painter& painter) {
|
|||||||
const Rect r6{r.left(), r.top(), r.width(), r.height()};
|
const Rect r6{r.left(), r.top(), r.width(), r.height()};
|
||||||
painter.draw_rectangle(
|
painter.draw_rectangle(
|
||||||
r6,
|
r6,
|
||||||
Color::white());
|
Color::white()); // TODO this and all the following Color struct call should satisfy the new "theme" system ref
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -500,4 +521,8 @@ bool RSSI::on_touch(const TouchEvent event) {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void RSSI::set_db(int16_t db) {
|
||||||
|
db_ = db;
|
||||||
|
}
|
||||||
} /* namespace ui */
|
} /* namespace ui */
|
||||||
|
@ -61,6 +61,7 @@ class RSSI : public Widget {
|
|||||||
void on_focus() override;
|
void on_focus() override;
|
||||||
bool on_key(const KeyEvent key) override;
|
bool on_key(const KeyEvent key) override;
|
||||||
bool on_touch(const TouchEvent event) override;
|
bool on_touch(const TouchEvent event) override;
|
||||||
|
void set_db(int16_t db);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
int8_t min_ = 0;
|
int8_t min_ = 0;
|
||||||
@ -68,6 +69,7 @@ class RSSI : public Widget {
|
|||||||
int8_t max_ = 0;
|
int8_t max_ = 0;
|
||||||
int8_t peak_ = 0;
|
int8_t peak_ = 0;
|
||||||
size_t peak_duration_ = 0;
|
size_t peak_duration_ = 0;
|
||||||
|
int16_t db_ = 0;
|
||||||
bool instant_exec_{false};
|
bool instant_exec_{false};
|
||||||
|
|
||||||
bool pitch_rssi_enabled = false;
|
bool pitch_rssi_enabled = false;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user