mirror of
https://github.com/portapack-mayhem/mayhem-firmware.git
synced 2025-04-23 16:51:30 +00:00
Changed default RSSI peak value, position and size of RSSI graph
This commit is contained in:
parent
47b770bc3a
commit
c76c6bd857
@ -180,7 +180,7 @@ namespace ui {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// default peak value
|
// default peak value
|
||||||
peak_mode.set_selected_index(3);
|
peak_mode.set_selected_index(2);
|
||||||
rssi_resolution.set_selected_index(1);
|
rssi_resolution.set_selected_index(1);
|
||||||
//FILL STEP OPTIONS
|
//FILL STEP OPTIONS
|
||||||
freqman_set_modulation_option( field_mode );
|
freqman_set_modulation_option( field_mode );
|
||||||
|
@ -41,200 +41,197 @@
|
|||||||
|
|
||||||
namespace ui {
|
namespace ui {
|
||||||
|
|
||||||
class LevelView : public View {
|
class LevelView : public View {
|
||||||
public:
|
public:
|
||||||
LevelView(NavigationView& nav);
|
LevelView(NavigationView& nav);
|
||||||
~LevelView();
|
~LevelView();
|
||||||
|
|
||||||
void focus() override;
|
void focus() override;
|
||||||
|
|
||||||
void big_display_freq( int64_t f );
|
void big_display_freq( int64_t f );
|
||||||
|
|
||||||
const Style style_grey { // level
|
const Style style_grey { // level
|
||||||
.font = font::fixed_8x16,
|
.font = font::fixed_8x16,
|
||||||
.background = Color::black(),
|
.background = Color::black(),
|
||||||
.foreground = Color::grey(),
|
.foreground = Color::grey(),
|
||||||
};
|
};
|
||||||
|
|
||||||
const Style style_white { // level
|
const Style style_white { // level
|
||||||
.font = font::fixed_8x16,
|
.font = font::fixed_8x16,
|
||||||
.background = Color::black(),
|
.background = Color::black(),
|
||||||
.foreground = Color::white(),
|
.foreground = Color::white(),
|
||||||
};
|
};
|
||||||
|
|
||||||
const Style style_yellow { //Found signal
|
const Style style_yellow { //Found signal
|
||||||
.font = font::fixed_8x16,
|
.font = font::fixed_8x16,
|
||||||
.background = Color::black(),
|
.background = Color::black(),
|
||||||
.foreground = Color::yellow(),
|
.foreground = Color::yellow(),
|
||||||
};
|
};
|
||||||
|
|
||||||
const Style style_green { //Found signal
|
const Style style_green { //Found signal
|
||||||
.font = font::fixed_8x16,
|
.font = font::fixed_8x16,
|
||||||
.background = Color::black(),
|
.background = Color::black(),
|
||||||
.foreground = Color::green(),
|
.foreground = Color::green(),
|
||||||
};
|
};
|
||||||
|
|
||||||
const Style style_red { //erasing freq
|
const Style style_red { //erasing freq
|
||||||
.font = font::fixed_8x16,
|
.font = font::fixed_8x16,
|
||||||
.background = Color::black(),
|
.background = Color::black(),
|
||||||
.foreground = Color::red(),
|
.foreground = Color::red(),
|
||||||
};
|
};
|
||||||
|
|
||||||
const Style style_blue { // quick level, wait == 0
|
const Style style_blue { // quick level, wait == 0
|
||||||
.font = font::fixed_8x16,
|
.font = font::fixed_8x16,
|
||||||
.background = Color::black(),
|
.background = Color::black(),
|
||||||
.foreground = Color::blue(),
|
.foreground = Color::blue(),
|
||||||
};
|
};
|
||||||
|
|
||||||
std::string title() const override { return "Level"; };
|
std::string title() const override { return "Level"; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
NavigationView& nav_;
|
NavigationView& nav_;
|
||||||
|
|
||||||
size_t change_mode( freqman_index_t mod_type);
|
size_t change_mode( freqman_index_t mod_type);
|
||||||
void on_statistics_update(const ChannelStatistics& statistics);
|
void on_statistics_update(const ChannelStatistics& statistics);
|
||||||
void set_display_freq( int64_t freq );
|
void set_display_freq( int64_t freq );
|
||||||
bool check_sd_card();
|
bool check_sd_card();
|
||||||
|
|
||||||
int32_t db { 0 };
|
int32_t db { 0 };
|
||||||
long long int MAX_UFREQ = { 7200000000 }; // maximum usable freq
|
long long int MAX_UFREQ = { 7200000000 }; // maximum usable freq
|
||||||
bool sd_card_mounted = false ;
|
bool sd_card_mounted = false ;
|
||||||
rf::Frequency freq = { 0 } ;
|
rf::Frequency freq = { 0 } ;
|
||||||
|
|
||||||
Labels labels
|
Labels labels
|
||||||
{
|
{
|
||||||
{ { 0 * 8 , 0 * 16 }, "LNA: VGA: AMP: VOL: ", Color::light_grey() },
|
{ { 0 * 8 , 0 * 16 }, "LNA: VGA: AMP: VOL: ", Color::light_grey() },
|
||||||
{ { 0 * 8 , 1 * 16 }, "BW: MODE: S: ", Color::light_grey() },
|
{ { 0 * 8 , 1 * 16 }, "BW: MODE: S: ", Color::light_grey() },
|
||||||
};
|
};
|
||||||
|
|
||||||
LNAGainField field_lna {
|
LNAGainField field_lna {
|
||||||
{ 4 * 8, 0 * 16 }
|
{ 4 * 8, 0 * 16 }
|
||||||
};
|
};
|
||||||
|
|
||||||
VGAGainField field_vga {
|
VGAGainField field_vga {
|
||||||
{ 11 * 8, 0 * 16 }
|
{ 11 * 8, 0 * 16 }
|
||||||
};
|
};
|
||||||
|
|
||||||
RFAmpField field_rf_amp {
|
RFAmpField field_rf_amp {
|
||||||
{ 18 * 8, 0 * 16 }
|
{ 18 * 8, 0 * 16 }
|
||||||
};
|
};
|
||||||
|
|
||||||
NumberField field_volume {
|
NumberField field_volume {
|
||||||
{ 24 * 8, 0 * 16 },
|
{ 24 * 8, 0 * 16 },
|
||||||
2,
|
2,
|
||||||
{ 0, 99 },
|
{ 0, 99 },
|
||||||
1,
|
1,
|
||||||
' ',
|
' ',
|
||||||
};
|
};
|
||||||
|
|
||||||
OptionsField field_bw {
|
OptionsField field_bw {
|
||||||
{ 3 * 8, 1 * 16 },
|
{ 3 * 8, 1 * 16 },
|
||||||
6,
|
6,
|
||||||
{ }
|
{ }
|
||||||
};
|
};
|
||||||
|
|
||||||
OptionsField field_mode {
|
OptionsField field_mode {
|
||||||
{ 15 * 8, 1 * 16 },
|
{ 15 * 8, 1 * 16 },
|
||||||
3,
|
3,
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
OptionsField step_mode {
|
OptionsField step_mode {
|
||||||
{ 16 * 8, 2 * 16 + 4 },
|
{ 16 * 8, 2 * 16 + 4 },
|
||||||
12,
|
12,
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
RSSIGraph rssi_graph { // 240x320 =>
|
ButtonWithEncoder button_frequency {
|
||||||
{ 0 , 5 * 16 + 4 , 240 - 5 * 8 , 216 },
|
{ 0 * 8 , 2 * 16 + 8 , 15 * 8 , 1 * 8 },
|
||||||
};
|
""
|
||||||
|
};
|
||||||
|
|
||||||
RSSI rssi { // 240x320 =>
|
OptionsField audio_mode {
|
||||||
{ 240 - 5 * 8 , 5 * 16 + 4 , 5 * 8 , 216 },
|
{ 21 * 8, 1 * 16 },
|
||||||
};
|
9,
|
||||||
|
{
|
||||||
|
{"audio off", 0},
|
||||||
|
{"audio on",1}
|
||||||
|
//{"tone on", 2},
|
||||||
|
//{"tone off", 2},
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
Text text_ctcss {
|
||||||
|
{ 22 * 8, 3 * 16 + 4 , 14 * 8, 1 * 8 },
|
||||||
|
""
|
||||||
|
};
|
||||||
|
|
||||||
ButtonWithEncoder button_frequency {
|
// RSSI: XX/XX/XXX,dt: XX
|
||||||
{ 0 * 8 , 2 * 16 + 8 , 15 * 8 , 1 * 8 },
|
Text freq_stats_rssi {
|
||||||
""
|
{ 0 * 8 , 3 * 16 + 4 , 22 * 8, 14 },
|
||||||
};
|
};
|
||||||
|
|
||||||
OptionsField audio_mode {
|
// Power: -XXX db
|
||||||
{ 21 * 8, 1 * 16 },
|
Text freq_stats_db {
|
||||||
9,
|
{ 0 * 8 , 4 * 16 + 4 , 14 * 8, 14 },
|
||||||
{
|
};
|
||||||
{"audio off", 0},
|
|
||||||
{"audio on",1}
|
|
||||||
//{"tone on", 2},
|
|
||||||
//{"tone off", 2},
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
OptionsField peak_mode {
|
||||||
|
{ 40 + 10 * 8, 4 * 16 + 4 },
|
||||||
|
10,
|
||||||
|
{
|
||||||
|
{"peak:none", 0},
|
||||||
|
{"peak:0.25s",250},
|
||||||
|
{"peak:0.5s",500},
|
||||||
|
{"peak:1s",1000},
|
||||||
|
{"peak:3s",3000},
|
||||||
|
{"peak:5s",5000},
|
||||||
|
{"peak:10s",10000},
|
||||||
|
}
|
||||||
|
};
|
||||||
|
OptionsField rssi_resolution {
|
||||||
|
{ 44 + 20 * 8, 4 * 16 + 4},
|
||||||
|
4,
|
||||||
|
{
|
||||||
|
{"16x", 16},
|
||||||
|
{"32x", 32},
|
||||||
|
{"64x", 64},
|
||||||
|
{"128x", 128},
|
||||||
|
{"240x", 240},
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
Text text_ctcss {
|
RSSIGraph rssi_graph { // 240x320 =>
|
||||||
{ 22 * 8, 3 * 16 + 4 , 14 * 8, 1 * 8 },
|
{ 0 , 5 * 16 + 4 , 240 - 5 * 8 , 320 - ( 5 * 16 + 4 ) },
|
||||||
""
|
};
|
||||||
};
|
|
||||||
|
|
||||||
// RSSI: XX/XX/XXX,dt: XX
|
RSSI rssi { // 240x320 =>
|
||||||
Text freq_stats_rssi {
|
{ 240 - 5 * 8 , 5 * 16 + 4 , 5 * 8 , 320 - ( 5 * 16 + 4 ) },
|
||||||
{ 0 * 8 , 3 * 16 + 4 , 22 * 8, 16 },
|
};
|
||||||
};
|
|
||||||
|
|
||||||
Text freq_stats_db {
|
void handle_coded_squelch(const uint32_t value);
|
||||||
{ 0 * 8 , 4 * 16 + 4 , 15 * 8, 16 },
|
void on_headphone_volume_changed(int32_t v);
|
||||||
};
|
|
||||||
|
|
||||||
|
MessageHandlerRegistration message_handler_coded_squelch {
|
||||||
|
Message::ID::CodedSquelch,
|
||||||
|
[this](const Message* const p) {
|
||||||
|
const auto message = *reinterpret_cast<const CodedSquelchMessage*>(p);
|
||||||
|
this->handle_coded_squelch(message.value);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
OptionsField peak_mode {
|
MessageHandlerRegistration message_handler_stats {
|
||||||
{ 40 + 10 * 8, 4 * 16 + 4 },
|
Message::ID::ChannelStatistics,
|
||||||
10,
|
[this](const Message* const p) {
|
||||||
{
|
this->on_statistics_update(static_cast<const ChannelStatisticsMessage*>(p)->statistics);
|
||||||
{"peak:none", 0},
|
}
|
||||||
{"peak:0.25s",250},
|
};
|
||||||
{"peak:0.5s",500},
|
// app save settings
|
||||||
{"peak:1s",1000},
|
std::app_settings settings { };
|
||||||
{"peak:3s",3000},
|
std::app_settings::AppSettings app_settings { };
|
||||||
{"peak:5s",5000},
|
};
|
||||||
{"peak:10s",10000},
|
|
||||||
}
|
|
||||||
};
|
|
||||||
OptionsField rssi_resolution {
|
|
||||||
{ 44 + 20 * 8, 4 * 16 + 4},
|
|
||||||
4,
|
|
||||||
{
|
|
||||||
{"16x", 16},
|
|
||||||
{"32x", 32},
|
|
||||||
{"64x", 64},
|
|
||||||
{"128x", 128},
|
|
||||||
{"240x", 240},
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
void handle_coded_squelch(const uint32_t value);
|
|
||||||
void on_headphone_volume_changed(int32_t v);
|
|
||||||
|
|
||||||
MessageHandlerRegistration message_handler_coded_squelch {
|
|
||||||
Message::ID::CodedSquelch,
|
|
||||||
[this](const Message* const p) {
|
|
||||||
const auto message = *reinterpret_cast<const CodedSquelchMessage*>(p);
|
|
||||||
this->handle_coded_squelch(message.value);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
MessageHandlerRegistration message_handler_stats {
|
|
||||||
Message::ID::ChannelStatistics,
|
|
||||||
[this](const Message* const p) {
|
|
||||||
this->on_statistics_update(static_cast<const ChannelStatisticsMessage*>(p)->statistics);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
// app save settings
|
|
||||||
std::app_settings settings { };
|
|
||||||
std::app_settings::AppSettings app_settings { };
|
|
||||||
};
|
|
||||||
|
|
||||||
} /* namespace ui */
|
} /* namespace ui */
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user