mirror of
https://github.com/eried/portapack-mayhem.git
synced 2024-12-25 07:19:28 -05:00
Consolidate frequency field on_edit (#1166)
This commit is contained in:
parent
7b669d7001
commit
5daa0dfbb1
@ -55,7 +55,8 @@ void ACARSLogger::log_raw_data(const acars::Packet& packet, const uint32_t frequ
|
|||||||
|
|
||||||
namespace ui {
|
namespace ui {
|
||||||
|
|
||||||
ACARSAppView::ACARSAppView(NavigationView& nav) {
|
ACARSAppView::ACARSAppView(NavigationView& nav)
|
||||||
|
: nav_{nav} {
|
||||||
baseband::run_image(portapack::spi_flash::image_tag_acars);
|
baseband::run_image(portapack::spi_flash::image_tag_acars);
|
||||||
|
|
||||||
add_children({&rssi,
|
add_children({&rssi,
|
||||||
@ -69,19 +70,6 @@ ACARSAppView::ACARSAppView(NavigationView& nav) {
|
|||||||
|
|
||||||
receiver_model.enable();
|
receiver_model.enable();
|
||||||
|
|
||||||
field_frequency.set_value(receiver_model.target_frequency());
|
|
||||||
field_frequency.set_step(receiver_model.frequency_step());
|
|
||||||
field_frequency.on_change = [this](rf::Frequency f) {
|
|
||||||
receiver_model.set_target_frequency(f);
|
|
||||||
};
|
|
||||||
field_frequency.on_edit = [this, &nav]() {
|
|
||||||
// TODO: Provide separate modal method/scheme?
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(receiver_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
field_frequency.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
check_log.set_value(logging);
|
check_log.set_value(logging);
|
||||||
check_log.on_select = [this](Checkbox&, bool v) {
|
check_log.on_select = [this](Checkbox&, bool v) {
|
||||||
logging = v;
|
logging = v;
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
#include "radio_state.hpp"
|
#include "radio_state.hpp"
|
||||||
#include "ui_widget.hpp"
|
#include "ui_widget.hpp"
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
|
#include "ui_freq_field.hpp"
|
||||||
#include "ui_rssi.hpp"
|
#include "ui_rssi.hpp"
|
||||||
#include "log_file.hpp"
|
#include "log_file.hpp"
|
||||||
|
|
||||||
@ -57,6 +58,7 @@ class ACARSAppView : public View {
|
|||||||
std::string title() const override { return "ACARS (WIP)"; };
|
std::string title() const override { return "ACARS (WIP)"; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
NavigationView& nav_;
|
||||||
RxRadioState radio_state_{
|
RxRadioState radio_state_{
|
||||||
1750000 /* bandwidth */,
|
1750000 /* bandwidth */,
|
||||||
2457600 /* sampling rate */
|
2457600 /* sampling rate */
|
||||||
@ -74,15 +76,13 @@ class ACARSAppView : public View {
|
|||||||
VGAGainField field_vga{
|
VGAGainField field_vga{
|
||||||
{18 * 8, 0 * 16}};
|
{18 * 8, 0 * 16}};
|
||||||
RSSI rssi{
|
RSSI rssi{
|
||||||
{21 * 8, 0, 6 * 8, 4},
|
{21 * 8, 0, 6 * 8, 4}};
|
||||||
};
|
|
||||||
Channel channel{
|
Channel channel{
|
||||||
{21 * 8, 5, 6 * 8, 4},
|
{21 * 8, 5, 6 * 8, 4}};
|
||||||
};
|
|
||||||
|
|
||||||
FrequencyField field_frequency{
|
RxFrequencyField field_frequency{
|
||||||
{0 * 8, 0 * 8},
|
{0 * 8, 0 * 8},
|
||||||
};
|
nav_};
|
||||||
Checkbox check_log{
|
Checkbox check_log{
|
||||||
{22 * 8, 21},
|
{22 * 8, 21},
|
||||||
3,
|
3,
|
||||||
|
@ -152,19 +152,6 @@ AnalogAudioView::AnalogAudioView(
|
|||||||
// Filename Datetime and Frequency
|
// Filename Datetime and Frequency
|
||||||
record_view.set_filename_date_frequency(true);
|
record_view.set_filename_date_frequency(true);
|
||||||
|
|
||||||
field_frequency.set_value(receiver_model.target_frequency());
|
|
||||||
field_frequency.on_change = [this](rf::Frequency f) {
|
|
||||||
receiver_model.set_target_frequency(f);
|
|
||||||
};
|
|
||||||
field_frequency.set_step(receiver_model.frequency_step());
|
|
||||||
field_frequency.on_edit = [this, &nav]() {
|
|
||||||
// TODO: Provide separate modal method/scheme?
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(receiver_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
field_frequency.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
field_frequency.on_show_options = [this]() {
|
field_frequency.on_show_options = [this]() {
|
||||||
this->on_show_options_frequency();
|
this->on_show_options_frequency();
|
||||||
};
|
};
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
#include "receiver_model.hpp"
|
#include "receiver_model.hpp"
|
||||||
|
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
|
#include "ui_freq_field.hpp"
|
||||||
#include "ui_spectrum.hpp"
|
#include "ui_spectrum.hpp"
|
||||||
#include "ui_record_view.hpp"
|
#include "ui_record_view.hpp"
|
||||||
#include "ui_styles.hpp"
|
#include "ui_styles.hpp"
|
||||||
@ -156,6 +157,7 @@ class AnalogAudioView : public View {
|
|||||||
private:
|
private:
|
||||||
static constexpr ui::Dim header_height = 3 * 16;
|
static constexpr ui::Dim header_height = 3 * 16;
|
||||||
|
|
||||||
|
NavigationView& nav_;
|
||||||
RxRadioState radio_state_{};
|
RxRadioState radio_state_{};
|
||||||
app_settings::SettingsManager settings_{
|
app_settings::SettingsManager settings_{
|
||||||
"rx_audio", app_settings::Mode::RX,
|
"rx_audio", app_settings::Mode::RX,
|
||||||
@ -168,24 +170,20 @@ class AnalogAudioView : public View {
|
|||||||
uint32_t spec_bw = 20000000;
|
uint32_t spec_bw = 20000000;
|
||||||
uint16_t spec_trigger = 63;
|
uint16_t spec_trigger = 63;
|
||||||
|
|
||||||
NavigationView& nav_;
|
|
||||||
// bool exit_on_squelch { false };
|
// bool exit_on_squelch { false };
|
||||||
|
|
||||||
RSSI rssi{
|
RSSI rssi{
|
||||||
{21 * 8, 0, 6 * 8, 4},
|
{21 * 8, 0, 6 * 8, 4}};
|
||||||
};
|
|
||||||
|
|
||||||
Channel channel{
|
Channel channel{
|
||||||
{21 * 8, 5, 6 * 8, 4},
|
{21 * 8, 5, 6 * 8, 4}};
|
||||||
};
|
|
||||||
|
|
||||||
Audio audio{
|
Audio audio{
|
||||||
{21 * 8, 10, 6 * 8, 4},
|
{21 * 8, 10, 6 * 8, 4}};
|
||||||
};
|
|
||||||
|
|
||||||
FrequencyField field_frequency{
|
RxFrequencyField field_frequency{
|
||||||
{5 * 8, 0 * 16},
|
{5 * 8, 0 * 16},
|
||||||
};
|
nav_};
|
||||||
|
|
||||||
LNAGainField field_lna{
|
LNAGainField field_lna{
|
||||||
{15 * 8, 0 * 16}};
|
{15 * 8, 0 * 16}};
|
||||||
@ -229,7 +227,6 @@ class AnalogAudioView : public View {
|
|||||||
void on_show_options_modulation();
|
void on_show_options_modulation();
|
||||||
void on_frequency_step_changed(rf::Frequency f);
|
void on_frequency_step_changed(rf::Frequency f);
|
||||||
void on_reference_ppm_correction_changed(int32_t v);
|
void on_reference_ppm_correction_changed(int32_t v);
|
||||||
void on_edit_frequency();
|
|
||||||
|
|
||||||
void remove_options_widget();
|
void remove_options_widget();
|
||||||
void set_options_widget(std::unique_ptr<Widget> new_widget);
|
void set_options_widget(std::unique_ptr<Widget> new_widget);
|
||||||
|
@ -56,22 +56,6 @@ AnalogTvView::AnalogTvView(
|
|||||||
&field_volume,
|
&field_volume,
|
||||||
&tv});
|
&tv});
|
||||||
|
|
||||||
// Set on_change before initialising the field
|
|
||||||
field_frequency.on_change = [this](rf::Frequency f) {
|
|
||||||
this->on_target_frequency_changed(f);
|
|
||||||
};
|
|
||||||
|
|
||||||
field_frequency.set_value(receiver_model.target_frequency());
|
|
||||||
field_frequency.set_step(receiver_model.frequency_step());
|
|
||||||
field_frequency.on_edit = [this, &nav]() {
|
|
||||||
// TODO: Provide separate modal method/scheme?
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(receiver_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
this->on_target_frequency_changed(f);
|
|
||||||
this->field_frequency.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
field_frequency.on_show_options = [this]() {
|
field_frequency.on_show_options = [this]() {
|
||||||
this->on_show_options_frequency();
|
this->on_show_options_frequency();
|
||||||
};
|
};
|
||||||
@ -125,10 +109,6 @@ void AnalogTvView::focus() {
|
|||||||
field_frequency.focus();
|
field_frequency.focus();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AnalogTvView::on_target_frequency_changed(rf::Frequency f) {
|
|
||||||
receiver_model.set_target_frequency(f);
|
|
||||||
}
|
|
||||||
|
|
||||||
void AnalogTvView::on_baseband_bandwidth_changed(uint32_t bandwidth_hz) {
|
void AnalogTvView::on_baseband_bandwidth_changed(uint32_t bandwidth_hz) {
|
||||||
receiver_model.set_baseband_bandwidth(bandwidth_hz);
|
receiver_model.set_baseband_bandwidth(bandwidth_hz);
|
||||||
}
|
}
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
#include "receiver_model.hpp"
|
#include "receiver_model.hpp"
|
||||||
|
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
|
#include "ui_freq_field.hpp"
|
||||||
#include "ui_tv.hpp"
|
#include "ui_tv.hpp"
|
||||||
#include "ui_record_view.hpp"
|
#include "ui_record_view.hpp"
|
||||||
#include "ui_styles.hpp"
|
#include "ui_styles.hpp"
|
||||||
@ -53,6 +54,7 @@ class AnalogTvView : public View {
|
|||||||
private:
|
private:
|
||||||
static constexpr ui::Dim header_height = 3 * 16;
|
static constexpr ui::Dim header_height = 3 * 16;
|
||||||
|
|
||||||
|
NavigationView& nav_;
|
||||||
RxRadioState radio_state_{};
|
RxRadioState radio_state_{};
|
||||||
app_settings::SettingsManager settings_{
|
app_settings::SettingsManager settings_{
|
||||||
"rx_tv", app_settings::Mode::RX};
|
"rx_tv", app_settings::Mode::RX};
|
||||||
@ -60,23 +62,18 @@ class AnalogTvView : public View {
|
|||||||
const Rect options_view_rect{0 * 8, 1 * 16, 30 * 8, 1 * 16};
|
const Rect options_view_rect{0 * 8, 1 * 16, 30 * 8, 1 * 16};
|
||||||
const Rect nbfm_view_rect{0 * 8, 1 * 16, 18 * 8, 1 * 16};
|
const Rect nbfm_view_rect{0 * 8, 1 * 16, 18 * 8, 1 * 16};
|
||||||
|
|
||||||
NavigationView& nav_;
|
|
||||||
|
|
||||||
RSSI rssi{
|
RSSI rssi{
|
||||||
{21 * 8, 0, 6 * 8, 4},
|
{21 * 8, 0, 6 * 8, 4}};
|
||||||
};
|
|
||||||
|
|
||||||
Channel channel{
|
Channel channel{
|
||||||
{21 * 8, 5, 6 * 8, 4},
|
{21 * 8, 5, 6 * 8, 4}};
|
||||||
};
|
|
||||||
|
|
||||||
Audio audio{
|
Audio audio{
|
||||||
{21 * 8, 10, 6 * 8, 4},
|
{21 * 8, 10, 6 * 8, 4}};
|
||||||
};
|
|
||||||
|
|
||||||
FrequencyField field_frequency{
|
RxFrequencyField field_frequency{
|
||||||
{5 * 8, 0 * 16},
|
{5 * 8, 0 * 16},
|
||||||
};
|
nav_};
|
||||||
|
|
||||||
LNAGainField field_lna{
|
LNAGainField field_lna{
|
||||||
{15 * 8, 0 * 16}};
|
{15 * 8, 0 * 16}};
|
||||||
@ -100,7 +97,6 @@ class AnalogTvView : public View {
|
|||||||
|
|
||||||
tv::TVWidget tv{};
|
tv::TVWidget tv{};
|
||||||
|
|
||||||
void on_target_frequency_changed(rf::Frequency f);
|
|
||||||
void on_baseband_bandwidth_changed(uint32_t bandwidth_hz);
|
void on_baseband_bandwidth_changed(uint32_t bandwidth_hz);
|
||||||
void on_modulation_changed(const ReceiverModel::Mode modulation);
|
void on_modulation_changed(const ReceiverModel::Mode modulation);
|
||||||
void on_show_options_frequency();
|
void on_show_options_frequency();
|
||||||
@ -108,7 +104,6 @@ class AnalogTvView : public View {
|
|||||||
void on_show_options_modulation();
|
void on_show_options_modulation();
|
||||||
void on_frequency_step_changed(rf::Frequency f);
|
void on_frequency_step_changed(rf::Frequency f);
|
||||||
void on_reference_ppm_correction_changed(int32_t v);
|
void on_reference_ppm_correction_changed(int32_t v);
|
||||||
void on_edit_frequency();
|
|
||||||
|
|
||||||
void remove_options_widget();
|
void remove_options_widget();
|
||||||
void set_options_widget(std::unique_ptr<Widget> new_widget);
|
void set_options_widget(std::unique_ptr<Widget> new_widget);
|
||||||
|
@ -28,7 +28,8 @@ using namespace portapack;
|
|||||||
|
|
||||||
namespace ui {
|
namespace ui {
|
||||||
|
|
||||||
CaptureAppView::CaptureAppView(NavigationView& nav) {
|
CaptureAppView::CaptureAppView(NavigationView& nav)
|
||||||
|
: nav_{nav} {
|
||||||
baseband::run_image(portapack::spi_flash::image_tag_capture);
|
baseband::run_image(portapack::spi_flash::image_tag_capture);
|
||||||
|
|
||||||
add_children({
|
add_children({
|
||||||
@ -45,19 +46,6 @@ CaptureAppView::CaptureAppView(NavigationView& nav) {
|
|||||||
&waterfall,
|
&waterfall,
|
||||||
});
|
});
|
||||||
|
|
||||||
field_frequency.set_value(receiver_model.target_frequency());
|
|
||||||
field_frequency.set_step(receiver_model.frequency_step());
|
|
||||||
field_frequency.on_change = [this](rf::Frequency f) {
|
|
||||||
receiver_model.set_target_frequency(f);
|
|
||||||
};
|
|
||||||
field_frequency.on_edit = [this, &nav]() {
|
|
||||||
// TODO: Provide separate modal method/scheme?
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(receiver_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
this->field_frequency.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
field_frequency_step.set_by_value(receiver_model.frequency_step());
|
field_frequency_step.set_by_value(receiver_model.frequency_step());
|
||||||
field_frequency_step.on_change = [this](size_t, OptionsField::value_t v) {
|
field_frequency_step.on_change = [this](size_t, OptionsField::value_t v) {
|
||||||
receiver_model.set_frequency_step(v);
|
receiver_model.set_frequency_step(v);
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
#include "ui_widget.hpp"
|
#include "ui_widget.hpp"
|
||||||
#include "ui_navigation.hpp"
|
#include "ui_navigation.hpp"
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
|
#include "ui_freq_field.hpp"
|
||||||
#include "ui_record_view.hpp"
|
#include "ui_record_view.hpp"
|
||||||
#include "ui_spectrum.hpp"
|
#include "ui_spectrum.hpp"
|
||||||
#include "app_settings.hpp"
|
#include "app_settings.hpp"
|
||||||
@ -64,6 +65,7 @@ class CaptureAppView : public View {
|
|||||||
private:
|
private:
|
||||||
static constexpr ui::Dim header_height = 3 * 16;
|
static constexpr ui::Dim header_height = 3 * 16;
|
||||||
|
|
||||||
|
NavigationView& nav_;
|
||||||
RxRadioState radio_state_{};
|
RxRadioState radio_state_{};
|
||||||
app_settings::SettingsManager settings_{
|
app_settings::SettingsManager settings_{
|
||||||
"rx_capture", app_settings::Mode::RX,
|
"rx_capture", app_settings::Mode::RX,
|
||||||
@ -72,27 +74,22 @@ class CaptureAppView : public View {
|
|||||||
uint32_t sampling_rate = 0;
|
uint32_t sampling_rate = 0;
|
||||||
uint32_t anti_alias_baseband_bandwidth_filter = 2500000;
|
uint32_t anti_alias_baseband_bandwidth_filter = 2500000;
|
||||||
|
|
||||||
void on_target_frequency_changed(rf::Frequency f);
|
|
||||||
|
|
||||||
Labels labels{
|
Labels labels{
|
||||||
{{0 * 8, 1 * 16}, "Rate:", Color::light_grey()},
|
{{0 * 8, 1 * 16}, "Rate:", Color::light_grey()},
|
||||||
};
|
};
|
||||||
|
|
||||||
RSSI rssi{
|
RSSI rssi{
|
||||||
{24 * 8, 0, 6 * 8, 4},
|
{24 * 8, 0, 6 * 8, 4}};
|
||||||
};
|
|
||||||
|
|
||||||
Channel channel{
|
Channel channel{
|
||||||
{24 * 8, 5, 6 * 8, 4},
|
{24 * 8, 5, 6 * 8, 4}};
|
||||||
};
|
|
||||||
|
|
||||||
FrequencyField field_frequency{
|
RxFrequencyField field_frequency{
|
||||||
{0 * 8, 0 * 16},
|
{0 * 8, 0 * 16},
|
||||||
};
|
nav_};
|
||||||
|
|
||||||
FrequencyStepView field_frequency_step{
|
FrequencyStepView field_frequency_step{
|
||||||
{10 * 8, 0 * 16},
|
{10 * 8, 0 * 16}};
|
||||||
};
|
|
||||||
|
|
||||||
RFAmpField field_rf_amp{
|
RFAmpField field_rf_amp{
|
||||||
{16 * 8, 0 * 16}};
|
{16 * 8, 0 * 16}};
|
||||||
|
@ -187,18 +187,7 @@ GpsSimAppView::GpsSimAppView(
|
|||||||
&waterfall,
|
&waterfall,
|
||||||
});
|
});
|
||||||
|
|
||||||
field_frequency.set_value(transmitter_model.target_frequency());
|
|
||||||
field_frequency.set_step(5000);
|
field_frequency.set_step(5000);
|
||||||
field_frequency.on_change = [this](rf::Frequency f) {
|
|
||||||
transmitter_model.set_target_frequency(f);
|
|
||||||
};
|
|
||||||
field_frequency.on_edit = [this, &nav]() {
|
|
||||||
// TODO: Provide separate modal method/scheme?
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(transmitter_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
this->field_frequency.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
button_play.on_select = [this](ImageButton&) {
|
button_play.on_select = [this](ImageButton&) {
|
||||||
this->toggle();
|
this->toggle();
|
||||||
|
@ -32,6 +32,7 @@
|
|||||||
#include "ui_widget.hpp"
|
#include "ui_widget.hpp"
|
||||||
#include "ui_navigation.hpp"
|
#include "ui_navigation.hpp"
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
|
#include "ui_freq_field.hpp"
|
||||||
#include "replay_thread.hpp"
|
#include "replay_thread.hpp"
|
||||||
#include "ui_spectrum.hpp"
|
#include "ui_spectrum.hpp"
|
||||||
#include "ui_transmitter.hpp"
|
#include "ui_transmitter.hpp"
|
||||||
@ -102,9 +103,9 @@ class GpsSimAppView : public View {
|
|||||||
ProgressBar progressbar{
|
ProgressBar progressbar{
|
||||||
{18 * 8, 1 * 16, 12 * 8, 16}};
|
{18 * 8, 1 * 16, 12 * 8, 16}};
|
||||||
|
|
||||||
FrequencyField field_frequency{
|
TxFrequencyField field_frequency{
|
||||||
{0 * 8, 2 * 16},
|
{0 * 8, 2 * 16},
|
||||||
};
|
nav_};
|
||||||
|
|
||||||
TransmitterView2 tx_view{
|
TransmitterView2 tx_view{
|
||||||
// new handling of NumberField field_rfgain, NumberField field_rfamp
|
// new handling of NumberField field_rfgain, NumberField field_rfamp
|
||||||
|
@ -51,9 +51,8 @@ void POCSAGLogger::log_decoded(
|
|||||||
|
|
||||||
namespace ui {
|
namespace ui {
|
||||||
|
|
||||||
POCSAGAppView::POCSAGAppView(NavigationView& nav) {
|
POCSAGAppView::POCSAGAppView(NavigationView& nav)
|
||||||
uint32_t ignore_address;
|
: nav_{nav} {
|
||||||
|
|
||||||
baseband::run_image(portapack::spi_flash::image_tag_pocsag);
|
baseband::run_image(portapack::spi_flash::image_tag_pocsag);
|
||||||
|
|
||||||
add_children({&rssi,
|
add_children({&rssi,
|
||||||
@ -70,28 +69,16 @@ POCSAGAppView::POCSAGAppView(NavigationView& nav) {
|
|||||||
&console});
|
&console});
|
||||||
|
|
||||||
if (!settings_.loaded())
|
if (!settings_.loaded())
|
||||||
receiver_model.set_target_frequency(initial_target_frequency);
|
field_frequency.set_value(initial_target_frequency);
|
||||||
|
|
||||||
receiver_model.set_modulation(ReceiverModel::Mode::NarrowbandFMAudio);
|
receiver_model.set_modulation(ReceiverModel::Mode::NarrowbandFMAudio);
|
||||||
receiver_model.enable();
|
receiver_model.enable();
|
||||||
|
|
||||||
field_frequency.set_value(receiver_model.target_frequency());
|
// TODO: app setting instead?
|
||||||
field_frequency.on_change = [this](rf::Frequency f) {
|
uint32_t ignore_address;
|
||||||
receiver_model.set_target_frequency(f);
|
|
||||||
};
|
|
||||||
field_frequency.set_step(receiver_model.frequency_step());
|
|
||||||
field_frequency.on_edit = [this, &nav]() {
|
|
||||||
// TODO: Provide separate modal method/scheme?
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(receiver_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
field_frequency.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
// TODO app setting instead?
|
|
||||||
ignore_address = persistent_memory::pocsag_ignore_address();
|
ignore_address = persistent_memory::pocsag_ignore_address();
|
||||||
|
|
||||||
// TODO is this common enough for a helper?
|
// TODO: is this common enough for a helper?
|
||||||
for (size_t c = 0; c < 7; c++) {
|
for (size_t c = 0; c < 7; c++) {
|
||||||
sym_ignore.set_sym(6 - c, ignore_address % 10);
|
sym_ignore.set_sym(6 - c, ignore_address % 10);
|
||||||
ignore_address /= 10;
|
ignore_address /= 10;
|
||||||
@ -156,7 +143,8 @@ void POCSAGAppView::on_packet(const POCSAGPacketMessage* message) {
|
|||||||
console.write(console_info);
|
console.write(console_info);
|
||||||
|
|
||||||
if (logger && logging()) {
|
if (logger && logging()) {
|
||||||
logger->log_decoded(message->packet, to_string_dec_uint(pocsag_state.address) +
|
logger->log_decoded(
|
||||||
|
message->packet, to_string_dec_uint(pocsag_state.address) +
|
||||||
" F" + to_string_dec_uint(pocsag_state.function) +
|
" F" + to_string_dec_uint(pocsag_state.function) +
|
||||||
" Address only");
|
" Address only");
|
||||||
}
|
}
|
||||||
@ -175,7 +163,8 @@ void POCSAGAppView::on_packet(const POCSAGPacketMessage* message) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (logger && logging())
|
if (logger && logging())
|
||||||
logger->log_decoded(message->packet, to_string_dec_uint(pocsag_state.address) +
|
logger->log_decoded(
|
||||||
|
message->packet, to_string_dec_uint(pocsag_state.address) +
|
||||||
" F" + to_string_dec_uint(pocsag_state.function) +
|
" F" + to_string_dec_uint(pocsag_state.function) +
|
||||||
" Alpha: " + pocsag_state.output);
|
" Alpha: " + pocsag_state.output);
|
||||||
}
|
}
|
||||||
@ -183,8 +172,8 @@ void POCSAGAppView::on_packet(const POCSAGPacketMessage* message) {
|
|||||||
|
|
||||||
// TODO: make setting.
|
// TODO: make setting.
|
||||||
// Log raw data whatever it contains
|
// Log raw data whatever it contains
|
||||||
if (logger && logging())
|
/*if (logger && logging())
|
||||||
logger->log_raw_data(message->packet, receiver_model.target_frequency());
|
logger->log_raw_data(message->packet, receiver_model.target_frequency());*/
|
||||||
}
|
}
|
||||||
|
|
||||||
} /* namespace ui */
|
} /* namespace ui */
|
||||||
|
@ -24,6 +24,7 @@
|
|||||||
#define __POCSAG_APP_H__
|
#define __POCSAG_APP_H__
|
||||||
|
|
||||||
#include "ui_widget.hpp"
|
#include "ui_widget.hpp"
|
||||||
|
#include "ui_freq_field.hpp"
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
#include "ui_rssi.hpp"
|
#include "ui_rssi.hpp"
|
||||||
|
|
||||||
@ -61,6 +62,7 @@ class POCSAGAppView : public View {
|
|||||||
bool logging() const { return check_log.value(); };
|
bool logging() const { return check_log.value(); };
|
||||||
bool ignore() const { return check_ignore.value(); };
|
bool ignore() const { return check_ignore.value(); };
|
||||||
|
|
||||||
|
NavigationView& nav_;
|
||||||
RxRadioState radio_state_{};
|
RxRadioState radio_state_{};
|
||||||
app_settings::SettingsManager settings_{
|
app_settings::SettingsManager settings_{
|
||||||
"rx_pocsag", app_settings::Mode::RX};
|
"rx_pocsag", app_settings::Mode::RX};
|
||||||
@ -75,18 +77,15 @@ class POCSAGAppView : public View {
|
|||||||
VGAGainField field_vga{
|
VGAGainField field_vga{
|
||||||
{18 * 8, 0 * 16}};
|
{18 * 8, 0 * 16}};
|
||||||
RSSI rssi{
|
RSSI rssi{
|
||||||
{21 * 8, 0, 6 * 8, 4},
|
{21 * 8, 0, 6 * 8, 4}};
|
||||||
};
|
|
||||||
Channel channel{
|
Channel channel{
|
||||||
{21 * 8, 5, 6 * 8, 4},
|
{21 * 8, 5, 6 * 8, 4}};
|
||||||
};
|
|
||||||
Audio audio{
|
Audio audio{
|
||||||
{21 * 8, 10, 6 * 8, 4},
|
{21 * 8, 10, 6 * 8, 4}};
|
||||||
};
|
|
||||||
|
|
||||||
FrequencyField field_frequency{
|
RxFrequencyField field_frequency{
|
||||||
{0 * 8, 0 * 8},
|
{0 * 8, 0 * 8},
|
||||||
};
|
nav_};
|
||||||
|
|
||||||
AudioVolumeField field_volume{
|
AudioVolumeField field_volume{
|
||||||
{28 * 8, 0 * 16}};
|
{28 * 8, 0 * 16}};
|
||||||
|
@ -188,27 +188,12 @@ ReplayAppView::ReplayAppView(
|
|||||||
&text_duration,
|
&text_duration,
|
||||||
&progressbar,
|
&progressbar,
|
||||||
&field_frequency,
|
&field_frequency,
|
||||||
&tx_view, // now it handles previous rfgain , rfamp.
|
&tx_view, // now it handles previous rfgain, rfamp.
|
||||||
&check_loop,
|
&check_loop,
|
||||||
&button_play,
|
&button_play,
|
||||||
&waterfall,
|
&waterfall,
|
||||||
});
|
});
|
||||||
|
|
||||||
field_frequency.set_value(transmitter_model.target_frequency());
|
|
||||||
field_frequency.set_step(receiver_model.frequency_step());
|
|
||||||
field_frequency.on_change = [this](rf::Frequency f) {
|
|
||||||
transmitter_model.set_target_frequency(f);
|
|
||||||
};
|
|
||||||
field_frequency.on_edit = [this, &nav]() {
|
|
||||||
// TODO: Provide separate modal method/scheme?
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(transmitter_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
field_frequency.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
field_frequency.set_step(5000);
|
|
||||||
|
|
||||||
button_play.on_select = [this](ImageButton&) {
|
button_play.on_select = [this](ImageButton&) {
|
||||||
this->toggle();
|
this->toggle();
|
||||||
};
|
};
|
||||||
|
@ -31,6 +31,7 @@
|
|||||||
#include "ui_widget.hpp"
|
#include "ui_widget.hpp"
|
||||||
#include "ui_navigation.hpp"
|
#include "ui_navigation.hpp"
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
|
#include "ui_freq_field.hpp"
|
||||||
#include "replay_thread.hpp"
|
#include "replay_thread.hpp"
|
||||||
#include "ui_spectrum.hpp"
|
#include "ui_spectrum.hpp"
|
||||||
#include "ui_transmitter.hpp"
|
#include "ui_transmitter.hpp"
|
||||||
@ -98,9 +99,10 @@ class ReplayAppView : public View {
|
|||||||
ProgressBar progressbar{
|
ProgressBar progressbar{
|
||||||
{18 * 8, 1 * 16, 12 * 8, 16}};
|
{18 * 8, 1 * 16, 12 * 8, 16}};
|
||||||
|
|
||||||
FrequencyField field_frequency{
|
// TODO: Does this need to be a frequency field at all?
|
||||||
|
TxFrequencyField field_frequency{
|
||||||
{0 * 8, 2 * 16},
|
{0 * 8, 2 * 16},
|
||||||
};
|
nav_};
|
||||||
|
|
||||||
TransmitterView2 tx_view{
|
TransmitterView2 tx_view{
|
||||||
// new handling of NumberField field_rfgain, NumberField field_rfamp
|
// new handling of NumberField field_rfgain, NumberField field_rfamp
|
||||||
|
@ -43,11 +43,8 @@ void AFSKRxView::focus() {
|
|||||||
field_frequency.focus();
|
field_frequency.focus();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AFSKRxView::update_freq(rf::Frequency f) {
|
AFSKRxView::AFSKRxView(NavigationView& nav)
|
||||||
receiver_model.set_target_frequency(f);
|
: nav_{nav} {
|
||||||
}
|
|
||||||
|
|
||||||
AFSKRxView::AFSKRxView(NavigationView& nav) {
|
|
||||||
baseband::run_image(portapack::spi_flash::image_tag_afsk_rx);
|
baseband::run_image(portapack::spi_flash::image_tag_afsk_rx);
|
||||||
|
|
||||||
add_children({&rssi,
|
add_children({&rssi,
|
||||||
@ -62,8 +59,8 @@ AFSKRxView::AFSKRxView(NavigationView& nav) {
|
|||||||
&button_modem_setup,
|
&button_modem_setup,
|
||||||
&console});
|
&console});
|
||||||
|
|
||||||
// Auto-configure modem for LCR RX (will be removed later)
|
// Auto-configure modem for LCR RX (TODO remove)
|
||||||
update_freq(467225500); // 462713300
|
field_frequency.set_value(467225500);
|
||||||
auto def_bell202 = &modem_defs[0];
|
auto def_bell202 = &modem_defs[0];
|
||||||
persistent_memory::set_modem_baudrate(def_bell202->baudrate);
|
persistent_memory::set_modem_baudrate(def_bell202->baudrate);
|
||||||
serial_format_t serial_format;
|
serial_format_t serial_format;
|
||||||
@ -73,17 +70,7 @@ AFSKRxView::AFSKRxView(NavigationView& nav) {
|
|||||||
serial_format.bit_order = LSB_FIRST;
|
serial_format.bit_order = LSB_FIRST;
|
||||||
persistent_memory::set_serial_format(serial_format);
|
persistent_memory::set_serial_format(serial_format);
|
||||||
|
|
||||||
field_frequency.set_value(receiver_model.target_frequency());
|
|
||||||
field_frequency.set_step(100);
|
field_frequency.set_step(100);
|
||||||
field_frequency.on_change = [this](rf::Frequency f) {
|
|
||||||
update_freq(f);
|
|
||||||
};
|
|
||||||
field_frequency.on_edit = [this, &nav]() {
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(receiver_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
field_frequency.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
check_log.set_value(logging);
|
check_log.set_value(logging);
|
||||||
check_log.on_select = [this](Checkbox&, bool v) {
|
check_log.on_select = [this](Checkbox&, bool v) {
|
||||||
|
@ -26,7 +26,8 @@
|
|||||||
#include "ui.hpp"
|
#include "ui.hpp"
|
||||||
#include "ui_navigation.hpp"
|
#include "ui_navigation.hpp"
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
#include "ui_record_view.hpp" // DEBUG
|
#include "ui_freq_field.hpp"
|
||||||
|
#include "ui_record_view.hpp"
|
||||||
#include "app_settings.hpp"
|
#include "app_settings.hpp"
|
||||||
#include "radio_state.hpp"
|
#include "radio_state.hpp"
|
||||||
#include "log_file.hpp"
|
#include "log_file.hpp"
|
||||||
@ -58,6 +59,7 @@ class AFSKRxView : public View {
|
|||||||
private:
|
private:
|
||||||
void on_data(uint32_t value, bool is_data);
|
void on_data(uint32_t value, bool is_data);
|
||||||
|
|
||||||
|
NavigationView& nav_;
|
||||||
RxRadioState radio_state_{};
|
RxRadioState radio_state_{};
|
||||||
app_settings::SettingsManager settings_{
|
app_settings::SettingsManager settings_{
|
||||||
"rx_afsk", app_settings::Mode::RX};
|
"rx_afsk", app_settings::Mode::RX};
|
||||||
@ -74,18 +76,16 @@ class AFSKRxView : public View {
|
|||||||
VGAGainField field_vga{
|
VGAGainField field_vga{
|
||||||
{18 * 8, 0 * 16}};
|
{18 * 8, 0 * 16}};
|
||||||
RSSI rssi{
|
RSSI rssi{
|
||||||
{21 * 8, 0, 6 * 8, 4},
|
{21 * 8, 0, 6 * 8, 4}};
|
||||||
};
|
|
||||||
Channel channel{
|
Channel channel{
|
||||||
{21 * 8, 5, 6 * 8, 4},
|
{21 * 8, 5, 6 * 8, 4}};
|
||||||
};
|
|
||||||
|
|
||||||
AudioVolumeField field_volume{
|
AudioVolumeField field_volume{
|
||||||
{28 * 8, 0 * 16}};
|
{28 * 8, 0 * 16}};
|
||||||
|
|
||||||
FrequencyField field_frequency{
|
RxFrequencyField field_frequency{
|
||||||
{0 * 8, 0 * 16},
|
{0 * 8, 0 * 16},
|
||||||
};
|
nav_};
|
||||||
|
|
||||||
Checkbox check_log{
|
Checkbox check_log{
|
||||||
{0 * 8, 1 * 16},
|
{0 * 8, 1 * 16},
|
||||||
@ -104,7 +104,6 @@ class AFSKRxView : public View {
|
|||||||
Console console{
|
Console console{
|
||||||
{0, 4 * 16, 240, 240}};
|
{0, 4 * 16, 240, 240}};
|
||||||
|
|
||||||
void update_freq(rf::Frequency f);
|
|
||||||
void on_data_afsk(const AFSKDataMessage& message);
|
void on_data_afsk(const AFSKDataMessage& message);
|
||||||
|
|
||||||
std::unique_ptr<AFSKLogger> logger{};
|
std::unique_ptr<AFSKLogger> logger{};
|
||||||
|
@ -73,12 +73,8 @@ void APRSRxView::focus() {
|
|||||||
options_region.focus();
|
options_region.focus();
|
||||||
}
|
}
|
||||||
|
|
||||||
void APRSRxView::update_freq(rf::Frequency f) {
|
|
||||||
receiver_model.set_target_frequency(f);
|
|
||||||
}
|
|
||||||
|
|
||||||
APRSRxView::APRSRxView(NavigationView& nav, Rect parent_rect)
|
APRSRxView::APRSRxView(NavigationView& nav, Rect parent_rect)
|
||||||
: View(parent_rect) {
|
: View(parent_rect), nav_{nav} {
|
||||||
baseband::run_image(portapack::spi_flash::image_tag_aprs_rx);
|
baseband::run_image(portapack::spi_flash::image_tag_aprs_rx);
|
||||||
|
|
||||||
add_children({&rssi,
|
add_children({&rssi,
|
||||||
@ -111,18 +107,7 @@ APRSRxView::APRSRxView(NavigationView& nav, Rect parent_rect)
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
field_frequency.set_value(receiver_model.target_frequency());
|
|
||||||
field_frequency.set_step(100);
|
field_frequency.set_step(100);
|
||||||
field_frequency.on_change = [this](rf::Frequency f) {
|
|
||||||
update_freq(f);
|
|
||||||
};
|
|
||||||
field_frequency.on_edit = [this, &nav]() {
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(receiver_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
field_frequency.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
options_region.set_selected_index(0, true);
|
options_region.set_selected_index(0, true);
|
||||||
|
|
||||||
logger = std::make_unique<APRSLogger>();
|
logger = std::make_unique<APRSLogger>();
|
||||||
|
@ -26,7 +26,8 @@
|
|||||||
#include "ui.hpp"
|
#include "ui.hpp"
|
||||||
#include "ui_navigation.hpp"
|
#include "ui_navigation.hpp"
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
#include "ui_record_view.hpp" // DEBUG
|
#include "ui_freq_field.hpp"
|
||||||
|
#include "ui_record_view.hpp"
|
||||||
#include "ui_geomap.hpp"
|
#include "ui_geomap.hpp"
|
||||||
#include "app_settings.hpp"
|
#include "app_settings.hpp"
|
||||||
#include "radio_state.hpp"
|
#include "radio_state.hpp"
|
||||||
@ -188,6 +189,7 @@ class APRSRxView : public View {
|
|||||||
void on_data(uint32_t value, bool is_data);
|
void on_data(uint32_t value, bool is_data);
|
||||||
bool reset_console = false;
|
bool reset_console = false;
|
||||||
|
|
||||||
|
NavigationView& nav_;
|
||||||
RxRadioState radio_state_{};
|
RxRadioState radio_state_{};
|
||||||
app_settings::SettingsManager settings_{
|
app_settings::SettingsManager settings_{
|
||||||
"rx_aprs", app_settings::Mode::RX};
|
"rx_aprs", app_settings::Mode::RX};
|
||||||
@ -202,11 +204,9 @@ class APRSRxView : public View {
|
|||||||
VGAGainField field_vga{
|
VGAGainField field_vga{
|
||||||
{18 * 8, 0 * 16}};
|
{18 * 8, 0 * 16}};
|
||||||
RSSI rssi{
|
RSSI rssi{
|
||||||
{21 * 8, 0, 6 * 8, 4},
|
{21 * 8, 0, 6 * 8, 4}};
|
||||||
};
|
|
||||||
Channel channel{
|
Channel channel{
|
||||||
{21 * 8, 5, 6 * 8, 4},
|
{21 * 8, 5, 6 * 8, 4}};
|
||||||
};
|
|
||||||
|
|
||||||
AudioVolumeField field_volume{
|
AudioVolumeField field_volume{
|
||||||
{28 * 8, 0 * 16}};
|
{28 * 8, 0 * 16}};
|
||||||
@ -219,9 +219,9 @@ class APRSRxView : public View {
|
|||||||
{"AUS", 2},
|
{"AUS", 2},
|
||||||
{"NZ ", 3}}};
|
{"NZ ", 3}}};
|
||||||
|
|
||||||
FrequencyField field_frequency{
|
RxFrequencyField field_frequency{
|
||||||
{3 * 8, 0 * 16},
|
{3 * 8, 0 * 16},
|
||||||
};
|
nav_};
|
||||||
|
|
||||||
// DEBUG
|
// DEBUG
|
||||||
RecordView record_view{
|
RecordView record_view{
|
||||||
@ -235,8 +235,6 @@ class APRSRxView : public View {
|
|||||||
Console console{
|
Console console{
|
||||||
{0, 2 * 16, 240, 240}};
|
{0, 2 * 16, 240, 240}};
|
||||||
|
|
||||||
void update_freq(rf::Frequency f);
|
|
||||||
|
|
||||||
std::unique_ptr<APRSLogger> logger{};
|
std::unique_ptr<APRSLogger> logger{};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -40,11 +40,8 @@ void BTLERxView::focus() {
|
|||||||
field_frequency.focus();
|
field_frequency.focus();
|
||||||
}
|
}
|
||||||
|
|
||||||
void BTLERxView::update_freq(rf::Frequency f) {
|
BTLERxView::BTLERxView(NavigationView& nav)
|
||||||
receiver_model.set_target_frequency(f);
|
: nav_{nav} {
|
||||||
}
|
|
||||||
|
|
||||||
BTLERxView::BTLERxView(NavigationView& nav) {
|
|
||||||
baseband::run_image(portapack::spi_flash::image_tag_btle_rx);
|
baseband::run_image(portapack::spi_flash::image_tag_btle_rx);
|
||||||
|
|
||||||
add_children({&rssi,
|
add_children({&rssi,
|
||||||
@ -56,8 +53,8 @@ BTLERxView::BTLERxView(NavigationView& nav) {
|
|||||||
&button_modem_setup,
|
&button_modem_setup,
|
||||||
&console});
|
&console});
|
||||||
|
|
||||||
// Auto-configure modem for LCR RX (will be removed later)
|
// Auto-configure modem for LCR RX (TODO: remove later)
|
||||||
update_freq(2426000000);
|
field_frequency.set_value(2426000000);
|
||||||
auto def_bell202 = &modem_defs[0];
|
auto def_bell202 = &modem_defs[0];
|
||||||
persistent_memory::set_modem_baudrate(def_bell202->baudrate);
|
persistent_memory::set_modem_baudrate(def_bell202->baudrate);
|
||||||
serial_format_t serial_format;
|
serial_format_t serial_format;
|
||||||
@ -67,17 +64,7 @@ BTLERxView::BTLERxView(NavigationView& nav) {
|
|||||||
serial_format.bit_order = LSB_FIRST;
|
serial_format.bit_order = LSB_FIRST;
|
||||||
persistent_memory::set_serial_format(serial_format);
|
persistent_memory::set_serial_format(serial_format);
|
||||||
|
|
||||||
field_frequency.set_value(receiver_model.target_frequency());
|
|
||||||
field_frequency.set_step(100);
|
field_frequency.set_step(100);
|
||||||
field_frequency.on_change = [this](rf::Frequency f) {
|
|
||||||
update_freq(f);
|
|
||||||
};
|
|
||||||
field_frequency.on_edit = [this, &nav]() {
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(receiver_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
field_frequency.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
button_modem_setup.on_select = [&nav](Button&) {
|
button_modem_setup.on_select = [&nav](Button&) {
|
||||||
nav.push<ModemSetupView>();
|
nav.push<ModemSetupView>();
|
||||||
|
@ -27,9 +27,10 @@
|
|||||||
#include "ui.hpp"
|
#include "ui.hpp"
|
||||||
#include "ui_navigation.hpp"
|
#include "ui_navigation.hpp"
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
|
#include "ui_freq_field.hpp"
|
||||||
#include "app_settings.hpp"
|
#include "app_settings.hpp"
|
||||||
#include "radio_state.hpp"
|
#include "radio_state.hpp"
|
||||||
#include "ui_record_view.hpp" // DEBUG
|
#include "ui_record_view.hpp"
|
||||||
|
|
||||||
#include "utility.hpp"
|
#include "utility.hpp"
|
||||||
|
|
||||||
@ -47,6 +48,7 @@ class BTLERxView : public View {
|
|||||||
private:
|
private:
|
||||||
void on_data(uint32_t value, bool is_data);
|
void on_data(uint32_t value, bool is_data);
|
||||||
|
|
||||||
|
NavigationView& nav_;
|
||||||
RxRadioState radio_state_{
|
RxRadioState radio_state_{
|
||||||
4000000 /* bandwidth */,
|
4000000 /* bandwidth */,
|
||||||
4000000 /* sampling rate */
|
4000000 /* sampling rate */
|
||||||
@ -64,15 +66,13 @@ class BTLERxView : public View {
|
|||||||
VGAGainField field_vga{
|
VGAGainField field_vga{
|
||||||
{18 * 8, 0 * 16}};
|
{18 * 8, 0 * 16}};
|
||||||
RSSI rssi{
|
RSSI rssi{
|
||||||
{21 * 8, 0, 6 * 8, 4},
|
{21 * 8, 0, 6 * 8, 4}};
|
||||||
};
|
|
||||||
Channel channel{
|
Channel channel{
|
||||||
{21 * 8, 5, 6 * 8, 4},
|
{21 * 8, 5, 6 * 8, 4}};
|
||||||
};
|
|
||||||
|
|
||||||
FrequencyField field_frequency{
|
RxFrequencyField field_frequency{
|
||||||
{0 * 8, 0 * 16},
|
{0 * 8, 0 * 16},
|
||||||
};
|
nav_};
|
||||||
|
|
||||||
Button button_modem_setup{
|
Button button_modem_setup{
|
||||||
{240 - 12 * 8, 1 * 16, 96, 24},
|
{240 - 12 * 8, 1 * 16, 96, 24},
|
||||||
@ -81,9 +81,6 @@ class BTLERxView : public View {
|
|||||||
Console console{
|
Console console{
|
||||||
{0, 4 * 16, 240, 240}};
|
{0, 4 * 16, 240, 240}};
|
||||||
|
|
||||||
void update_freq(rf::Frequency f);
|
|
||||||
// void on_data_afsk(const AFSKDataMessage& message);
|
|
||||||
|
|
||||||
MessageHandlerRegistration message_handler_packet{
|
MessageHandlerRegistration message_handler_packet{
|
||||||
Message::ID::AFSKData,
|
Message::ID::AFSKData,
|
||||||
[this](Message* const p) {
|
[this](Message* const p) {
|
||||||
|
@ -204,6 +204,7 @@ class MicTXView : public View {
|
|||||||
{"OFF-08dB", 4}, // WM8731 Mic Boost OFF to avoid ADC sat in high voice ,relative G = -12 dB's (respect ref level)
|
{"OFF-08dB", 4}, // WM8731 Mic Boost OFF to avoid ADC sat in high voice ,relative G = -12 dB's (respect ref level)
|
||||||
}};
|
}};
|
||||||
|
|
||||||
|
// TODO: Use TxFrequencyField
|
||||||
FrequencyField field_frequency{
|
FrequencyField field_frequency{
|
||||||
{5 * 8, 3 * 8},
|
{5 * 8, 3 * 8},
|
||||||
};
|
};
|
||||||
@ -309,6 +310,7 @@ class MicTXView : public View {
|
|||||||
' ',
|
' ',
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// TODO: Use RxFrequencyField
|
||||||
FrequencyField field_rxfrequency{
|
FrequencyField field_rxfrequency{
|
||||||
{10 * 8, (25 * 8) + 2},
|
{10 * 8, (25 * 8) + 2},
|
||||||
};
|
};
|
||||||
|
@ -38,8 +38,6 @@ class ModemSetupView : public View {
|
|||||||
std::string title() const override { return "Modem setup"; };
|
std::string title() const override { return "Modem setup"; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void update_freq(rf::Frequency f);
|
|
||||||
|
|
||||||
Labels labels{
|
Labels labels{
|
||||||
{{2 * 8, 11 * 8}, "Baudrate:", Color::light_grey()},
|
{{2 * 8, 11 * 8}, "Baudrate:", Color::light_grey()},
|
||||||
{{2 * 8, 13 * 8}, "Mark: Hz", Color::light_grey()},
|
{{2 * 8, 13 * 8}, "Mark: Hz", Color::light_grey()},
|
||||||
|
@ -40,11 +40,8 @@ void NRFRxView::focus() {
|
|||||||
field_frequency.focus();
|
field_frequency.focus();
|
||||||
}
|
}
|
||||||
|
|
||||||
void NRFRxView::update_freq(rf::Frequency f) {
|
NRFRxView::NRFRxView(NavigationView& nav)
|
||||||
receiver_model.set_target_frequency(f);
|
: nav_{nav} {
|
||||||
}
|
|
||||||
|
|
||||||
NRFRxView::NRFRxView(NavigationView& nav) {
|
|
||||||
baseband::run_image(portapack::spi_flash::image_tag_nrf_rx);
|
baseband::run_image(portapack::spi_flash::image_tag_nrf_rx);
|
||||||
|
|
||||||
add_children({&rssi,
|
add_children({&rssi,
|
||||||
@ -57,7 +54,7 @@ NRFRxView::NRFRxView(NavigationView& nav) {
|
|||||||
&console});
|
&console});
|
||||||
|
|
||||||
// Auto-configure modem for LCR RX (will be removed later)
|
// Auto-configure modem for LCR RX (will be removed later)
|
||||||
update_freq(2480000000);
|
field_frequency.set_value(2480000000);
|
||||||
auto def_bell202 = &modem_defs[0];
|
auto def_bell202 = &modem_defs[0];
|
||||||
persistent_memory::set_modem_baudrate(def_bell202->baudrate);
|
persistent_memory::set_modem_baudrate(def_bell202->baudrate);
|
||||||
serial_format_t serial_format;
|
serial_format_t serial_format;
|
||||||
@ -67,17 +64,7 @@ NRFRxView::NRFRxView(NavigationView& nav) {
|
|||||||
serial_format.bit_order = LSB_FIRST;
|
serial_format.bit_order = LSB_FIRST;
|
||||||
persistent_memory::set_serial_format(serial_format);
|
persistent_memory::set_serial_format(serial_format);
|
||||||
|
|
||||||
field_frequency.set_value(receiver_model.target_frequency());
|
|
||||||
field_frequency.set_step(100);
|
field_frequency.set_step(100);
|
||||||
field_frequency.on_change = [this](rf::Frequency f) {
|
|
||||||
update_freq(f);
|
|
||||||
};
|
|
||||||
field_frequency.on_edit = [this, &nav]() {
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(receiver_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
field_frequency.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
button_modem_setup.on_select = [&nav](Button&) {
|
button_modem_setup.on_select = [&nav](Button&) {
|
||||||
nav.push<ModemSetupView>();
|
nav.push<ModemSetupView>();
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
#include "ui.hpp"
|
#include "ui.hpp"
|
||||||
#include "ui_navigation.hpp"
|
#include "ui_navigation.hpp"
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
|
#include "ui_freq_field.hpp"
|
||||||
#include "app_settings.hpp"
|
#include "app_settings.hpp"
|
||||||
#include "radio_state.hpp"
|
#include "radio_state.hpp"
|
||||||
#include "ui_record_view.hpp" // DEBUG
|
#include "ui_record_view.hpp" // DEBUG
|
||||||
@ -47,6 +48,7 @@ class NRFRxView : public View {
|
|||||||
private:
|
private:
|
||||||
void on_data(uint32_t value, bool is_data);
|
void on_data(uint32_t value, bool is_data);
|
||||||
|
|
||||||
|
NavigationView& nav_;
|
||||||
RxRadioState radio_state_{
|
RxRadioState radio_state_{
|
||||||
4000000 /* bandwidth */,
|
4000000 /* bandwidth */,
|
||||||
4000000 /* sampling rate */
|
4000000 /* sampling rate */
|
||||||
@ -64,15 +66,13 @@ class NRFRxView : public View {
|
|||||||
VGAGainField field_vga{
|
VGAGainField field_vga{
|
||||||
{18 * 8, 0 * 16}};
|
{18 * 8, 0 * 16}};
|
||||||
RSSI rssi{
|
RSSI rssi{
|
||||||
{21 * 8, 0, 6 * 8, 4},
|
{21 * 8, 0, 6 * 8, 4}};
|
||||||
};
|
|
||||||
Channel channel{
|
Channel channel{
|
||||||
{21 * 8, 5, 6 * 8, 4},
|
{21 * 8, 5, 6 * 8, 4}};
|
||||||
};
|
|
||||||
|
|
||||||
FrequencyField field_frequency{
|
RxFrequencyField field_frequency{
|
||||||
{0 * 8, 0 * 16},
|
{0 * 8, 0 * 16},
|
||||||
};
|
nav_};
|
||||||
|
|
||||||
Button button_modem_setup{
|
Button button_modem_setup{
|
||||||
{240 - 12 * 8, 1 * 16, 96, 24},
|
{240 - 12 * 8, 1 * 16, 96, 24},
|
||||||
@ -81,9 +81,6 @@ class NRFRxView : public View {
|
|||||||
Console console{
|
Console console{
|
||||||
{0, 4 * 16, 240, 240}};
|
{0, 4 * 16, 240, 240}};
|
||||||
|
|
||||||
void update_freq(rf::Frequency f);
|
|
||||||
// void on_data_afsk(const AFSKDataMessage& message);
|
|
||||||
|
|
||||||
MessageHandlerRegistration message_handler_packet{
|
MessageHandlerRegistration message_handler_packet{
|
||||||
Message::ID::AFSKData,
|
Message::ID::AFSKData,
|
||||||
[this](Message* const p) {
|
[this](Message* const p) {
|
||||||
|
@ -378,26 +378,14 @@ SearchView::SearchView(
|
|||||||
|
|
||||||
field_frequency_min.set_value(receiver_model.target_frequency() - 1000000);
|
field_frequency_min.set_value(receiver_model.target_frequency() - 1000000);
|
||||||
field_frequency_min.set_step(100000);
|
field_frequency_min.set_step(100000);
|
||||||
field_frequency_min.on_change = [this](rf::Frequency) {
|
field_frequency_min.updated = [this](rf::Frequency) {
|
||||||
this->on_range_changed();
|
on_range_changed();
|
||||||
};
|
|
||||||
field_frequency_min.on_edit = [this, &nav]() {
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(receiver_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
this->field_frequency_min.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
field_frequency_max.set_value(receiver_model.target_frequency() + 1000000);
|
field_frequency_max.set_value(receiver_model.target_frequency() + 1000000);
|
||||||
field_frequency_max.set_step(100000);
|
field_frequency_max.set_step(100000);
|
||||||
field_frequency_max.on_change = [this](rf::Frequency) {
|
field_frequency_max.updated = [this](rf::Frequency) {
|
||||||
this->on_range_changed();
|
on_range_changed();
|
||||||
};
|
|
||||||
field_frequency_max.on_edit = [this, &nav]() {
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(receiver_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
this->field_frequency_max.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
field_lna.set_value(receiver_model.lna());
|
field_lna.set_value(receiver_model.lna());
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
#include "spectrum_color_lut.hpp"
|
#include "spectrum_color_lut.hpp"
|
||||||
|
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
|
#include "ui_freq_field.hpp"
|
||||||
#include "ui_styles.hpp"
|
#include "ui_styles.hpp"
|
||||||
#include "recent_entries.hpp"
|
#include "recent_entries.hpp"
|
||||||
|
|
||||||
@ -146,12 +147,14 @@ class SearchView : public View {
|
|||||||
{{1 * 8, 25 * 8}, "Accuracy +/-4.9kHz", Color::light_grey()},
|
{{1 * 8, 25 * 8}, "Accuracy +/-4.9kHz", Color::light_grey()},
|
||||||
{{26 * 8, 25 * 8}, "MHz", Color::light_grey()}};
|
{{26 * 8, 25 * 8}, "MHz", Color::light_grey()}};
|
||||||
|
|
||||||
FrequencyField field_frequency_min{
|
RxFrequencyField field_frequency_min{
|
||||||
{1 * 8, 1 * 16},
|
{1 * 8, 1 * 16},
|
||||||
};
|
nav_,
|
||||||
FrequencyField field_frequency_max{
|
false};
|
||||||
|
RxFrequencyField field_frequency_max{
|
||||||
{11 * 8, 1 * 16},
|
{11 * 8, 1 * 16},
|
||||||
};
|
nav_,
|
||||||
|
false};
|
||||||
LNAGainField field_lna{
|
LNAGainField field_lna{
|
||||||
{22 * 8, 1 * 16}};
|
{22 * 8, 1 * 16}};
|
||||||
VGAGainField field_vga{
|
VGAGainField field_vga{
|
||||||
|
@ -41,7 +41,8 @@ void SondeLogger::on_packet(const sonde::Packet& packet) {
|
|||||||
|
|
||||||
namespace ui {
|
namespace ui {
|
||||||
|
|
||||||
SondeView::SondeView(NavigationView& nav) {
|
SondeView::SondeView(NavigationView& nav)
|
||||||
|
: nav_{nav} {
|
||||||
baseband::run_image(portapack::spi_flash::image_tag_sonde);
|
baseband::run_image(portapack::spi_flash::image_tag_sonde);
|
||||||
|
|
||||||
add_children({&labels,
|
add_children({&labels,
|
||||||
@ -66,20 +67,9 @@ SondeView::SondeView(NavigationView& nav) {
|
|||||||
&button_see_map});
|
&button_see_map});
|
||||||
|
|
||||||
if (!settings_.loaded())
|
if (!settings_.loaded())
|
||||||
receiver_model.set_target_frequency(initial_target_frequency);
|
field_frequency.set_value(initial_target_frequency);
|
||||||
|
|
||||||
field_frequency.set_value(receiver_model.target_frequency());
|
|
||||||
field_frequency.set_step(500); // euquiq: was 10000, but we are using this for fine-tunning
|
field_frequency.set_step(500); // euquiq: was 10000, but we are using this for fine-tunning
|
||||||
field_frequency.on_change = [this](rf::Frequency f) {
|
|
||||||
receiver_model.set_target_frequency(f);
|
|
||||||
};
|
|
||||||
field_frequency.on_edit = [this, &nav]() {
|
|
||||||
// TODO: Provide separate modal method/scheme?
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(receiver_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
field_frequency.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
geopos.set_read_only(true);
|
geopos.set_read_only(true);
|
||||||
|
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
|
|
||||||
#include "ui_navigation.hpp"
|
#include "ui_navigation.hpp"
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
|
#include "ui_freq_field.hpp"
|
||||||
#include "ui_rssi.hpp"
|
#include "ui_rssi.hpp"
|
||||||
#include "ui_qrcode.hpp"
|
#include "ui_qrcode.hpp"
|
||||||
#include "ui_geomap.hpp"
|
#include "ui_geomap.hpp"
|
||||||
@ -65,6 +66,7 @@ class SondeView : public View {
|
|||||||
std::string title() const override { return "Radiosnd RX"; };
|
std::string title() const override { return "Radiosnd RX"; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
NavigationView& nav_;
|
||||||
RxRadioState radio_state_{
|
RxRadioState radio_state_{
|
||||||
1750000 /* bandwidth */,
|
1750000 /* bandwidth */,
|
||||||
2457600 /* sampling rate */
|
2457600 /* sampling rate */
|
||||||
@ -96,9 +98,9 @@ class SondeView : public View {
|
|||||||
{{4 * 8, 7 * 16}, "Temp:", Color::light_grey()},
|
{{4 * 8, 7 * 16}, "Temp:", Color::light_grey()},
|
||||||
{{0 * 8, 8 * 16}, "Humidity:", Color::light_grey()}};
|
{{0 * 8, 8 * 16}, "Humidity:", Color::light_grey()}};
|
||||||
|
|
||||||
FrequencyField field_frequency{
|
RxFrequencyField field_frequency{
|
||||||
{0 * 8, 0 * 8},
|
{0 * 8, 0 * 8},
|
||||||
};
|
nav_};
|
||||||
|
|
||||||
RFAmpField field_rf_amp{
|
RFAmpField field_rf_amp{
|
||||||
{13 * 8, 0 * 16}};
|
{13 * 8, 0 * 16}};
|
||||||
@ -110,8 +112,7 @@ class SondeView : public View {
|
|||||||
{18 * 8, 0 * 16}};
|
{18 * 8, 0 * 16}};
|
||||||
|
|
||||||
RSSI rssi{
|
RSSI rssi{
|
||||||
{21 * 8, 0, 6 * 8, 4},
|
{21 * 8, 0, 6 * 8, 4}};
|
||||||
};
|
|
||||||
|
|
||||||
AudioVolumeField field_volume{
|
AudioVolumeField field_volume{
|
||||||
{28 * 8, 0 * 16}};
|
{28 * 8, 0 * 16}};
|
||||||
|
@ -57,17 +57,7 @@ SpectrumPainterView::SpectrumPainterView(
|
|||||||
input_image.set_parent_rect(view_rect);
|
input_image.set_parent_rect(view_rect);
|
||||||
input_text.set_parent_rect(view_rect);
|
input_text.set_parent_rect(view_rect);
|
||||||
|
|
||||||
field_frequency.set_value(transmitter_model.target_frequency());
|
|
||||||
field_frequency.set_step(5000);
|
field_frequency.set_step(5000);
|
||||||
field_frequency.on_change = [this](rf::Frequency f) {
|
|
||||||
transmitter_model.set_target_frequency(f);
|
|
||||||
};
|
|
||||||
field_frequency.on_edit = [this, &nav]() {
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(transmitter_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
field_frequency.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
tx_gain = transmitter_model.tx_gain();
|
tx_gain = transmitter_model.tx_gain();
|
||||||
field_rfgain.set_value(tx_gain); // Initial default value (-12 dB's max ).
|
field_rfgain.set_value(tx_gain); // Initial default value (-12 dB's max ).
|
||||||
|
@ -94,9 +94,9 @@ class SpectrumPainterView : public View {
|
|||||||
{{1 * 8, footer_location + 2 * 16}, "BW: Du: P:", Color::light_grey()},
|
{{1 * 8, footer_location + 2 * 16}, "BW: Du: P:", Color::light_grey()},
|
||||||
};
|
};
|
||||||
|
|
||||||
FrequencyField field_frequency{
|
TxFrequencyField field_frequency{
|
||||||
{0 * 8, footer_location + 1 * 16},
|
{0 * 8, footer_location + 1 * 16},
|
||||||
};
|
nav_};
|
||||||
|
|
||||||
NumberField field_rfgain{
|
NumberField field_rfgain{
|
||||||
{14 * 8, footer_location + 1 * 16},
|
{14 * 8, footer_location + 1 * 16},
|
||||||
|
@ -40,7 +40,8 @@ void TestLogger::log_raw_data(const testapp::Packet& packet, const int32_t alt)
|
|||||||
|
|
||||||
namespace ui {
|
namespace ui {
|
||||||
|
|
||||||
TestView::TestView(NavigationView& nav) {
|
TestView::TestView(NavigationView& nav)
|
||||||
|
: nav_{nav} {
|
||||||
baseband::run_image(portapack::spi_flash::image_tag_test);
|
baseband::run_image(portapack::spi_flash::image_tag_test);
|
||||||
|
|
||||||
add_children({&labels,
|
add_children({&labels,
|
||||||
@ -54,18 +55,7 @@ TestView::TestView(NavigationView& nav) {
|
|||||||
&button_cal,
|
&button_cal,
|
||||||
&check_log});
|
&check_log});
|
||||||
|
|
||||||
field_frequency.set_value(receiver_model.target_frequency());
|
|
||||||
field_frequency.set_step(10000);
|
field_frequency.set_step(10000);
|
||||||
field_frequency.on_change = [this](rf::Frequency f) {
|
|
||||||
receiver_model.set_target_frequency(f);
|
|
||||||
};
|
|
||||||
field_frequency.on_edit = [this, &nav]() {
|
|
||||||
// TODO: Provide separate modal method/scheme?
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(receiver_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
field_frequency.set_value(f);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
check_log.on_select = [this](Checkbox&, bool v) {
|
check_log.on_select = [this](Checkbox&, bool v) {
|
||||||
logging = v;
|
logging = v;
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
|
|
||||||
#include "ui_navigation.hpp"
|
#include "ui_navigation.hpp"
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
|
#include "ui_freq_field.hpp"
|
||||||
#include "ui_rssi.hpp"
|
#include "ui_rssi.hpp"
|
||||||
|
|
||||||
#include "event_m0.hpp"
|
#include "event_m0.hpp"
|
||||||
@ -59,6 +60,7 @@ class TestView : public View {
|
|||||||
std::string title() const override { return "Test app"; };
|
std::string title() const override { return "Test app"; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
NavigationView& nav_;
|
||||||
RxRadioState radio_state_{
|
RxRadioState radio_state_{
|
||||||
1750000 /* bandwidth */,
|
1750000 /* bandwidth */,
|
||||||
2457600 * 2 /* sampling rate */
|
2457600 * 2 /* sampling rate */
|
||||||
@ -75,9 +77,9 @@ class TestView : public View {
|
|||||||
Labels labels{
|
Labels labels{
|
||||||
{{0 * 8, 1 * 16}, "Data:", Color::light_grey()}};
|
{{0 * 8, 1 * 16}, "Data:", Color::light_grey()}};
|
||||||
|
|
||||||
FrequencyField field_frequency{
|
RxFrequencyField field_frequency{
|
||||||
{0 * 8, 0 * 8},
|
{0 * 8, 0 * 8},
|
||||||
};
|
nav_};
|
||||||
RFAmpField field_rf_amp{
|
RFAmpField field_rf_amp{
|
||||||
{13 * 8, 0 * 16}};
|
{13 * 8, 0 * 16}};
|
||||||
|
|
||||||
|
@ -102,7 +102,8 @@ void WhipCalcView::update_result() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
WhipCalcView::WhipCalcView(NavigationView& nav) {
|
WhipCalcView::WhipCalcView(NavigationView& nav)
|
||||||
|
: nav_{nav} {
|
||||||
add_children({&labels,
|
add_children({&labels,
|
||||||
//&antennas_on_memory,
|
//&antennas_on_memory,
|
||||||
&field_frequency,
|
&field_frequency,
|
||||||
@ -142,16 +143,8 @@ WhipCalcView::WhipCalcView(NavigationView& nav) {
|
|||||||
};
|
};
|
||||||
|
|
||||||
field_frequency.set_step(1000000); // 1MHz step
|
field_frequency.set_step(1000000); // 1MHz step
|
||||||
field_frequency.on_change = [this](rf::Frequency) {
|
field_frequency.updated = [this](rf::Frequency) {
|
||||||
this->update_result();
|
update_result();
|
||||||
};
|
|
||||||
field_frequency.on_edit = [this, &nav]() {
|
|
||||||
// TODO: Provide separate modal method/scheme?
|
|
||||||
auto new_view = nav.push<FrequencyKeypadView>(transmitter_model.target_frequency());
|
|
||||||
new_view->on_changed = [this](rf::Frequency f) {
|
|
||||||
this->field_frequency.set_value(f);
|
|
||||||
this->update_result();
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
button_exit.on_select = [this, &nav](Button&) {
|
button_exit.on_select = [this, &nav](Button&) {
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
#include "ui.hpp"
|
#include "ui.hpp"
|
||||||
#include "ui_widget.hpp"
|
#include "ui_widget.hpp"
|
||||||
#include "ui_receiver.hpp"
|
#include "ui_receiver.hpp"
|
||||||
|
#include "ui_freq_field.hpp"
|
||||||
#include "ui_navigation.hpp"
|
#include "ui_navigation.hpp"
|
||||||
#include "string_format.hpp"
|
#include "string_format.hpp"
|
||||||
#include <vector>
|
#include <vector>
|
||||||
@ -47,6 +48,7 @@ class WhipCalcView : public View {
|
|||||||
std::vector<uint16_t> elements{};
|
std::vector<uint16_t> elements{};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
NavigationView& nav_;
|
||||||
std::vector<antenna_entry> antenna_db{};
|
std::vector<antenna_entry> antenna_db{};
|
||||||
void update_result();
|
void update_result();
|
||||||
uint16_t string_to_number(std::string);
|
uint16_t string_to_number(std::string);
|
||||||
@ -59,9 +61,10 @@ class WhipCalcView : public View {
|
|||||||
{{5 * 8, 3 * 16}, "Metric:", Color::light_grey()},
|
{{5 * 8, 3 * 16}, "Metric:", Color::light_grey()},
|
||||||
{{3 * 8, 4 * 16}, "Imperial:", Color::light_grey()}};
|
{{3 * 8, 4 * 16}, "Imperial:", Color::light_grey()}};
|
||||||
|
|
||||||
FrequencyField field_frequency{
|
TxFrequencyField field_frequency{
|
||||||
{13 * 8, 1 * 16},
|
{13 * 8, 1 * 16},
|
||||||
};
|
nav_,
|
||||||
|
false};
|
||||||
|
|
||||||
OptionsField options_type{
|
OptionsField options_type{
|
||||||
{13 * 8, 2 * 16},
|
{13 * 8, 2 * 16},
|
||||||
|
72
firmware/application/ui/ui_freq_field.hpp
Normal file
72
firmware/application/ui/ui_freq_field.hpp
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2023 Kyle Reed
|
||||||
|
*
|
||||||
|
* This file is part of PortaPack.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2, or (at your option)
|
||||||
|
* any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; see the file COPYING. If not, write to
|
||||||
|
* the Free Software Foundation, Inc., 51 Franklin Street,
|
||||||
|
* Boston, MA 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __UI_FREQ_FIELD_H__
|
||||||
|
#define __UI_FREQ_FIELD_H__
|
||||||
|
|
||||||
|
#include "portapack.hpp"
|
||||||
|
#include "receiver_model.hpp"
|
||||||
|
#include "transmitter_model.hpp"
|
||||||
|
#include "ui_receiver.hpp"
|
||||||
|
|
||||||
|
namespace ui {
|
||||||
|
|
||||||
|
/* A frequency field bound directly a radio model
|
||||||
|
* that can manage its own editing UX. */
|
||||||
|
template <typename TModel, TModel* model>
|
||||||
|
class BoundFrequencyField : public FrequencyField {
|
||||||
|
private:
|
||||||
|
using FrequencyField::on_change;
|
||||||
|
using FrequencyField::on_edit;
|
||||||
|
|
||||||
|
public:
|
||||||
|
decltype(FrequencyField::on_change) updated{};
|
||||||
|
|
||||||
|
BoundFrequencyField(Point parent_pos, NavigationView& nav, bool update_model = true)
|
||||||
|
: FrequencyField(parent_pos) {
|
||||||
|
// NB: There is no frequency_step on the tx_model.
|
||||||
|
set_step(portapack::receiver_model.frequency_step());
|
||||||
|
set_value(model->target_frequency());
|
||||||
|
|
||||||
|
on_change = [this, update_model](rf::Frequency f) {
|
||||||
|
if (update_model)
|
||||||
|
model->set_target_frequency(f);
|
||||||
|
if (updated)
|
||||||
|
updated(f);
|
||||||
|
};
|
||||||
|
|
||||||
|
on_edit = [this, &nav]() {
|
||||||
|
auto freq_view = nav.push<FrequencyKeypadView>(model->target_frequency());
|
||||||
|
freq_view->on_changed = [this](rf::Frequency f) {
|
||||||
|
set_value(f);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: override set_step and update the rx model then call base.
|
||||||
|
};
|
||||||
|
|
||||||
|
using RxFrequencyField = BoundFrequencyField<ReceiverModel, &portapack::receiver_model>;
|
||||||
|
using TxFrequencyField = BoundFrequencyField<TransmitterModel, &portapack::transmitter_model>;
|
||||||
|
|
||||||
|
} // namespace ui
|
||||||
|
|
||||||
|
#endif // __UI_FREQ_FIELD_H__
|
@ -36,7 +36,6 @@
|
|||||||
|
|
||||||
namespace ui {
|
namespace ui {
|
||||||
|
|
||||||
// TODO: build in support for editing.
|
|
||||||
class FrequencyField : public Widget {
|
class FrequencyField : public Widget {
|
||||||
public:
|
public:
|
||||||
std::function<void(rf::Frequency)> on_change{};
|
std::function<void(rf::Frequency)> on_change{};
|
||||||
@ -45,7 +44,7 @@ class FrequencyField : public Widget {
|
|||||||
|
|
||||||
using range_t = rf::FrequencyRange;
|
using range_t = rf::FrequencyRange;
|
||||||
|
|
||||||
FrequencyField(const Point parent_pos);
|
FrequencyField(Point parent_pos);
|
||||||
|
|
||||||
rf::Frequency value() const;
|
rf::Frequency value() const;
|
||||||
|
|
||||||
@ -54,9 +53,9 @@ class FrequencyField : public Widget {
|
|||||||
|
|
||||||
void paint(Painter& painter) override;
|
void paint(Painter& painter) override;
|
||||||
|
|
||||||
bool on_key(const ui::KeyEvent event) override;
|
bool on_key(ui::KeyEvent event) override;
|
||||||
bool on_encoder(const EncoderEvent delta) override;
|
bool on_encoder(EncoderEvent delta) override;
|
||||||
bool on_touch(const TouchEvent event) override;
|
bool on_touch(TouchEvent event) override;
|
||||||
void on_focus() override;
|
void on_focus() override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
Loading…
Reference in New Issue
Block a user