mirror of
https://github.com/portapack-mayhem/mayhem-firmware.git
synced 2025-12-02 19:01:48 +00:00
Finished jammer modes
Shaved off a few kBs by using the Labels widget
This commit is contained in:
@@ -166,7 +166,7 @@ void set_adsb() {
|
||||
send_message(&message);
|
||||
}
|
||||
|
||||
void set_jammer(const bool run, const uint32_t type, const uint32_t speed) {
|
||||
void set_jammer(const bool run, const jammer::JammerType type, const uint32_t speed) {
|
||||
const JammerConfigureMessage message {
|
||||
run,
|
||||
type,
|
||||
|
||||
@@ -25,6 +25,7 @@
|
||||
|
||||
#include "message.hpp"
|
||||
#include "pocsag_packet.hpp"
|
||||
#include "jammer.hpp"
|
||||
|
||||
#include "dsp_fir_taps.hpp"
|
||||
|
||||
@@ -67,7 +68,7 @@ void set_fsk_data(const uint32_t stream_length, const uint32_t samples_per_bit,
|
||||
const uint32_t progress_notice);
|
||||
void set_pocsag(const pocsag::BitRate bitrate);
|
||||
void set_adsb();
|
||||
void set_jammer(const bool run, const uint32_t type, const uint32_t speed);
|
||||
void set_jammer(const bool run, const jammer::JammerType type, const uint32_t speed);
|
||||
void set_rds_data(const uint16_t message_length);
|
||||
void set_spectrum(const size_t sampling_rate, const size_t trigger);
|
||||
|
||||
|
||||
@@ -36,6 +36,8 @@ std::string gen_message_ep(uint8_t city_code, size_t family_code_ep, uint32_t re
|
||||
char ook_bitstream[256];
|
||||
char ep_message[13] = { 0 };
|
||||
|
||||
(void)relay_state_B;
|
||||
|
||||
// EP frame
|
||||
// Repeated 2x 26 times
|
||||
// Whole frame + space = 128ms, data only = 64ms
|
||||
|
||||
@@ -112,24 +112,18 @@ ADSBTxView::ADSBTxView(NavigationView& nav) {
|
||||
baseband::run_image(portapack::spi_flash::image_tag_adsb_tx);
|
||||
|
||||
add_children({
|
||||
&text_format,
|
||||
&labels,
|
||||
&options_format,
|
||||
&text_icaolabel,
|
||||
&sym_icao,
|
||||
&text_callsign,
|
||||
&button_callsign,
|
||||
&text_altitude,
|
||||
&field_altitude,
|
||||
&text_latitude,
|
||||
&field_lat_degrees,
|
||||
&field_lat_minutes,
|
||||
&field_lat_seconds,
|
||||
&text_longitude,
|
||||
&field_lon_degrees,
|
||||
&field_lon_minutes,
|
||||
&field_lon_seconds,
|
||||
&check_emergency,
|
||||
&text_squawk,
|
||||
&field_squawk,
|
||||
&text_frame_a,
|
||||
&text_frame_b,
|
||||
|
||||
@@ -74,10 +74,16 @@ private:
|
||||
.foreground = Color::red(),
|
||||
};
|
||||
|
||||
Text text_format {
|
||||
{ 2 * 8, 1 * 16, 7 * 8, 16 },
|
||||
"Format:"
|
||||
Labels labels {
|
||||
{ { 2 * 8, 2 * 8 }, "Format:", Color::light_grey() },
|
||||
{ { 2 * 8, 4 * 8 }, "ICAO24:", Color::light_grey() },
|
||||
{ { 2 * 8, 7 * 8 }, "ID:", Color::light_grey() },
|
||||
{ { 2 * 8, 10 * 8 }, "Altitude: feet", Color::light_grey() },
|
||||
{ { 2 * 8, 12 * 8 }, "Latitude: * ' \"", Color::light_grey() }, // No ° symbol in 8x16 font
|
||||
{ { 2 * 8, 14 * 8 }, "Longitude: * ' \"", Color::light_grey() }, // No ° symbol in 8x16 font
|
||||
{ { 15 * 8, 18 * 8 }, "Squawk", Color::light_grey() }
|
||||
};
|
||||
|
||||
OptionsField options_format {
|
||||
{ 10 * 8, 1 * 16 },
|
||||
9,
|
||||
@@ -88,29 +94,17 @@ private:
|
||||
}
|
||||
};
|
||||
|
||||
Text text_icaolabel {
|
||||
{ 2 * 8, 2 * 16, 7 * 8, 16 },
|
||||
"ICAO24:"
|
||||
};
|
||||
SymField sym_icao {
|
||||
{ 10 * 8, 2 * 16 },
|
||||
6,
|
||||
SymField::SYMFIELD_HEX
|
||||
};
|
||||
|
||||
Text text_callsign {
|
||||
{ 2 * 8, 3 * 16 + 8, 3 * 8, 16 },
|
||||
"ID:"
|
||||
};
|
||||
Button button_callsign {
|
||||
{ 6 * 8, 3 * 16 + 4, 10 * 8, 24 },
|
||||
""
|
||||
};
|
||||
|
||||
Text text_altitude {
|
||||
{ 2 * 8, 5 * 16, 20 * 8, 16 },
|
||||
"Altitude: feet"
|
||||
};
|
||||
NumberField field_altitude {
|
||||
{ 12 * 8, 5 * 16 },
|
||||
5,
|
||||
@@ -119,10 +113,6 @@ private:
|
||||
' '
|
||||
};
|
||||
|
||||
Text text_latitude {
|
||||
{ 2 * 8, 6 * 16, 20 * 8, 16 },
|
||||
"Latitude: * ' \"" // No ° symbol in 8x16 font
|
||||
};
|
||||
NumberField field_lat_degrees {
|
||||
{ 12 * 8, 6 * 16 }, 3, { -90, 90 }, 1, ' '
|
||||
};
|
||||
@@ -132,10 +122,7 @@ private:
|
||||
NumberField field_lat_seconds {
|
||||
{ 19 * 8, 6 * 16 }, 2, { 0, 59 }, 1, ' '
|
||||
};
|
||||
Text text_longitude {
|
||||
{ 2 * 8, 7 * 16, 20 * 8, 16 },
|
||||
"Longitude: * ' \"" // No ° symbol in 8x16 font
|
||||
};
|
||||
|
||||
NumberField field_lon_degrees {
|
||||
{ 12 * 8, 7 * 16 }, 3, { -90, 90 }, 1, ' '
|
||||
};
|
||||
@@ -152,10 +139,7 @@ private:
|
||||
"Emergency",
|
||||
false
|
||||
};
|
||||
Text text_squawk {
|
||||
{ 15 * 8, 9 * 16, 6 * 8, 16 },
|
||||
"Squawk"
|
||||
};
|
||||
|
||||
SymField field_squawk {
|
||||
{ 22 * 8, 9 * 16 },
|
||||
4,
|
||||
|
||||
@@ -119,28 +119,22 @@ BHTView::BHTView(NavigationView& nav) {
|
||||
//baseband::run_image(portapack::spi_flash::image_tag_encoders);
|
||||
|
||||
add_children({
|
||||
&labels,
|
||||
&options_mode,
|
||||
&text_header,
|
||||
&header_code_a,
|
||||
&header_code_b,
|
||||
&checkbox_speaker,
|
||||
&bmp_speaker,
|
||||
&text_city,
|
||||
&city_code_xy,
|
||||
&text_family,
|
||||
&family_code_xy,
|
||||
&text_subfamily,
|
||||
&subfamily_code,
|
||||
&checkbox_wcsubfamily,
|
||||
&text_receiver,
|
||||
&receiver_code,
|
||||
&checkbox_wcid,
|
||||
&text_relais,
|
||||
&progressbar,
|
||||
&text_message,
|
||||
&checkbox_cligno,
|
||||
&tempo_cligno,
|
||||
&text_cligno,
|
||||
&tx_view
|
||||
});
|
||||
|
||||
@@ -163,17 +157,14 @@ BHTView::BHTView(NavigationView& nav) {
|
||||
if (_mode) {
|
||||
// EP layout
|
||||
remove_children({
|
||||
&text_header,
|
||||
&header_code_a,
|
||||
&header_code_b,
|
||||
&checkbox_speaker,
|
||||
&bmp_speaker,
|
||||
&city_code_xy,
|
||||
&family_code_xy,
|
||||
&text_subfamily,
|
||||
&subfamily_code,
|
||||
&checkbox_wcsubfamily,
|
||||
&text_receiver,
|
||||
&receiver_code,
|
||||
&checkbox_wcid,
|
||||
&relay_states[2],
|
||||
@@ -191,17 +182,14 @@ BHTView::BHTView(NavigationView& nav) {
|
||||
&family_code_ep
|
||||
});
|
||||
add_children({
|
||||
&text_header,
|
||||
&header_code_a,
|
||||
&header_code_b,
|
||||
&checkbox_speaker,
|
||||
&bmp_speaker,
|
||||
&city_code_xy,
|
||||
&family_code_xy,
|
||||
&text_subfamily,
|
||||
&subfamily_code,
|
||||
&checkbox_wcsubfamily,
|
||||
&text_receiver,
|
||||
&receiver_code,
|
||||
&checkbox_wcid,
|
||||
&relay_states[2],
|
||||
@@ -238,12 +226,8 @@ BHTView::BHTView(NavigationView& nav) {
|
||||
checkbox_wcsubfamily.on_select = [this](Checkbox&, bool v) {
|
||||
if (v) {
|
||||
subfamily_code.set_focusable(false);
|
||||
subfamily_code.set_style(&style_grey);
|
||||
text_subfamily.set_style(&style_grey);
|
||||
} else {
|
||||
subfamily_code.set_focusable(true);
|
||||
subfamily_code.set_style(&style());
|
||||
text_subfamily.set_style(&style());
|
||||
}
|
||||
generate_message();
|
||||
};
|
||||
@@ -251,12 +235,8 @@ BHTView::BHTView(NavigationView& nav) {
|
||||
checkbox_wcid.on_select = [this](Checkbox&, bool v) {
|
||||
if (v) {
|
||||
receiver_code.set_focusable(false);
|
||||
receiver_code.set_style(&style_grey);
|
||||
text_receiver.set_style(&style_grey);
|
||||
} else {
|
||||
receiver_code.set_focusable(true);
|
||||
receiver_code.set_style(&style());
|
||||
text_receiver.set_style(&style());
|
||||
}
|
||||
generate_message();
|
||||
};
|
||||
|
||||
@@ -81,6 +81,15 @@ private:
|
||||
.foreground = Color::grey(),
|
||||
};
|
||||
|
||||
Labels labels {
|
||||
{ { 8 * 8, 3 * 8 }, "Header:", Color::light_grey() },
|
||||
{ { 4 * 8, 5 * 8 }, "Code ville:", Color::light_grey() },
|
||||
{ { 7 * 8, 7 * 8 }, "Famille:", Color::light_grey() },
|
||||
{ { 2 * 8, 9 * 8 + 2 }, "Sous-famille:", Color::light_grey() },
|
||||
{ { 2 * 8, 13 * 8 }, "ID recepteur:", Color::light_grey() },
|
||||
{ { 1 * 8, 17 * 8 }, "Relais:", Color::light_grey() },
|
||||
{ { 27 * 8 + 4, 20 * 8 + 4 }, "s.", Color::light_grey() }
|
||||
};
|
||||
|
||||
OptionsField options_mode {
|
||||
{ 10 * 8, 4 },
|
||||
@@ -103,10 +112,6 @@ private:
|
||||
ui::Color::black()
|
||||
};
|
||||
|
||||
Text text_header {
|
||||
{ 8 * 8, 3 * 8, 7 * 8, 16 },
|
||||
"Header:"
|
||||
};
|
||||
NumberField header_code_a {
|
||||
{ 16 * 8, 3 * 8 },
|
||||
2,
|
||||
@@ -122,10 +127,6 @@ private:
|
||||
'0'
|
||||
};
|
||||
|
||||
Text text_city {
|
||||
{ 4 * 8, 5 * 8, 11 * 8, 16 },
|
||||
"Code ville:"
|
||||
};
|
||||
NumberField city_code_xy {
|
||||
{ 16 * 8, 5 * 8 },
|
||||
2,
|
||||
@@ -141,10 +142,6 @@ private:
|
||||
' '
|
||||
};
|
||||
|
||||
Text text_family {
|
||||
{ 7 * 8, 7 * 8, 8 * 8, 16 },
|
||||
"Famille:"
|
||||
};
|
||||
NumberField family_code_xy {
|
||||
{ 16 * 8, 7 * 8 },
|
||||
1,
|
||||
@@ -163,10 +160,6 @@ private:
|
||||
}
|
||||
};
|
||||
|
||||
Text text_subfamily {
|
||||
{ 2 * 8, 9 * 8 + 2, 13 * 8, 16 },
|
||||
"Sous-famille:"
|
||||
};
|
||||
NumberField subfamily_code {
|
||||
{ 16 * 8, 9 * 8 + 2 },
|
||||
1,
|
||||
@@ -180,10 +173,6 @@ private:
|
||||
"Toutes"
|
||||
};
|
||||
|
||||
Text text_receiver {
|
||||
{ 2 * 8, 13 * 8, 13 * 8, 16 },
|
||||
"ID recepteur:"
|
||||
};
|
||||
NumberField receiver_code {
|
||||
{ 16 * 8, 13 * 8 },
|
||||
2,
|
||||
@@ -197,11 +186,6 @@ private:
|
||||
"Tous"
|
||||
};
|
||||
|
||||
Text text_relais {
|
||||
{ 1 * 8, 8 * 16 + 8, 7 * 8, 16 },
|
||||
"Relais:"
|
||||
};
|
||||
|
||||
std::array<ImageOptionsField, 4> relay_states { };
|
||||
|
||||
ImageOptionsField::options_t relay_options = {
|
||||
@@ -230,10 +214,6 @@ private:
|
||||
1,
|
||||
' '
|
||||
};
|
||||
Text text_cligno {
|
||||
{ 27 * 8 + 4, 10 * 16 + 4, 2 * 8, 16 },
|
||||
"s."
|
||||
};
|
||||
|
||||
TransmitterView tx_view {
|
||||
16 * 16,
|
||||
|
||||
@@ -288,9 +288,7 @@ CloseCallView::CloseCallView(
|
||||
baseband::run_image(portapack::spi_flash::image_tag_wideband_spectrum);
|
||||
|
||||
add_children({
|
||||
&text_labels_a,
|
||||
&text_labels_b,
|
||||
&text_labels_c,
|
||||
&labels,
|
||||
&field_frequency_min,
|
||||
&field_frequency_max,
|
||||
&field_lna,
|
||||
@@ -306,9 +304,6 @@ CloseCallView::CloseCallView(
|
||||
&button_exit
|
||||
});
|
||||
|
||||
text_labels_a.set_style(&style_grey);
|
||||
text_labels_b.set_style(&style_grey);
|
||||
text_labels_c.set_style(&style_grey);
|
||||
text_slices.set_style(&style_grey);
|
||||
text_rate.set_style(&style_grey);
|
||||
text_mhz.set_style(&style_grey);
|
||||
|
||||
@@ -62,25 +62,25 @@ private:
|
||||
.foreground = Color::green(),
|
||||
};
|
||||
|
||||
rf::Frequency f_min, f_max;
|
||||
rf::Frequency f_min { 0 }, f_max { 0 };
|
||||
Coord last_pos { 0 };
|
||||
ChannelSpectrumFIFO* fifo { nullptr };
|
||||
uint8_t detect_counter { 0 }, release_counter { 0 };
|
||||
uint8_t slice_trim;
|
||||
uint8_t slice_trim { 0 };
|
||||
uint32_t mean { 0 };
|
||||
uint32_t min_threshold { 80 }; // Todo: Put this in persistent / settings
|
||||
rf::Frequency slice_start;
|
||||
rf::Frequency slice_frequency;
|
||||
uint8_t slices_max;
|
||||
uint8_t slices_counter;
|
||||
int16_t last_channel;
|
||||
rf::Frequency slice_start { 0 };
|
||||
rf::Frequency slice_frequency { 0 };
|
||||
uint8_t slices_max { 0 };
|
||||
uint8_t slices_counter { 0 };
|
||||
int16_t last_channel { 0 };
|
||||
uint32_t weight { 0 };
|
||||
uint64_t frequency_acc { 0 };
|
||||
rf::Frequency scan_span, resolved_frequency;
|
||||
uint16_t locked_imax;
|
||||
rf::Frequency scan_span { 0 }, resolved_frequency { 0 };
|
||||
uint16_t locked_imax { 0 };
|
||||
uint8_t slicemax_pow[32]; // Todo: Cap max slices !
|
||||
int16_t slicemax_idx[32];
|
||||
uint8_t scan_counter;
|
||||
uint8_t scan_counter { 0 };
|
||||
SignalToken signal_token_tick_second { };
|
||||
bool ignore { true };
|
||||
bool slicing { false };
|
||||
@@ -101,17 +101,10 @@ private:
|
||||
* |
|
||||
* */
|
||||
|
||||
Text text_labels_a {
|
||||
{ 1 * 8, 0 * 16, 28 * 8, 16 },
|
||||
"Min: Max: LNA VGA"
|
||||
};
|
||||
Text text_labels_b {
|
||||
{ 1 * 8, 2 * 16, 10 * 8, 16 },
|
||||
"Threshold:"
|
||||
};
|
||||
Text text_labels_c {
|
||||
{ 1 * 8, 3 * 16, 28 * 8, 16 },
|
||||
"Slices: Rate: Hz"
|
||||
Labels labels {
|
||||
{ { 1 * 8, 0 }, "Min: Max: LNA VGA", Color::light_grey() },
|
||||
{ { 1 * 8, 4 * 8 }, "Threshold:", Color::light_grey() },
|
||||
{ { 1 * 8, 6 * 8 }, "Slices: Rate: Hz", Color::light_grey() }
|
||||
};
|
||||
|
||||
NumberField field_threshold {
|
||||
|
||||
@@ -265,23 +265,15 @@ EncodersView::EncodersView(NavigationView& nav) {
|
||||
encoder_def = &encoder_defs[0];
|
||||
|
||||
add_children({
|
||||
&text_enctype,
|
||||
&labels,
|
||||
&options_enctype,
|
||||
&text_clk,
|
||||
&numberfield_clk,
|
||||
&text_kHz,
|
||||
&text_bitduration,
|
||||
&numberfield_bitduration,
|
||||
&text_us1,
|
||||
&text_wordduration,
|
||||
&numberfield_wordduration,
|
||||
&text_us2,
|
||||
&text_symfield,
|
||||
&symfield_word,
|
||||
&text_format,
|
||||
//&text_format_a, // DEBUG
|
||||
//&text_format_d, // DEBUG
|
||||
&text_waveform,
|
||||
&waveform,
|
||||
&text_status,
|
||||
&progress,
|
||||
|
||||
@@ -99,21 +99,25 @@ private:
|
||||
.foreground = Color::blue(),
|
||||
};
|
||||
|
||||
Text text_enctype {
|
||||
{ 1 * 8, 32, 5 * 8, 16 },
|
||||
"Type:"
|
||||
Labels labels {
|
||||
{ { 1 * 8, 4 * 8 }, "Type:", Color::light_grey() },
|
||||
{ { 16 * 8, 4 * 8 }, "Clk:", Color::light_grey() },
|
||||
{ { 24 * 8, 4 * 8 }, "kHz", Color::light_grey() },
|
||||
{ { 16 * 8, 6 * 8 }, "Bit:", Color::light_grey() },
|
||||
{ { 25 * 8, 6 * 8 }, "us", Color::light_grey() },
|
||||
{ { 15 * 8, 8 * 8 }, "Word:", Color::light_grey() },
|
||||
{ { 26 * 8, 8 * 8 }, "us", Color::light_grey() },
|
||||
{ { 2 * 8, 10 * 8 }, "Word:", Color::light_grey() },
|
||||
{ { 1 * 8, 17 * 8 }, "Waveform:", Color::light_grey() }
|
||||
};
|
||||
|
||||
OptionsField options_enctype { // Options are loaded at runtime
|
||||
{ 6 * 8, 32 },
|
||||
7,
|
||||
{
|
||||
}
|
||||
};
|
||||
|
||||
Text text_clk {
|
||||
{ 16 * 8, 4 * 8, 4 * 8, 16 },
|
||||
"Clk:"
|
||||
};
|
||||
|
||||
NumberField numberfield_clk {
|
||||
{ 21 * 8, 4 * 8 },
|
||||
3,
|
||||
@@ -121,15 +125,7 @@ private:
|
||||
1,
|
||||
' '
|
||||
};
|
||||
Text text_kHz {
|
||||
{ 24 * 8, 4 * 8, 3 * 8, 16 },
|
||||
"kHz"
|
||||
};
|
||||
|
||||
Text text_bitduration {
|
||||
{ 16 * 8, 6 * 8, 4 * 8, 16 },
|
||||
"Bit:"
|
||||
};
|
||||
|
||||
NumberField numberfield_bitduration {
|
||||
{ 21 * 8, 6 * 8 },
|
||||
4,
|
||||
@@ -137,15 +133,7 @@ private:
|
||||
1,
|
||||
' '
|
||||
};
|
||||
Text text_us1 {
|
||||
{ 25 * 8, 6 * 8, 2 * 8, 16 },
|
||||
"us"
|
||||
};
|
||||
|
||||
Text text_wordduration {
|
||||
{ 15 * 8, 8 * 8, 5 * 8, 16 },
|
||||
"Word:"
|
||||
};
|
||||
|
||||
NumberField numberfield_wordduration {
|
||||
{ 21 * 8, 8 * 8 },
|
||||
5,
|
||||
@@ -153,15 +141,7 @@ private:
|
||||
100,
|
||||
' '
|
||||
};
|
||||
Text text_us2 {
|
||||
{ 26 * 8, 8 * 8, 2 * 8, 16 },
|
||||
"us"
|
||||
};
|
||||
|
||||
Text text_symfield {
|
||||
{ 2 * 8, 10 * 8, 5 * 8, 16 },
|
||||
"Word:"
|
||||
};
|
||||
SymField symfield_word {
|
||||
{ 2 * 8, 12 * 8 },
|
||||
20,
|
||||
@@ -175,11 +155,6 @@ private:
|
||||
//Text text_format_a; // DEBUG
|
||||
//Text text_format_d; // DEBUG
|
||||
|
||||
Text text_waveform {
|
||||
{ 1 * 8, 136, 9 * 8, 16 },
|
||||
"Waveform:"
|
||||
};
|
||||
|
||||
Waveform waveform {
|
||||
{ 0, 160, 240, 32 },
|
||||
waveform_buffer,
|
||||
@@ -193,6 +168,7 @@ private:
|
||||
{ 2 * 8, 13 * 16, 128, 16 },
|
||||
"Ready"
|
||||
};
|
||||
|
||||
ProgressBar progress {
|
||||
{ 2 * 8, 13 * 16 + 20, 208, 16 }
|
||||
};
|
||||
|
||||
@@ -280,10 +280,8 @@ FreqManView::FreqManView(
|
||||
|
||||
add_children({
|
||||
&menu_view,
|
||||
&text_edit,
|
||||
&button_edit_freq,
|
||||
&button_edit_desc,
|
||||
&text_category,
|
||||
&options_category,
|
||||
&button_del,
|
||||
&button_exit
|
||||
|
||||
@@ -153,11 +153,12 @@ private:
|
||||
{ 0, 0, 240, 168 },
|
||||
true
|
||||
};
|
||||
|
||||
Text text_edit {
|
||||
{ 2 * 8, 24 * 8, 5 * 8, 16 },
|
||||
"Edit:"
|
||||
|
||||
Labels label {
|
||||
{ { 2 * 8, 24 * 8 }, "Edit:", Color::light_grey() },
|
||||
{ { 2 * 8, 35 * 8 }, "Category:", Color::light_grey() }
|
||||
};
|
||||
|
||||
Button button_edit_freq {
|
||||
{ 2 * 8, 26 * 8, 14 * 8, 32 },
|
||||
"Frequency"
|
||||
@@ -166,10 +167,7 @@ private:
|
||||
{ 2 * 8, 30 * 8 + 4, 14 * 8, 32 },
|
||||
"Description"
|
||||
};
|
||||
Text text_category {
|
||||
{ 2 * 8, 35 * 8, 9 * 8, 16 },
|
||||
"Category:",
|
||||
};
|
||||
|
||||
OptionsField options_category {
|
||||
{ 12 * 8, 35 * 8 },
|
||||
8,
|
||||
|
||||
@@ -32,10 +32,8 @@
|
||||
#include <cstring>
|
||||
#include <stdio.h>
|
||||
|
||||
#define JAMMER_CH_WIDTH 1000000
|
||||
#define JAMMER_MAX_CH 24
|
||||
|
||||
using namespace portapack;
|
||||
using namespace jammer;
|
||||
|
||||
namespace ui {
|
||||
|
||||
@@ -126,18 +124,14 @@ JammerView::JammerView(NavigationView& nav) {
|
||||
JammerChannel * jammer_channels = (JammerChannel*)shared_memory.bb_data.data;
|
||||
|
||||
add_children({
|
||||
&text_type,
|
||||
&labels,
|
||||
&options_type,
|
||||
&text_range_number,
|
||||
&text_range_total,
|
||||
&text_speed,
|
||||
&options_speed,
|
||||
&text_preset,
|
||||
&options_preset,
|
||||
&text_hop,
|
||||
&options_hop,
|
||||
&button_transmit,
|
||||
&button_exit
|
||||
&button_transmit
|
||||
});
|
||||
|
||||
const auto button_freq_fn = [this, &nav](Button& button) {
|
||||
@@ -219,8 +213,8 @@ JammerView::JammerView(NavigationView& nav) {
|
||||
|
||||
};
|
||||
|
||||
options_type.set_selected_index(1); // Noise
|
||||
options_speed.set_selected_index(2); // 10kHz
|
||||
options_type.set_selected_index(2); // Sweep
|
||||
options_speed.set_selected_index(3); // 10kHz
|
||||
options_preset.set_selected_index(8); // ISM 868
|
||||
options_hop.set_selected_index(1); // 50ms
|
||||
button_transmit.set_style(&style_val);
|
||||
@@ -236,7 +230,7 @@ JammerView::JammerView(NavigationView& nav) {
|
||||
button_transmit.set_text("START");
|
||||
transmitter_model.disable();
|
||||
radio::disable();
|
||||
baseband::set_jammer(false, 0, 0);
|
||||
baseband::set_jammer(false, JammerType::TYPE_FSK, 0);
|
||||
jamming = false;
|
||||
} else {
|
||||
|
||||
@@ -303,16 +297,12 @@ JammerView::JammerView(NavigationView& nav) {
|
||||
transmitter_model.set_tx_gain(47);
|
||||
transmitter_model.enable();
|
||||
|
||||
baseband::set_jammer(true, options_type.selected_index(), options_speed.selected_index());
|
||||
baseband::set_jammer(true, (JammerType)options_type.selected_index(), options_speed.selected_index_value());
|
||||
} else {
|
||||
nav.display_modal("Error", "Jamming bandwidth too large.");
|
||||
nav.display_modal("Error", "Jamming bandwidth too large.\nMust be less than 24MHz.");
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
button_exit.on_select = [&nav](Button&){
|
||||
nav.pop();
|
||||
};
|
||||
}
|
||||
|
||||
} /* namespace ui */
|
||||
|
||||
@@ -24,8 +24,9 @@
|
||||
#include "ui_widget.hpp"
|
||||
#include "ui_font_fixed_8x16.hpp"
|
||||
#include "ui_navigation.hpp"
|
||||
#include "message.hpp"
|
||||
#include "transmitter_model.hpp"
|
||||
#include "message.hpp"
|
||||
#include "jammer.hpp"
|
||||
|
||||
namespace ui {
|
||||
|
||||
@@ -157,19 +158,22 @@ private:
|
||||
|
||||
};
|
||||
|
||||
bool jamming = false;
|
||||
bool jamming { false };
|
||||
|
||||
Text text_type {
|
||||
{ 3 * 8, 4, 5 * 8, 16 },
|
||||
"Type:"
|
||||
Labels labels {
|
||||
{ { 3 * 8, 4 }, "Type:", Color::light_grey() },
|
||||
{ { 2 * 8, 20 }, "Speed:", Color::light_grey() },
|
||||
{ { 1 * 8, 36 }, "Preset:", Color::light_grey() },
|
||||
{ { 5 * 8, 52 }, "Hop:", Color::light_grey() }
|
||||
};
|
||||
|
||||
OptionsField options_type {
|
||||
{ 9 * 8, 4 },
|
||||
5,
|
||||
{
|
||||
{ "Ramp ", 0 },
|
||||
{ "Noise", 1 },
|
||||
{ "Tones", 2 }
|
||||
{ "FSK ", 0 },
|
||||
{ "Tone ", 1 },
|
||||
{ "Sweep", 2 }
|
||||
}
|
||||
};
|
||||
|
||||
@@ -182,26 +186,18 @@ private:
|
||||
"/--"
|
||||
};
|
||||
|
||||
Text text_speed {
|
||||
{ 2 * 8, 20, 6 * 8, 16 },
|
||||
"Speed:"
|
||||
};
|
||||
OptionsField options_speed {
|
||||
{ 9 * 8, 20 },
|
||||
6,
|
||||
{
|
||||
{ "10Hz ", 0 },
|
||||
{ "100Hz ", 1 },
|
||||
{ "1kHz ", 2 },
|
||||
{ "10kHz ", 3 },
|
||||
{ "100kHz", 4 }
|
||||
{ "10Hz ", 10 },
|
||||
{ "100Hz ", 100 },
|
||||
{ "1kHz ", 1000 },
|
||||
{ "10kHz ", 10000 },
|
||||
{ "100kHz", 100000 }
|
||||
}
|
||||
};
|
||||
|
||||
Text text_preset {
|
||||
{ 1 * 8, 36, 7 * 8, 16 },
|
||||
"Preset:"
|
||||
};
|
||||
OptionsField options_preset {
|
||||
{ 9 * 8, 36 },
|
||||
16,
|
||||
@@ -232,10 +228,6 @@ private:
|
||||
}
|
||||
};
|
||||
|
||||
Text text_hop {
|
||||
{ 5 * 8, 52, 10 * 8, 16 },
|
||||
"Hop:"
|
||||
};
|
||||
OptionsField options_hop {
|
||||
{ 9 * 8, 52 },
|
||||
5,
|
||||
@@ -259,11 +251,6 @@ private:
|
||||
"START"
|
||||
};
|
||||
|
||||
Button button_exit {
|
||||
{ 19 * 8, 16 * 16, 80, 48 },
|
||||
"Exit"
|
||||
};
|
||||
|
||||
MessageHandlerRegistration message_handler_retune {
|
||||
Message::ID::Retune,
|
||||
[this](Message* const p) {
|
||||
|
||||
@@ -77,24 +77,19 @@ RDSView::RDSView(NavigationView& nav) {
|
||||
strcpy(RadioText, "Radiotext test ABCD1234");
|
||||
|
||||
add_children({
|
||||
&text_pty,
|
||||
&labels,
|
||||
&options_pty,
|
||||
&text_countrycode,
|
||||
&options_countrycode,
|
||||
&text_coverage,
|
||||
&options_coverage,
|
||||
&text_tx,
|
||||
&options_tx,
|
||||
&check_mono_stereo,
|
||||
&check_TA,
|
||||
&check_TP,
|
||||
&check_MS,
|
||||
&text_pi_code,
|
||||
&sym_pi_code,
|
||||
&button_editpsn,
|
||||
&text_psn,
|
||||
&button_editradiotext,
|
||||
&text_radiotext,
|
||||
&text_radiotexta,
|
||||
&text_radiotextb,
|
||||
&tx_view,
|
||||
|
||||
@@ -55,10 +55,15 @@ private:
|
||||
void start_tx();
|
||||
void on_tuning_frequency_changed(rf::Frequency f);
|
||||
|
||||
Text text_pty {
|
||||
{ 1 * 8, 16 + 8, 4 * 8, 16 },
|
||||
"PTY:"
|
||||
Labels labels {
|
||||
{ { 1 * 8, 16 + 8 }, "PTY:", Color::light_grey() },
|
||||
{ { 14 * 8, 16 + 8 }, "CC:", Color::light_grey() },
|
||||
{ { 1 * 8, 32 + 8 }, "PI:", Color::light_grey() },
|
||||
{ { 13 * 8, 32 + 8 }, "Cov:", Color::light_grey() },
|
||||
{ { 2 * 8, 8 * 16 }, "RadioText:", Color::light_grey() },
|
||||
{ { 2 * 8, 14 * 16 }, "TX:", Color::light_grey() }
|
||||
};
|
||||
|
||||
OptionsField options_pty {
|
||||
{ 5 * 8, 16 + 8 },
|
||||
8,
|
||||
@@ -98,10 +103,6 @@ private:
|
||||
}
|
||||
};
|
||||
|
||||
Text text_countrycode {
|
||||
{ 14 * 8, 16 + 8, 4 * 8, 16 },
|
||||
"CC:"
|
||||
};
|
||||
OptionsField options_countrycode {
|
||||
{ 17 * 8, 16 + 8 },
|
||||
11,
|
||||
@@ -171,20 +172,12 @@ private:
|
||||
}
|
||||
};
|
||||
|
||||
Text text_pi_code {
|
||||
{ 1 * 8, 32 + 8, 3 * 8, 16 },
|
||||
"PI:"
|
||||
};
|
||||
SymField sym_pi_code {
|
||||
{ 4 * 8, 32 + 8 },
|
||||
4,
|
||||
SymField::SYMFIELD_HEX
|
||||
};
|
||||
|
||||
Text text_coverage {
|
||||
{ 13 * 8, 32 + 8, 9 * 8, 16 },
|
||||
"Cov:"
|
||||
};
|
||||
OptionsField options_coverage {
|
||||
{ 17 * 8, 32 + 8 },
|
||||
12,
|
||||
@@ -229,19 +222,15 @@ private:
|
||||
"MS"
|
||||
};
|
||||
|
||||
Text text_psn {
|
||||
{ 2 * 8, 6 * 16, 12 * 8, 16 },
|
||||
"PSN:"
|
||||
};
|
||||
Button button_editpsn {
|
||||
{ 22 * 8, 5 * 16 + 12, 48, 24 },
|
||||
"Set"
|
||||
};
|
||||
|
||||
Text text_radiotext {
|
||||
{ 2 * 8, 8 * 16, 10 * 8, 16 },
|
||||
"RadioText:"
|
||||
Text text_psn {
|
||||
{ 2 * 8, 6 * 16, 4 * 8, 16 },
|
||||
"PSN:"
|
||||
};
|
||||
|
||||
Text text_radiotexta {
|
||||
{ 2 * 8, 9 * 16, 19 * 8, 16 },
|
||||
"-"
|
||||
@@ -255,10 +244,6 @@ private:
|
||||
"Set"
|
||||
};
|
||||
|
||||
Text text_tx {
|
||||
{ 2 * 8, 14 * 16, 3 * 8, 16 },
|
||||
"TX:"
|
||||
};
|
||||
OptionsField options_tx {
|
||||
{ 5 * 8, 14 * 16 },
|
||||
11,
|
||||
|
||||
@@ -74,9 +74,8 @@ WhipCalcView::WhipCalcView(
|
||||
) {
|
||||
|
||||
add_children({
|
||||
&text_frequency,
|
||||
&labels,
|
||||
&field_frequency,
|
||||
&text_type,
|
||||
&options_type,
|
||||
&text_result_metric,
|
||||
&text_result_imperial,
|
||||
|
||||
@@ -47,18 +47,15 @@ private:
|
||||
|
||||
void update_result();
|
||||
|
||||
Text text_frequency {
|
||||
{ 2 * 8, 2 * 16, 10 * 16, 16 },
|
||||
"Frequency:"
|
||||
Labels labels {
|
||||
{ { 2 * 8, 2 * 16 }, "Frequency:", Color::light_grey() },
|
||||
{ { 2 * 8, 3 * 16 }, "Type:", Color::light_grey() }
|
||||
};
|
||||
|
||||
FrequencyField field_frequency {
|
||||
{ 13 * 8, 2 * 16 },
|
||||
};
|
||||
|
||||
Text text_type {
|
||||
{ 2 * 8, 3 * 16, 5 * 16, 16 },
|
||||
"Type:"
|
||||
};
|
||||
|
||||
OptionsField options_type {
|
||||
{ 8 * 8, 3 * 16 },
|
||||
12,
|
||||
|
||||
Reference in New Issue
Block a user