2017-10-29 21:00:39 -04:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Jared Boone, ShareBrained Technology, Inc.
|
|
|
|
* Copyright (C) 2017 Furrtek
|
|
|
|
*
|
|
|
|
* 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_TEST_H__
|
|
|
|
#define __UI_TEST_H__
|
|
|
|
|
|
|
|
#include "ui_navigation.hpp"
|
|
|
|
#include "ui_receiver.hpp"
|
|
|
|
#include "ui_rssi.hpp"
|
|
|
|
|
|
|
|
#include "event_m0.hpp"
|
|
|
|
|
|
|
|
#include "test_packet.hpp"
|
2017-11-08 15:08:46 -05:00
|
|
|
#include "log_file.hpp"
|
2017-10-29 21:00:39 -04:00
|
|
|
|
|
|
|
#include <cstddef>
|
|
|
|
#include <string>
|
|
|
|
|
2017-11-08 15:08:46 -05:00
|
|
|
class TestLogger {
|
2023-05-18 16:16:05 -04:00
|
|
|
public:
|
|
|
|
Optional<File::Error> append(const std::string& filename) {
|
|
|
|
return log_file.append(filename);
|
|
|
|
}
|
|
|
|
|
|
|
|
void log_raw_data(const testapp::Packet& packet, const int32_t alt);
|
|
|
|
|
|
|
|
private:
|
|
|
|
LogFile log_file{};
|
2017-11-08 15:08:46 -05:00
|
|
|
};
|
|
|
|
|
2017-10-29 21:00:39 -04:00
|
|
|
namespace ui {
|
|
|
|
|
|
|
|
class TestView : public View {
|
2023-05-18 16:16:05 -04:00
|
|
|
public:
|
|
|
|
TestView(NavigationView& nav);
|
|
|
|
~TestView();
|
|
|
|
|
|
|
|
void focus() override;
|
|
|
|
|
|
|
|
std::string title() const override { return "Test app"; };
|
|
|
|
|
|
|
|
private:
|
2023-06-14 03:57:20 -04:00
|
|
|
RxRadioState radio_state_{
|
|
|
|
1750000 /* bandwidth */,
|
|
|
|
2457600 * 2 /* sampling rate */
|
|
|
|
};
|
|
|
|
|
2023-05-18 16:16:05 -04:00
|
|
|
Coord cur_x{0};
|
|
|
|
uint32_t packet_count{0};
|
|
|
|
uint32_t packets_lost{0};
|
|
|
|
uint32_t prev_v{0};
|
|
|
|
uint32_t raw_alt{0};
|
|
|
|
uint32_t cal_value{0};
|
|
|
|
bool logging{false};
|
|
|
|
|
|
|
|
Labels labels{
|
|
|
|
{{0 * 8, 1 * 16}, "Data:", Color::light_grey()}};
|
|
|
|
|
|
|
|
FrequencyField field_frequency{
|
|
|
|
{0 * 8, 0 * 8},
|
|
|
|
};
|
|
|
|
RFAmpField field_rf_amp{
|
|
|
|
{13 * 8, 0 * 16}};
|
|
|
|
|
|
|
|
LNAGainField field_lna{
|
|
|
|
{15 * 8, 0 * 16}};
|
|
|
|
|
|
|
|
VGAGainField field_vga{
|
|
|
|
{18 * 8, 0 * 16}};
|
|
|
|
|
|
|
|
RSSI rssi{
|
|
|
|
{21 * 8, 0, 6 * 8, 4},
|
|
|
|
};
|
|
|
|
|
|
|
|
Text text_debug_a{
|
|
|
|
{0 * 8, 4 * 16, 30 * 8, 16},
|
|
|
|
"..."};
|
|
|
|
Text text_debug_b{
|
|
|
|
{0 * 8, 5 * 16, 30 * 8, 16},
|
|
|
|
"..."};
|
|
|
|
|
|
|
|
Button button_cal{
|
|
|
|
{17 * 8, 2 * 16, 5 * 8, 2 * 16},
|
|
|
|
"CAL"};
|
|
|
|
Checkbox check_log{
|
|
|
|
{23 * 8, 2 * 16},
|
|
|
|
3,
|
|
|
|
"LOG"};
|
|
|
|
|
|
|
|
std::unique_ptr<TestLogger> logger{};
|
|
|
|
|
|
|
|
MessageHandlerRegistration message_handler_packet{
|
|
|
|
Message::ID::TestAppPacket,
|
|
|
|
[this](Message* const p) {
|
|
|
|
const auto message = static_cast<const TestAppPacketMessage*>(p);
|
|
|
|
const testapp::Packet packet{message->packet};
|
2023-06-11 14:47:13 -04:00
|
|
|
on_packet(packet);
|
2023-05-18 16:16:05 -04:00
|
|
|
}};
|
|
|
|
|
|
|
|
void on_packet(const testapp::Packet& packet);
|
2017-10-29 21:00:39 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
} /* namespace ui */
|
|
|
|
|
2023-05-18 16:16:05 -04:00
|
|
|
#endif /*__UI_TEST_H__*/
|