Moved SPainter and GPSSim to ext app (#1721)

* Moved GPSSim
* Moved spainter
This commit is contained in:
Totoo 2024-01-05 10:46:09 +01:00 committed by GitHub
parent 1a69ce2d97
commit d303098e35
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
17 changed files with 241 additions and 45 deletions

View File

@ -265,7 +265,7 @@ set(CPPSRC
apps/ble_tx_app.cpp apps/ble_tx_app.cpp
apps/capture_app.cpp apps/capture_app.cpp
apps/ert_app.cpp apps/ert_app.cpp
apps/gps_sim_app.cpp # apps/gps_sim_app.cpp
# apps/lge_app.cpp # apps/lge_app.cpp
apps/pocsag_app.cpp apps/pocsag_app.cpp
# apps/replay_app.cpp # apps/replay_app.cpp
@ -311,9 +311,9 @@ set(CPPSRC
apps/ui_settings.cpp apps/ui_settings.cpp
apps/ui_siggen.cpp apps/ui_siggen.cpp
apps/ui_sonde.cpp apps/ui_sonde.cpp
apps/ui_spectrum_painter_image.cpp # apps/ui_spectrum_painter_image.cpp
apps/ui_spectrum_painter_text.cpp # apps/ui_spectrum_painter_text.cpp
apps/ui_spectrum_painter.cpp # apps/ui_spectrum_painter.cpp
apps/ui_ss_viewer.cpp apps/ui_ss_viewer.cpp
apps/ui_sstvtx.cpp apps/ui_sstvtx.cpp
apps/ui_subghzd.cpp apps/ui_subghzd.cpp

View File

@ -44,6 +44,16 @@ set(EXTCPPSRC
#lcr #lcr
external/jammer/main.cpp external/jammer/main.cpp
external/jammer/ui_jammer.cpp external/jammer/ui_jammer.cpp
#gpssim
external/gpssim/main.cpp
external/gpssim/gps_sim_app.cpp
#spainter
external/spainter/main.cpp
external/spainter/ui_spectrum_painter.cpp
external/spainter/ui_spectrum_painter_text.cpp
external/spainter/ui_spectrum_painter_image.cpp
) )
set(EXTAPPLIST set(EXTAPPLIST
@ -58,4 +68,6 @@ set(EXTAPPLIST
lge lge
lcr lcr
jammer jammer
gpssim
spainter
) )

View File

@ -28,6 +28,8 @@ MEMORY
ram_external_app_lge(rwx) : org = 0xEEF10000, len = 32k ram_external_app_lge(rwx) : org = 0xEEF10000, len = 32k
ram_external_app_lcr(rwx) : org = 0xEEF20000, len = 32k ram_external_app_lcr(rwx) : org = 0xEEF20000, len = 32k
ram_external_app_jammer(rwx) : org = 0xEEF30000, len = 32k ram_external_app_jammer(rwx) : org = 0xEEF30000, len = 32k
ram_external_app_gpssim(rwx) : org = 0xEEF40000, len = 32k
ram_external_app_spainter(rwx) : org = 0xEEF50000, len = 32k
} }
SECTIONS SECTIONS
@ -88,18 +90,30 @@ SECTIONS
} > ram_external_app_lge } > ram_external_app_lge
.external_app_lcr : ALIGN(4) SUBALIGN(4) .external_app_lcr : ALIGN(4) SUBALIGN(4)
{ {
KEEP(*(.external_app.app_lcr.application_information)); KEEP(*(.external_app.app_lcr.application_information));
*(*ui*external_app*lcr*); *(*ui*external_app*lcr*);
} > ram_external_app_lcr } > ram_external_app_lcr
.external_app_jammer : ALIGN(4) SUBALIGN(4) .external_app_jammer : ALIGN(4) SUBALIGN(4)
{ {
KEEP(*(.external_app.app_jammer.application_information)); KEEP(*(.external_app.app_jammer.application_information));
*(*ui*external_app*jammer*); *(*ui*external_app*jammer*);
} > ram_external_app_jammer } > ram_external_app_jammer
.external_app_gpssim : ALIGN(4) SUBALIGN(4)
{
KEEP(*(.external_app.app_gpssim.application_information));
*(*ui*external_app*gpssim*);
} > ram_external_app_gpssim
.external_app_spainter : ALIGN(4) SUBALIGN(4)
{
KEEP(*(.external_app.app_spainter.application_information));
*(*ui*external_app*spainter*);
} > ram_external_app_spainter
} }

View File

@ -36,7 +36,7 @@
using namespace portapack; using namespace portapack;
namespace fs = std::filesystem; namespace fs = std::filesystem;
namespace ui { namespace ui::external_app::gpssim {
void GpsSimAppView::set_ready() { void GpsSimAppView::set_ready() {
ready_signal = true; ready_signal = true;
@ -161,7 +161,8 @@ void GpsSimAppView::handle_replay_thread_done(const uint32_t return_code) {
GpsSimAppView::GpsSimAppView( GpsSimAppView::GpsSimAppView(
NavigationView& nav) NavigationView& nav)
: nav_(nav) { : nav_(nav) {
baseband::run_image(portapack::spi_flash::image_tag_gps); // baseband::run_image(portapack::spi_flash::image_tag_gps);
baseband::run_prepared_image(portapack::memory::map::m4_code.base());
add_children({ add_children({
&button_open, &button_open,
@ -211,4 +212,4 @@ void GpsSimAppView::set_parent_rect(const Rect new_parent_rect) {
waterfall.set_parent_rect(waterfall_rect); waterfall.set_parent_rect(waterfall_rect);
} }
} /* namespace ui */ } /* namespace ui::external_app::gpssim */

View File

@ -25,6 +25,7 @@
#define __GPS_SIM_APP_HPP__ #define __GPS_SIM_APP_HPP__
#include "app_settings.hpp" #include "app_settings.hpp"
#include "ui_language.hpp"
#include "radio_state.hpp" #include "radio_state.hpp"
#include "ui_widget.hpp" #include "ui_widget.hpp"
#include "ui_navigation.hpp" #include "ui_navigation.hpp"
@ -37,7 +38,7 @@
#include <string> #include <string>
#include <memory> #include <memory>
namespace ui { namespace ui::external_app::gpssim {
class GpsSimAppView : public View { class GpsSimAppView : public View {
public: public:
@ -108,7 +109,7 @@ class GpsSimAppView : public View {
Checkbox check_loop{ Checkbox check_loop{
{21 * 8, 2 * 16}, {21 * 8, 2 * 16},
4, 4,
"Loop", LanguageHelper::currentMessages[LANG_LOOP],
true}; true};
ImageButton button_play{ ImageButton button_play{
{28 * 8, 2 * 16, 2 * 8, 1 * 16}, {28 * 8, 2 * 16, 2 * 8, 1 * 16},
@ -142,6 +143,6 @@ class GpsSimAppView : public View {
}}; }};
}; };
} /* namespace ui */ } /* namespace ui::external_app::gpssim */
#endif /*__GPS_SIM_APP_HPP__*/ #endif /*__GPS_SIM_APP_HPP__*/

View File

@ -0,0 +1,82 @@
/*
* Copyright (C) 2023 Bernd Herzog
*
* 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 "ui.hpp"
#include "gps_sim_app.hpp"
#include "ui_navigation.hpp"
#include "external_app.hpp"
namespace ui::external_app::gpssim {
void initialize_app(ui::NavigationView& nav) {
nav.push<GpsSimAppView>();
}
} // namespace ui::external_app::gpssim
extern "C" {
__attribute__((section(".external_app.app_gpssim.application_information"), used)) application_information_t _application_information_gpssim = {
/*.memory_location = */ (uint8_t*)0x00000000,
/*.externalAppEntry = */ ui::external_app::gpssim::initialize_app,
/*.header_version = */ CURRENT_HEADER_VERSION,
/*.app_version = */ VERSION_MD5,
/*.app_name = */ "GPSSim",
/*.bitmap_data = */ {
0xC0,
0x07,
0xE0,
0x0F,
0x70,
0x1F,
0x78,
0x3E,
0x78,
0x3C,
0x78,
0x38,
0x78,
0x30,
0x78,
0x38,
0x78,
0x3C,
0x70,
0x1E,
0x70,
0x1F,
0xE0,
0x0F,
0xC0,
0x07,
0x80,
0x03,
0x20,
0x09,
0x50,
0x14,
},
/*.icon_color = */ ui::Color::green().v,
/*.menu_location = */ app_location_t::TX,
/*.m4_app_tag = portapack::spi_flash::image_tag_gpssim */ {'P', 'G', 'P', 'S'},
/*.m4_app_offset = */ 0x00000000, // will be filled at compile time
};
}

View File

@ -0,0 +1,82 @@
/*
* Copyright (C) 2023 Bernd Herzog
*
* 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 "ui.hpp"
#include "ui_spectrum_painter.hpp"
#include "ui_navigation.hpp"
#include "external_app.hpp"
namespace ui::external_app::spainter {
void initialize_app(ui::NavigationView& nav) {
nav.push<SpectrumPainterView>();
}
} // namespace ui::external_app::spainter
extern "C" {
__attribute__((section(".external_app.app_spainter.application_information"), used)) application_information_t _application_information_spainter = {
/*.memory_location = */ (uint8_t*)0x00000000,
/*.externalAppEntry = */ ui::external_app::spainter::initialize_app,
/*.header_version = */ CURRENT_HEADER_VERSION,
/*.app_version = */ VERSION_MD5,
/*.app_name = */ "S.Painter",
/*.bitmap_data = */ {
0xFE,
0x3F,
0xFF,
0x3F,
0xFF,
0xFF,
0xFF,
0xBF,
0xFE,
0xBF,
0x00,
0x80,
0x80,
0xFF,
0x80,
0x00,
0x80,
0x00,
0xC0,
0x01,
0xC0,
0x01,
0xC0,
0x01,
0xC0,
0x01,
0xC0,
0x01,
0xC0,
0x01,
0xC0,
0x01,
},
/*.icon_color = */ ui::Color::orange().v,
/*.menu_location = */ app_location_t::TX,
/*.m4_app_tag = portapack::spi_flash::image_tag_spainter */ {'P', 'S', 'P', 'T'},
/*.m4_app_offset = */ 0x00000000, // will be filled at compile time
};
}

View File

@ -31,12 +31,13 @@
using namespace portapack; using namespace portapack;
namespace ui { namespace ui::external_app::spainter {
SpectrumPainterView::SpectrumPainterView( SpectrumPainterView::SpectrumPainterView(
NavigationView& nav) NavigationView& nav)
: nav_(nav) { : nav_(nav) {
baseband::run_image(spi_flash::image_tag_spectrum_painter); // baseband::run_image(spi_flash::image_tag_spectrum_painter);
baseband::run_prepared_image(portapack::memory::map::m4_code.base());
add_children({ add_children({
&labels, &labels,
@ -198,4 +199,4 @@ void SpectrumPainterView::paint(Painter& painter) {
} }
} }
} // namespace ui } // namespace ui::external_app::spainter

View File

@ -22,6 +22,7 @@
#pragma once #pragma once
#include "ui.hpp" #include "ui.hpp"
#include "ui_language.hpp"
#include "ui_widget.hpp" #include "ui_widget.hpp"
#include "ui_navigation.hpp" #include "ui_navigation.hpp"
@ -37,7 +38,7 @@
#include "ui_spectrum_painter_image.hpp" #include "ui_spectrum_painter_image.hpp"
#include "ui_spectrum_painter_text.hpp" #include "ui_spectrum_painter_text.hpp"
namespace ui { namespace ui::external_app::spainter {
class SpectrumPainterView : public View { class SpectrumPainterView : public View {
public: public:
@ -115,7 +116,7 @@ class SpectrumPainterView : public View {
Checkbox check_loop{ Checkbox check_loop{
{21 * 8, footer_location + 1 * 16}, {21 * 8, footer_location + 1 * 16},
4, 4,
"Loop", LanguageHelper::currentMessages[LANG_LOOP],
true}; true};
ImageButton button_play{ ImageButton button_play{
@ -163,4 +164,4 @@ class SpectrumPainterView : public View {
}}; }};
}; };
} // namespace ui } // namespace ui::external_app::spainter

View File

@ -29,7 +29,7 @@
#include "file.hpp" #include "file.hpp"
#include "portapack_persistent_memory.hpp" #include "portapack_persistent_memory.hpp"
namespace ui { namespace ui::external_app::spainter {
SpectrumInputImageView::SpectrumInputImageView(NavigationView& nav) { SpectrumInputImageView::SpectrumInputImageView(NavigationView& nav) {
hidden(true); hidden(true);
@ -254,4 +254,4 @@ void SpectrumInputImageView::paint(Painter& painter) {
} }
} }
} // namespace ui } // namespace ui::external_app::spainter

View File

@ -32,7 +32,7 @@
#include "portapack.hpp" #include "portapack.hpp"
#include "message.hpp" #include "message.hpp"
namespace ui { namespace ui::external_app::spainter {
class SpectrumInputImageView : public View { class SpectrumInputImageView : public View {
public: public:
@ -63,4 +63,4 @@ class SpectrumInputImageView : public View {
bool drawBMP_scaled(const ui::Rect r, const std::string file); bool drawBMP_scaled(const ui::Rect r, const std::string file);
}; };
} // namespace ui } // namespace ui::external_app::spainter

View File

@ -30,7 +30,7 @@
#include "file.hpp" #include "file.hpp"
#include "portapack_persistent_memory.hpp" #include "portapack_persistent_memory.hpp"
namespace ui { namespace ui::external_app::spainter {
SpectrumInputTextView::SpectrumInputTextView(NavigationView& nav) { SpectrumInputTextView::SpectrumInputTextView(NavigationView& nav) {
hidden(true); hidden(true);
@ -105,4 +105,4 @@ std::vector<uint8_t> SpectrumInputTextView::get_line(uint16_t y) {
return data; return data;
} }
} // namespace ui } // namespace ui::external_app::spainter

View File

@ -32,7 +32,7 @@
#include "portapack.hpp" #include "portapack.hpp"
#include "message.hpp" #include "message.hpp"
namespace ui { namespace ui::external_app::spainter {
class SpectrumInputTextView : public View { class SpectrumInputTextView : public View {
public: public:
@ -109,4 +109,4 @@ class SpectrumInputTextView : public View {
"Set message"}; "Set message"};
}; };
} // namespace ui } // namespace ui::external_app::spainter

View File

@ -70,7 +70,7 @@
#include "ui_settings.hpp" #include "ui_settings.hpp"
#include "ui_siggen.hpp" #include "ui_siggen.hpp"
#include "ui_sonde.hpp" #include "ui_sonde.hpp"
#include "ui_spectrum_painter.hpp" // #include "ui_spectrum_painter.hpp" //moved to ext app
#include "ui_ss_viewer.hpp" #include "ui_ss_viewer.hpp"
#include "ui_sstvtx.hpp" #include "ui_sstvtx.hpp"
#include "ui_styles.hpp" #include "ui_styles.hpp"
@ -93,7 +93,7 @@
#include "ble_tx_app.hpp" #include "ble_tx_app.hpp"
#include "capture_app.hpp" #include "capture_app.hpp"
#include "ert_app.hpp" #include "ert_app.hpp"
#include "gps_sim_app.hpp" // #include "gps_sim_app.hpp" //moved to ext
// #include "lge_app.hpp" //moved to ext // #include "lge_app.hpp" //moved to ext
#include "pocsag_app.hpp" #include "pocsag_app.hpp"
#include "replay_app.hpp" #include "replay_app.hpp"
@ -607,7 +607,7 @@ TransmittersMenuView::TransmittersMenuView(NavigationView& nav) {
{"BHT Xy/EP", ui::Color::green(), &bitmap_icon_bht, [&nav]() { nav.push<BHTView>(); }}, {"BHT Xy/EP", ui::Color::green(), &bitmap_icon_bht, [&nav]() { nav.push<BHTView>(); }},
{"BLE Tx", ui::Color::green(), &bitmap_icon_btle, [&nav]() { nav.push<BLETxView>(); }}, {"BLE Tx", ui::Color::green(), &bitmap_icon_btle, [&nav]() { nav.push<BLETxView>(); }},
// {"BurgerPgr", ui::Color::yellow(), &bitmap_icon_burger, [&nav]() { nav.push<CoasterPagerView>(); }}, //moved to ext // {"BurgerPgr", ui::Color::yellow(), &bitmap_icon_burger, [&nav]() { nav.push<CoasterPagerView>(); }}, //moved to ext
{"GPS Sim", ui::Color::green(), &bitmap_icon_gps_sim, [&nav]() { nav.push<GpsSimAppView>(); }}, //{"GPS Sim", ui::Color::green(), &bitmap_icon_gps_sim, [&nav]() { nav.push<GpsSimAppView>(); }}, //moved to ext
//{"Jammer", ui::Color::green(), &bitmap_icon_jammer, [&nav]() { nav.push<JammerView>(); }}, //moved to ext //{"Jammer", ui::Color::green(), &bitmap_icon_jammer, [&nav]() { nav.push<JammerView>(); }}, //moved to ext
// { "Key fob", ui::Color::orange(), &bitmap_icon_keyfob, [&nav](){ nav.push<KeyfobView>(); }}, // { "Key fob", ui::Color::orange(), &bitmap_icon_keyfob, [&nav](){ nav.push<KeyfobView>(); }},
// {"LGE", ui::Color::yellow(), &bitmap_icon_lge, [&nav]() { nav.push<LGEView>(); }}, //moved to ext // {"LGE", ui::Color::yellow(), &bitmap_icon_lge, [&nav]() { nav.push<LGEView>(); }}, //moved to ext
@ -617,7 +617,7 @@ TransmittersMenuView::TransmittersMenuView(NavigationView& nav) {
{"POCSAG TX", ui::Color::green(), &bitmap_icon_pocsag, [&nav]() { nav.push<POCSAGTXView>(); }}, {"POCSAG TX", ui::Color::green(), &bitmap_icon_pocsag, [&nav]() { nav.push<POCSAGTXView>(); }},
{"RDS", ui::Color::green(), &bitmap_icon_rds, [&nav]() { nav.push<RDSView>(); }}, {"RDS", ui::Color::green(), &bitmap_icon_rds, [&nav]() { nav.push<RDSView>(); }},
{"Soundbrd", ui::Color::green(), &bitmap_icon_soundboard, [&nav]() { nav.push<SoundBoardView>(); }}, {"Soundbrd", ui::Color::green(), &bitmap_icon_soundboard, [&nav]() { nav.push<SoundBoardView>(); }},
{"S.Painter", ui::Color::orange(), &bitmap_icon_paint, [&nav]() { nav.push<SpectrumPainterView>(); }}, //{"S.Painter", ui::Color::orange(), &bitmap_icon_paint, [&nav]() { nav.push<SpectrumPainterView>(); }},
{"SSTV", ui::Color::green(), &bitmap_icon_sstv, [&nav]() { nav.push<SSTVTXView>(); }}, {"SSTV", ui::Color::green(), &bitmap_icon_sstv, [&nav]() { nav.push<SSTVTXView>(); }},
// {"TEDI/LCR", ui::Color::yellow(), &bitmap_icon_lcr, [&nav]() { nav.push<LCRView>(); }}, //moved to ext // {"TEDI/LCR", ui::Color::yellow(), &bitmap_icon_lcr, [&nav]() { nav.push<LCRView>(); }}, //moved to ext
{"TouchTune", ui::Color::green(), &bitmap_icon_touchtunes, [&nav]() { nav.push<TouchTunesView>(); }}, {"TouchTune", ui::Color::green(), &bitmap_icon_touchtunes, [&nav]() { nav.push<TouchTunesView>(); }},

View File

@ -476,13 +476,6 @@ set(MODE_CPPSRC
) )
DeclareTargets(PREP replay) DeclareTargets(PREP replay)
### GPS Simulator
set(MODE_CPPSRC
proc_gps_sim.cpp
)
DeclareTargets(PGPS gps_sim)
### Signal generator ### Signal generator
set(MODE_CPPSRC set(MODE_CPPSRC
@ -490,12 +483,6 @@ set(MODE_CPPSRC
) )
DeclareTargets(PSIG siggen) DeclareTargets(PSIG siggen)
### Spectrum painter
set(MODE_CPPSRC
proc_spectrum_painter.cpp
)
DeclareTargets(PSPT spectrum_painter)
### SSTV TX ### SSTV TX
@ -637,6 +624,20 @@ set(MODE_CPPSRC
) )
DeclareTargets(PAMT am_tv) DeclareTargets(PAMT am_tv)
### GPS Simulator
set(MODE_CPPSRC
proc_gps_sim.cpp
)
DeclareTargets(PGPS gps_sim)
### Spectrum painter
set(MODE_CPPSRC
proc_spectrum_painter.cpp
)
DeclareTargets(PSPT spectrum_painter)
### Test ### Test
set(MODE_CPPSRC set(MODE_CPPSRC

View File

@ -1,6 +1,6 @@
#include "ui_language.hpp" #include "ui_language.hpp"
const char* LanguageHelper::englishMessages[] = {"OK", "Cancel", "Error", "Modem setup", "Debug", "Log", "Done", "Start", "Stop", "Scan", "Clear", "Ready", "Data:"}; const char* LanguageHelper::englishMessages[] = {"OK", "Cancel", "Error", "Modem setup", "Debug", "Log", "Done", "Start", "Stop", "Scan", "Clear", "Ready", "Data:", "Loop"};
const char** LanguageHelper::currentMessages = englishMessages; const char** LanguageHelper::currentMessages = englishMessages;

View File

@ -18,7 +18,8 @@ enum LangConsts {
LANG_SCAN, LANG_SCAN,
LANG_CLEAR, LANG_CLEAR,
LANG_READY, LANG_READY,
LANG_DATADP LANG_DATADP,
LANG_LOOP
}; };
class LanguageHelper { class LanguageHelper {