mirror of
https://github.com/eried/portapack-mayhem.git
synced 2024-10-01 01:26:06 -04:00
Adding Frequency Correction menu and effect (#1016)
* Adding Frequency Correction and entry menu in Settings
This commit is contained in:
parent
02811b9967
commit
f18764f109
@ -316,8 +316,7 @@ SetConverterSettingsView::SetConverterSettingsView(NavigationView& nav) {
|
|||||||
&check_converter,
|
&check_converter,
|
||||||
&converter_mode,
|
&converter_mode,
|
||||||
&button_converter_freq,
|
&button_converter_freq,
|
||||||
&button_save,
|
&button_return});
|
||||||
&button_cancel});
|
|
||||||
|
|
||||||
check_show_converter.set_value(!portapack::persistent_memory::config_hide_converter());
|
check_show_converter.set_value(!portapack::persistent_memory::config_hide_converter());
|
||||||
check_show_converter.on_select = [this](Checkbox&, bool v) {
|
check_show_converter.on_select = [this](Checkbox&, bool v) {
|
||||||
@ -365,16 +364,69 @@ SetConverterSettingsView::SetConverterSettingsView(NavigationView& nav) {
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
button_save.on_select = [&nav, this](Button&) {
|
button_return.on_select = [&nav, this](Button&) {
|
||||||
nav.pop();
|
|
||||||
};
|
|
||||||
button_cancel.on_select = [&nav, this](Button&) {
|
|
||||||
nav.pop();
|
nav.pop();
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
void SetConverterSettingsView::focus() {
|
void SetConverterSettingsView::focus() {
|
||||||
button_save.focus();
|
button_return.focus();
|
||||||
|
}
|
||||||
|
|
||||||
|
// ---------------------------------------------------------
|
||||||
|
// Frequency Correction Settings
|
||||||
|
// ---------------------------------------------------------
|
||||||
|
SetFrequencyCorrectionView::SetFrequencyCorrectionView(NavigationView& nav) {
|
||||||
|
add_children({&text_freqCorrection_about,
|
||||||
|
&frequency_rx_correction_mode,
|
||||||
|
&frequency_tx_correction_mode,
|
||||||
|
&button_freq_rx_correction,
|
||||||
|
&button_freq_tx_correction,
|
||||||
|
&button_return});
|
||||||
|
|
||||||
|
frequency_rx_correction_mode.set_by_value(portapack::persistent_memory::config_freq_rx_correction_updown());
|
||||||
|
frequency_rx_correction_mode.on_change = [this](size_t, OptionsField::value_t v) {
|
||||||
|
portapack::persistent_memory::set_freq_rx_correction_updown(v);
|
||||||
|
};
|
||||||
|
|
||||||
|
frequency_tx_correction_mode.set_by_value(portapack::persistent_memory::config_freq_rx_correction_updown());
|
||||||
|
frequency_tx_correction_mode.on_change = [this](size_t, OptionsField::value_t v) {
|
||||||
|
portapack::persistent_memory::set_freq_tx_correction_updown(v);
|
||||||
|
};
|
||||||
|
|
||||||
|
button_freq_rx_correction.set_text(to_string_short_freq(portapack::persistent_memory::config_freq_rx_correction()) + "MHz (Rx)");
|
||||||
|
button_freq_rx_correction.on_select = [this, &nav](Button& button) {
|
||||||
|
auto new_view = nav.push<FrequencyKeypadView>(portapack::persistent_memory::config_converter_freq());
|
||||||
|
new_view->on_changed = [this, &button](rf::Frequency f) {
|
||||||
|
if (f > 4000000)
|
||||||
|
f = 4000000;
|
||||||
|
portapack::persistent_memory::set_config_freq_rx_correction(f);
|
||||||
|
// Retune to take converter change in account
|
||||||
|
receiver_model.set_tuning_frequency(portapack::persistent_memory::tuned_frequency());
|
||||||
|
button_freq_rx_correction.set_text("<" + to_string_short_freq(f) + " MHz>");
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
button_freq_tx_correction.set_text(to_string_short_freq(portapack::persistent_memory::config_freq_tx_correction()) + "MHz (Tx)");
|
||||||
|
button_freq_tx_correction.on_select = [this, &nav](Button& button) {
|
||||||
|
auto new_view = nav.push<FrequencyKeypadView>(portapack::persistent_memory::config_converter_freq());
|
||||||
|
new_view->on_changed = [this, &button](rf::Frequency f) {
|
||||||
|
if (f > 4000000)
|
||||||
|
f = 4000000;
|
||||||
|
portapack::persistent_memory::set_config_freq_tx_correction(f);
|
||||||
|
// Retune to take converter change in account
|
||||||
|
receiver_model.set_tuning_frequency(portapack::persistent_memory::tuned_frequency());
|
||||||
|
button_freq_tx_correction.set_text("<" + to_string_short_freq(f) + " MHz>");
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
button_return.on_select = [&nav, this](Button&) {
|
||||||
|
nav.pop();
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetFrequencyCorrectionView::focus() {
|
||||||
|
button_return.focus();
|
||||||
}
|
}
|
||||||
|
|
||||||
// ---------------------------------------------------------
|
// ---------------------------------------------------------
|
||||||
@ -528,6 +580,7 @@ SettingsMenuView::SettingsMenuView(NavigationView& nav) {
|
|||||||
{"Calibration", ui::Color::dark_cyan(), &bitmap_icon_options_touch, [&nav]() { nav.push<TouchCalibrationView>(); }},
|
{"Calibration", ui::Color::dark_cyan(), &bitmap_icon_options_touch, [&nav]() { nav.push<TouchCalibrationView>(); }},
|
||||||
{"App Settings", ui::Color::dark_cyan(), &bitmap_icon_setup, [&nav]() { nav.push<SetAppSettingsView>(); }},
|
{"App Settings", ui::Color::dark_cyan(), &bitmap_icon_setup, [&nav]() { nav.push<SetAppSettingsView>(); }},
|
||||||
{"Converter", ui::Color::dark_cyan(), &bitmap_icon_options_radio, [&nav]() { nav.push<SetConverterSettingsView>(); }},
|
{"Converter", ui::Color::dark_cyan(), &bitmap_icon_options_radio, [&nav]() { nav.push<SetConverterSettingsView>(); }},
|
||||||
|
{"FreqCorrection", ui::Color::dark_cyan(), &bitmap_icon_options_radio, [&nav]() { nav.push<SetFrequencyCorrectionView>(); }},
|
||||||
{"QR Code", ui::Color::dark_cyan(), &bitmap_icon_qr_code, [&nav]() { nav.push<SetQRCodeView>(); }},
|
{"QR Code", ui::Color::dark_cyan(), &bitmap_icon_qr_code, [&nav]() { nav.push<SetQRCodeView>(); }},
|
||||||
{"P.Memory Mgmt", ui::Color::dark_cyan(), &bitmap_icon_memory, [&nav]() { nav.push<SetPersistentMemoryView>(); }},
|
{"P.Memory Mgmt", ui::Color::dark_cyan(), &bitmap_icon_memory, [&nav]() { nav.push<SetPersistentMemoryView>(); }},
|
||||||
});
|
});
|
||||||
|
@ -329,13 +329,49 @@ class SetConverterSettingsView : public View {
|
|||||||
"",
|
"",
|
||||||
};
|
};
|
||||||
|
|
||||||
Button button_save{
|
Button button_return{
|
||||||
{2 * 8, 16 * 16, 12 * 8, 32},
|
|
||||||
"Save"};
|
|
||||||
|
|
||||||
Button button_cancel{
|
|
||||||
{16 * 8, 16 * 16, 12 * 8, 32},
|
{16 * 8, 16 * 16, 12 * 8, 32},
|
||||||
"Cancel",
|
"return",
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
class SetFrequencyCorrectionView : public View {
|
||||||
|
public:
|
||||||
|
SetFrequencyCorrectionView(NavigationView& nav);
|
||||||
|
|
||||||
|
void focus() override;
|
||||||
|
|
||||||
|
std::string title() const override { return "FreqCorrect"; };
|
||||||
|
|
||||||
|
private:
|
||||||
|
Text text_freqCorrection_about{
|
||||||
|
{0, 2 * 16, 240, 16},
|
||||||
|
"Set Frequency correction:"};
|
||||||
|
|
||||||
|
OptionsField frequency_rx_correction_mode{
|
||||||
|
{18, 5 * 16 + 4},
|
||||||
|
0,
|
||||||
|
{{" + ", 0},
|
||||||
|
{" - ", 1}}};
|
||||||
|
|
||||||
|
OptionsField frequency_tx_correction_mode{
|
||||||
|
{18, 9 * 16 + 4},
|
||||||
|
0,
|
||||||
|
{{" + ", 0},
|
||||||
|
{" - ", 1}}};
|
||||||
|
|
||||||
|
Button button_freq_rx_correction{
|
||||||
|
{18 + 4 * 8, 5 * 16, 20 * 8, 24},
|
||||||
|
"",
|
||||||
|
};
|
||||||
|
Button button_freq_tx_correction{
|
||||||
|
{18 + 4 * 8, 9 * 16, 20 * 8, 24},
|
||||||
|
"",
|
||||||
|
};
|
||||||
|
|
||||||
|
Button button_return{
|
||||||
|
{16 * 8, 16 * 16, 12 * 8, 32},
|
||||||
|
"Return",
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -161,7 +161,7 @@ void set_direction(const rf::Direction new_direction) {
|
|||||||
|
|
||||||
bool set_tuning_frequency(const rf::Frequency frequency) {
|
bool set_tuning_frequency(const rf::Frequency frequency) {
|
||||||
rf::Frequency final_frequency = frequency;
|
rf::Frequency final_frequency = frequency;
|
||||||
// if feature is enabled
|
// if converter feature is enabled
|
||||||
if (portapack::persistent_memory::config_converter()) {
|
if (portapack::persistent_memory::config_converter()) {
|
||||||
// downconvert
|
// downconvert
|
||||||
if (portapack::persistent_memory::config_updown_converter()) {
|
if (portapack::persistent_memory::config_updown_converter()) {
|
||||||
@ -171,6 +171,19 @@ bool set_tuning_frequency(const rf::Frequency frequency) {
|
|||||||
final_frequency = frequency + portapack::persistent_memory::config_converter_freq();
|
final_frequency = frequency + portapack::persistent_memory::config_converter_freq();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// apply frequency correction
|
||||||
|
if (direction == rf::Direction::Transmit) {
|
||||||
|
if (portapack::persistent_memory::config_freq_tx_correction_updown()) // tx freq correction down
|
||||||
|
final_frequency = final_frequency - portapack::persistent_memory::config_freq_tx_correction();
|
||||||
|
else // tx freq correction up
|
||||||
|
final_frequency = final_frequency + portapack::persistent_memory::config_freq_tx_correction();
|
||||||
|
} else {
|
||||||
|
if (portapack::persistent_memory::config_freq_rx_correction_updown()) // rx freq correction down
|
||||||
|
final_frequency = final_frequency - portapack::persistent_memory::config_freq_rx_correction();
|
||||||
|
else // rx freq correction up
|
||||||
|
final_frequency = final_frequency + portapack::persistent_memory::config_freq_rx_correction();
|
||||||
|
}
|
||||||
|
|
||||||
const auto tuning_config = tuning::config::create(final_frequency);
|
const auto tuning_config = tuning::config::create(final_frequency);
|
||||||
if (tuning_config.is_valid()) {
|
if (tuning_config.is_valid()) {
|
||||||
first_if.disable();
|
first_if.disable();
|
||||||
|
@ -206,7 +206,7 @@ int32_t ReceiverModel::tuning_offset() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void ReceiverModel::update_tuning_frequency() {
|
void ReceiverModel::update_tuning_frequency() {
|
||||||
radio::set_tuning_frequency(persistent_memory::tuned_frequency() + tuning_offset());
|
radio::set_tuning_frequency(persistent_memory::tuned_frequency());
|
||||||
}
|
}
|
||||||
|
|
||||||
void ReceiverModel::update_antenna_bias() {
|
void ReceiverModel::update_antenna_bias() {
|
||||||
|
@ -296,6 +296,12 @@ struct data_t {
|
|||||||
// up/down converter offset
|
// up/down converter offset
|
||||||
int64_t converter_frequency_offset;
|
int64_t converter_frequency_offset;
|
||||||
|
|
||||||
|
// frequency correction
|
||||||
|
int16_t frequency_rx_correction;
|
||||||
|
bool updown_frequency_rx_correction;
|
||||||
|
int16_t frequency_tx_correction;
|
||||||
|
bool updown_frequency_tx_correction;
|
||||||
|
|
||||||
constexpr data_t()
|
constexpr data_t()
|
||||||
: structure_version(data_structure_version_enum::VERSION_CURRENT),
|
: structure_version(data_structure_version_enum::VERSION_CURRENT),
|
||||||
tuned_frequency(tuned_frequency_reset_value),
|
tuned_frequency(tuned_frequency_reset_value),
|
||||||
@ -327,7 +333,11 @@ struct data_t {
|
|||||||
hide_converter(0),
|
hide_converter(0),
|
||||||
converter(0),
|
converter(0),
|
||||||
updown_converter(0),
|
updown_converter(0),
|
||||||
converter_frequency_offset(0) {
|
converter_frequency_offset(0),
|
||||||
|
frequency_rx_correction(0),
|
||||||
|
updown_frequency_rx_correction(0),
|
||||||
|
frequency_tx_correction(0),
|
||||||
|
updown_frequency_tx_correction(0) {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -755,22 +765,49 @@ bool config_updown_converter() {
|
|||||||
int64_t config_converter_freq() {
|
int64_t config_converter_freq() {
|
||||||
return data->converter_frequency_offset;
|
return data->converter_frequency_offset;
|
||||||
}
|
}
|
||||||
void set_config_hide_converter(const bool v) {
|
|
||||||
|
void set_config_hide_converter(bool v) {
|
||||||
data->hide_converter = v;
|
data->hide_converter = v;
|
||||||
if (v) {
|
if (v) {
|
||||||
data->converter = false;
|
data->converter = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
void set_config_converter(const bool v) {
|
void set_config_converter(bool v) {
|
||||||
data->converter = v;
|
data->converter = v;
|
||||||
}
|
}
|
||||||
void set_config_updown_converter(const bool v) {
|
void set_config_updown_converter(bool v) {
|
||||||
data->updown_converter = v;
|
data->updown_converter = v;
|
||||||
}
|
}
|
||||||
void set_config_converter_freq(const int64_t v) {
|
void set_config_converter_freq(int64_t v) {
|
||||||
data->converter_frequency_offset = v;
|
data->converter_frequency_offset = v;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// frequency correction settings
|
||||||
|
bool config_freq_tx_correction_updown() {
|
||||||
|
return data->updown_frequency_tx_correction;
|
||||||
|
}
|
||||||
|
void set_freq_tx_correction_updown(bool v) {
|
||||||
|
data->updown_frequency_tx_correction = v;
|
||||||
|
}
|
||||||
|
bool config_freq_rx_correction_updown() {
|
||||||
|
return data->updown_frequency_rx_correction;
|
||||||
|
}
|
||||||
|
void set_freq_rx_correction_updown(bool v) {
|
||||||
|
data->updown_frequency_rx_correction = v;
|
||||||
|
}
|
||||||
|
int16_t config_freq_tx_correction() {
|
||||||
|
return data->frequency_tx_correction;
|
||||||
|
}
|
||||||
|
int16_t config_freq_rx_correction() {
|
||||||
|
return data->frequency_rx_correction;
|
||||||
|
}
|
||||||
|
void set_config_freq_tx_correction(uint16_t v) {
|
||||||
|
data->frequency_tx_correction = v;
|
||||||
|
}
|
||||||
|
void set_config_freq_rx_correction(uint16_t v) {
|
||||||
|
data->frequency_rx_correction = v;
|
||||||
|
}
|
||||||
|
|
||||||
// sd persisting settings
|
// sd persisting settings
|
||||||
int save_persistent_settings_to_file(std::string filename) {
|
int save_persistent_settings_to_file(std::string filename) {
|
||||||
delete_file(filename);
|
delete_file(filename);
|
||||||
|
@ -177,10 +177,22 @@ void set_load_app_settings(bool v);
|
|||||||
void set_save_app_settings(bool v);
|
void set_save_app_settings(bool v);
|
||||||
void set_show_bigger_qr_code(bool v);
|
void set_show_bigger_qr_code(bool v);
|
||||||
void set_config_splash(bool v);
|
void set_config_splash(bool v);
|
||||||
|
bool config_hide_converter();
|
||||||
|
bool config_converter();
|
||||||
|
bool config_updown_converter();
|
||||||
|
int64_t config_converter_freq();
|
||||||
void set_config_hide_converter(bool v);
|
void set_config_hide_converter(bool v);
|
||||||
void set_config_converter(bool v);
|
void set_config_converter(bool v);
|
||||||
void set_config_updown_converter(const bool v);
|
void set_config_updown_converter(bool v);
|
||||||
void set_config_converter_freq(const int64_t v);
|
void set_config_converter_freq(int64_t v);
|
||||||
|
bool config_freq_tx_correction_updown();
|
||||||
|
void set_freq_tx_correction_updown(bool v);
|
||||||
|
bool config_freq_rx_correction_updown();
|
||||||
|
void set_freq_rx_correction_updown(bool v);
|
||||||
|
int16_t config_freq_tx_correction();
|
||||||
|
int16_t config_freq_rx_correction();
|
||||||
|
void set_config_freq_tx_correction(uint16_t v);
|
||||||
|
void set_config_freq_rx_correction(uint16_t v);
|
||||||
void set_clock_hidden(bool v);
|
void set_clock_hidden(bool v);
|
||||||
void set_clock_with_date(bool v);
|
void set_clock_with_date(bool v);
|
||||||
void set_config_login(bool v);
|
void set_config_login(bool v);
|
||||||
|
Loading…
Reference in New Issue
Block a user