Merge pull request #836 from gullradriel/looking-glass-update

Looking glass update
This commit is contained in:
gullradriel
2023-03-16 17:41:22 +01:00
committed by GitHub
2 changed files with 242 additions and 177 deletions

View File

@@ -184,6 +184,7 @@ namespace ui
&field_lna, &field_lna,
&field_vga, &field_vga,
&text_range, &text_range,
&steps_config,
&filter_config, &filter_config,
&field_rf_amp, &field_rf_amp,
&range_presets, &range_presets,
@@ -194,21 +195,71 @@ namespace ui
load_Presets(); // Load available presets from TXT files (or default) load_Presets(); // Load available presets from TXT files (or default)
field_frequency_min.set_value(presets_db[0].min); // Defaults to first preset field_frequency_min.set_value(presets_db[0].min); // Defaults to first preset
field_frequency_min.set_step( steps );
field_frequency_min.on_change = [this](int32_t v) field_frequency_min.on_change = [this](int32_t v)
{ {
if (v >= field_frequency_max.value()) int32_t steps_ = steps ;
field_frequency_max.set_value(v + 240); if( steps_ < 20 )
steps_ = 20 ;
if( v > 7200 - steps_ )
{
v = 7200 - steps_ ;
field_frequency_min.set_value( v );
}
if (v >= (field_frequency_max.value() - steps_ ) )
field_frequency_max.set_value( v + steps_ );
this->on_range_changed(); this->on_range_changed();
}; };
field_frequency_min.on_select = [this, &nav](NumberField& field) {
auto new_view = nav_.push<FrequencyKeypadView>(field_frequency_min.value()*1000000);
new_view->on_changed = [this, &field](rf::Frequency f) {
int32_t freq = f / 1000000 ;
int32_t steps_ = steps ;
if( steps_ < 20 )
steps_ = 20 ;
if( freq > (7200 - steps_ ) )
freq= 7200 - steps_ ;
field_frequency_min.set_value( freq );
if( field_frequency_max.value() < ( freq + steps_ ) )
field_frequency_max.set_value( freq + steps_ );
this->on_range_changed();
};
};
field_frequency_max.set_value(presets_db[0].max); // Defaults to first preset field_frequency_max.set_value(presets_db[0].max); // Defaults to first preset
field_frequency_max.set_step( steps );
field_frequency_max.on_change = [this](int32_t v) field_frequency_max.on_change = [this](int32_t v)
{ {
if (v <= field_frequency_min.value()) int32_t steps_ = steps ;
field_frequency_min.set_value(v - 240); if( steps_ < 20 )
steps_ = 20 ;
if( v < steps_ )
{
v = steps_ ;
field_frequency_max.set_value( v );
}
if (v < (field_frequency_min.value() + steps_) )
field_frequency_min.set_value(v - steps_);
this->on_range_changed(); this->on_range_changed();
}; };
field_frequency_max.on_select = [this, &nav](NumberField& field) {
auto new_view = nav_.push<FrequencyKeypadView>(field_frequency_max.value()*1000000);
new_view->on_changed = [this, &field](rf::Frequency f) {
int32_t steps_ = steps ;
if( steps_ < 20 )
steps_ = 20 ;
int32_t freq = f / 1000000 ;
if( freq < 20 )
freq = 20 ;
field_frequency_max.set_value( freq );
if( field_frequency_min.value() > ( freq - steps) )
field_frequency_min.set_value( freq - steps );
this->on_range_changed();
};
};
field_lna.set_value(receiver_model.lna()); field_lna.set_value(receiver_model.lna());
field_lna.on_change = [this](int32_t v) field_lna.on_change = [this](int32_t v)
{ {
@@ -221,11 +272,13 @@ namespace ui
this->on_vga_changed(v_db); this->on_vga_changed(v_db);
}; };
filter_config.set_selected_index(0); steps_config.set_selected_index(3); //default of 250 Mhz steps
filter_config.on_change = [this](size_t n, OptionsField::value_t v) steps_config.on_change = [this](size_t n, OptionsField::value_t v)
{ {
(void)n; (void)n;
min_color_power = v; field_frequency_min.set_step( v );
field_frequency_max.set_step( v );
steps = v ;
}; };
range_presets.on_change = [this](size_t n, OptionsField::value_t v) range_presets.on_change = [this](size_t n, OptionsField::value_t v)

View File

@@ -91,28 +91,29 @@
std::array<Color, 240> spectrum_row = { 0 }; std::array<Color, 240> spectrum_row = { 0 };
ChannelSpectrumFIFO* fifo { nullptr }; ChannelSpectrumFIFO* fifo { nullptr };
uint8_t max_power = 0; uint8_t max_power = 0;
int32_t steps = 250 ; // default of 250 Mhz steps
Labels labels{ Labels labels{
{{0, 0}, "MIN: MAX: LNA VGA ", Color::light_grey()}, {{0, 0}, "MIN: MAX: LNA VGA ", Color::light_grey()},
{{0, 1 * 16}, " RANGE: FILTER: AMP:", Color::light_grey()}, {{0, 1 * 16}, " RANGE: FILTER: AMP:", Color::light_grey()},
{{0, 2 * 16}, "PRESET:", Color::light_grey()}, {{0, 2 * 16}, "PRESET:", Color::light_grey()},
{{0, 3 * 16}, "MARKER: MHz +/- MHz", Color::light_grey()}, {{0, 3 * 16}, "MARKER: MHz +/- MHz", Color::light_grey()},
{{0, 4 * 16}, "RESOLUTION: (fft trigger)", Color::light_grey()} {{0, 4 * 16}, "RESOLUTION: STEPS:", Color::light_grey()}
}; };
NumberField field_frequency_min { NumberField field_frequency_min {
{ 4 * 8, 0 * 16 }, { 4 * 8, 0 * 16 },
4, 4,
{ 0, 6960 }, { 0, 7199 },
240, 1, // number of steps by encoder delta
' ' ' '
}; };
NumberField field_frequency_max { NumberField field_frequency_max {
{ 13 * 8, 0 * 16 }, { 13 * 8, 0 * 16 },
4, 4,
{ 240, 7200 }, { 1, 7200 },
240, 1, // number of steps by encoder delta
' ' ' '
}; };
@@ -128,6 +129,18 @@
{7 * 8, 1 * 16, 4 * 8, 16}, {7 * 8, 1 * 16, 4 * 8, 16},
""}; ""};
OptionsField steps_config{
{ 22 * 8, 4 * 16},
4,
{
{"1", 1},
{"50", 50},
{"100", 100},
{"250", 250},
{"500", 500},
{"1000", 1000},
}};
OptionsField filter_config{ OptionsField filter_config{
{19 * 8, 1 * 16}, {19 * 8, 1 * 16},
4, 4,
@@ -184,7 +197,6 @@
} }
} }
}; };
}; };
} }
#endif #endif