2016-04-11 17:59:55 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2016 Jared Boone, ShareBrained Technology, Inc.
|
2018-04-18 21:44:41 +00:00
|
|
|
* Copyright (C) 2018 Furrtek
|
2016-04-11 17:59:55 +00:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "capture_app.hpp"
|
2016-06-23 19:03:47 +00:00
|
|
|
#include "baseband_api.hpp"
|
2016-04-12 17:56:00 +00:00
|
|
|
#include "portapack.hpp"
|
2023-07-17 18:43:37 +00:00
|
|
|
#include "ui_freqman.hpp"
|
2023-06-17 14:54:52 +00:00
|
|
|
|
2016-04-12 17:56:00 +00:00
|
|
|
using namespace portapack;
|
2016-04-11 17:59:55 +00:00
|
|
|
|
|
|
|
namespace ui {
|
|
|
|
|
2023-06-18 19:11:04 +00:00
|
|
|
CaptureAppView::CaptureAppView(NavigationView& nav)
|
|
|
|
: nav_{nav} {
|
2023-05-18 20:16:05 +00:00
|
|
|
baseband::run_image(portapack::spi_flash::image_tag_capture);
|
|
|
|
|
|
|
|
add_children({
|
|
|
|
&labels,
|
|
|
|
&rssi,
|
|
|
|
&channel,
|
|
|
|
&field_frequency,
|
|
|
|
&field_frequency_step,
|
|
|
|
&field_rf_amp,
|
|
|
|
&field_lna,
|
|
|
|
&field_vga,
|
|
|
|
&option_bandwidth,
|
2023-07-22 07:20:56 +00:00
|
|
|
&option_format,
|
2023-09-21 15:43:10 +00:00
|
|
|
&check_trim,
|
2023-05-18 20:16:05 +00:00
|
|
|
&record_view,
|
|
|
|
&waterfall,
|
|
|
|
});
|
|
|
|
|
|
|
|
field_frequency_step.set_by_value(receiver_model.frequency_step());
|
|
|
|
field_frequency_step.on_change = [this](size_t, OptionsField::value_t v) {
|
|
|
|
receiver_model.set_frequency_step(v);
|
2023-07-24 15:12:35 +00:00
|
|
|
this->field_frequency.set_step(v);
|
2023-05-18 20:16:05 +00:00
|
|
|
};
|
|
|
|
|
2023-07-22 07:20:56 +00:00
|
|
|
option_format.set_selected_index(0); // Default to C16
|
|
|
|
option_format.on_change = [this](size_t, uint32_t file_type) {
|
|
|
|
record_view.set_file_type((RecordView::FileType)file_type);
|
|
|
|
};
|
|
|
|
|
2023-09-21 15:43:10 +00:00
|
|
|
check_trim.on_select = [this](Checkbox&, bool v) {
|
|
|
|
record_view.set_auto_trim(v);
|
|
|
|
};
|
|
|
|
|
2023-07-22 17:06:55 +00:00
|
|
|
freqman_set_bandwidth_option(SPEC_MODULATION, option_bandwidth);
|
2023-08-02 19:59:26 +00:00
|
|
|
option_bandwidth.on_change = [this](size_t, uint32_t bandwidth) {
|
|
|
|
/* Nyquist would imply a sample rate of 2x bandwidth, but because the ADC
|
|
|
|
* provides 2 values (I,Q), the sample_rate is equal to bandwidth here. */
|
|
|
|
auto sample_rate = bandwidth;
|
|
|
|
|
|
|
|
/* base_rate (bandwidth) is used for FFT calculation and display LCD, and also in recording writing SD Card rate. */
|
2023-06-17 14:54:52 +00:00
|
|
|
/* ex. sampling_rate values, 4Mhz, when recording 500 kHz (BW) and fs 8 Mhz, when selected 1 Mhz BW ... */
|
2023-08-02 19:59:26 +00:00
|
|
|
/* ex. recording 500kHz BW to .C16 file, base_rate clock 500kHz x2(I,Q) x 2 bytes (int signed) =2MB/sec rate SD Card. */
|
|
|
|
|
|
|
|
waterfall.stop();
|
2023-05-18 20:16:05 +00:00
|
|
|
|
2023-08-02 19:59:26 +00:00
|
|
|
// record_view determines the correct oversampling to apply and returns the actual sample rate.
|
|
|
|
// NB: record_view is what actually updates proc_capture baseband settings.
|
|
|
|
auto actual_sample_rate = record_view.set_sampling_rate(sample_rate);
|
2023-07-31 15:46:07 +00:00
|
|
|
|
2023-08-02 19:59:26 +00:00
|
|
|
// Update the radio model with the actual sampling rate.
|
|
|
|
receiver_model.set_sampling_rate(actual_sample_rate);
|
2023-07-31 15:46:07 +00:00
|
|
|
|
2023-08-02 19:59:26 +00:00
|
|
|
// Get suitable anti-aliasing BPF bandwidth for MAX2837 given the actual sample rate.
|
|
|
|
auto anti_alias_filter_bandwidth = filter_bandwidth_for_sampling_rate(actual_sample_rate);
|
|
|
|
receiver_model.set_baseband_bandwidth(anti_alias_filter_bandwidth);
|
2023-06-17 14:54:52 +00:00
|
|
|
|
2023-08-24 08:14:18 +00:00
|
|
|
// Automatically switch default capture format to C8 when bandwidth setting is increased to >=1.5MHz
|
|
|
|
if ((bandwidth >= 1500000) && (previous_bandwidth < 1500000)) {
|
|
|
|
option_format.set_selected_index(1);
|
|
|
|
}
|
|
|
|
previous_bandwidth = bandwidth;
|
|
|
|
|
2023-07-22 17:06:55 +00:00
|
|
|
waterfall.start();
|
2023-05-18 20:16:05 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
receiver_model.enable();
|
2023-09-21 15:43:10 +00:00
|
|
|
option_bandwidth.set_by_value(500000);
|
2023-05-18 20:16:05 +00:00
|
|
|
|
|
|
|
record_view.on_error = [&nav](std::string message) {
|
|
|
|
nav.display_modal("Error", message);
|
|
|
|
};
|
2016-04-11 17:59:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
CaptureAppView::~CaptureAppView() {
|
2023-05-18 20:16:05 +00:00
|
|
|
receiver_model.disable();
|
|
|
|
baseband::shutdown();
|
2016-04-11 17:59:55 +00:00
|
|
|
}
|
|
|
|
|
2016-04-13 18:09:18 +00:00
|
|
|
void CaptureAppView::set_parent_rect(const Rect new_parent_rect) {
|
2023-05-18 20:16:05 +00:00
|
|
|
View::set_parent_rect(new_parent_rect);
|
2016-04-13 18:09:18 +00:00
|
|
|
|
2023-06-17 14:54:52 +00:00
|
|
|
ui::Rect waterfall_rect{0, header_height, new_parent_rect.width(), new_parent_rect.height() - header_height};
|
2023-05-18 20:16:05 +00:00
|
|
|
waterfall.set_parent_rect(waterfall_rect);
|
2016-04-13 18:09:18 +00:00
|
|
|
}
|
|
|
|
|
2016-04-11 18:22:35 +00:00
|
|
|
void CaptureAppView::focus() {
|
2023-05-18 20:16:05 +00:00
|
|
|
record_view.focus();
|
2016-04-27 19:03:43 +00:00
|
|
|
}
|
|
|
|
|
2016-04-11 17:59:55 +00:00
|
|
|
} /* namespace ui */
|