mirror of
https://github.com/eried/portapack-mayhem.git
synced 2024-10-01 01:26:06 -04:00
Introduce common app list for menu and serial (#1791)
This commit is contained in:
parent
ea8563cb19
commit
ce1084abc7
@ -346,6 +346,7 @@ set(CPPSRC
|
|||||||
${CPLD_20170522_DATA_CPP}
|
${CPLD_20170522_DATA_CPP}
|
||||||
${HACKRF_CPLD_DATA_CPP}
|
${HACKRF_CPLD_DATA_CPP}
|
||||||
ui_external_items_menu_loader.cpp
|
ui_external_items_menu_loader.cpp
|
||||||
|
view_factory_base.cpp
|
||||||
|
|
||||||
${EXTCPPSRC}
|
${EXTCPPSRC}
|
||||||
)
|
)
|
||||||
|
@ -111,166 +111,109 @@ namespace pmem = portapack::persistent_memory;
|
|||||||
|
|
||||||
namespace ui {
|
namespace ui {
|
||||||
|
|
||||||
// When adding or removing apps from the Menu, please update it here:
|
bool CstrCmp::operator()(const char* a, const char* b) const {
|
||||||
std::vector<AppInfoConsole> NavigationView::fixedAppListFC = {
|
return strcmp(a, b) < 0;
|
||||||
{"adsbrx", "ADS-B", RX},
|
}
|
||||||
{"ais", "AIS Boats", RX},
|
|
||||||
{"aprsrx", "APRS", RX},
|
static NavigationView::AppMap generate_app_map(const NavigationView::AppList& appList) {
|
||||||
{"audio", "Audio", RX},
|
NavigationView::AppMap out;
|
||||||
{"blerx", "BLE Rx", RX},
|
|
||||||
{"ert", "ERT Meter", RX},
|
for (auto& app : appList) {
|
||||||
{"level", "Level", RX},
|
if (app.id == nullptr) {
|
||||||
{"pocsagrx", "POCSAG", RX},
|
// Skip items with no id
|
||||||
{"radiosnde", "Radiosnde", RX},
|
continue;
|
||||||
{"recon", "Recon", RX},
|
}
|
||||||
{"search", "Search", RX},
|
|
||||||
{"tpms", "TPMS Cars", RX},
|
auto res = out.emplace(app.id, app);
|
||||||
{"weather", "Weather", RX},
|
if (!res.second) {
|
||||||
{"subghzd", "SubGhzD", RX},
|
chDbgPanic("Application cannot be added, ID not unique!");
|
||||||
{"adsbtx", "ADS-B", TX},
|
}
|
||||||
{"aprstx", "APRS TX", TX},
|
}
|
||||||
{"bht", "BHT Xy/EP", TX},
|
|
||||||
{"bletx", "BLE Tx", TX},
|
return out;
|
||||||
{"morsetx", "Morse", TX},
|
}
|
||||||
{"ooktx", "OOK", TX},
|
|
||||||
{"pocsatx", "POCSAG TX", TX},
|
// TODO(u-foka): Check consistency of command names (where we add rx/tx postfix)
|
||||||
{"rdstx", "RDS TX", TX},
|
const NavigationView::AppList NavigationView::appList = {
|
||||||
{"soundbrd", "Soundbrd", TX},
|
/* HOME ******************************************************************/
|
||||||
{"sstvtx", "SSTV", TX},
|
//{"playdead", "Play dead", HOME, Color::red(), &bitmap_icon_playdead, new ViewFactory<PlayDeadView>()},
|
||||||
{"touchtune", "TouchTune", TX},
|
{nullptr, "Receive", HOME, Color::cyan(), &bitmap_icon_receivers, new ViewFactory<ReceiversMenuView>()},
|
||||||
{"capture", "Capture", RX},
|
{nullptr, "Transmit", HOME, Color::cyan(), &bitmap_icon_transmit, new ViewFactory<TransmittersMenuView>()},
|
||||||
{"replay", "Replay", TX},
|
{"capture", "Capture", HOME, Color::red(), &bitmap_icon_capture, new ViewFactory<CaptureAppView>()},
|
||||||
{"remote", "Remote", TX},
|
{"replay", "Replay", HOME, Color::green(), &bitmap_icon_replay, new ViewFactory<PlaylistView>()},
|
||||||
{"scanner", "Scanner", RX},
|
{"remote", "Remote", HOME, ui::Color::green(), &bitmap_icon_remote, new ViewFactory<RemoteView>()},
|
||||||
{"microphone", "Microphone", TX},
|
{"scanner", "Scanner", HOME, Color::green(), &bitmap_icon_scanner, new ViewFactory<ScannerView>()},
|
||||||
{"lookingglass", "Looking Glass", RX}};
|
{"microphone", "Microphone", HOME, Color::green(), &bitmap_icon_microphone, new ViewFactory<MicTXView>()},
|
||||||
|
{"lookingglass", "Looking Glass", HOME, Color::green(), &bitmap_icon_looking, new ViewFactory<GlassView>()},
|
||||||
|
{nullptr, "Utilities", HOME, Color::cyan(), &bitmap_icon_utilities, new ViewFactory<UtilitiesMenuView>()},
|
||||||
|
{nullptr, "Settings", HOME, Color::cyan(), &bitmap_icon_setup, new ViewFactory<SettingsMenuView>()},
|
||||||
|
{nullptr, "Debug", HOME, Color::light_grey(), &bitmap_icon_debug, new ViewFactory<DebugMenuView>()},
|
||||||
|
//{"about", "About", HOME, Color::cyan(), nullptr, new ViewFactory<AboutView>()},
|
||||||
|
/* RX ********************************************************************/
|
||||||
|
//{"acars", "ACARS", RX, Color::yellow(), &bitmap_icon_adsb, new ViewFactory<ACARSAppView>()},
|
||||||
|
{"adsbrx", "ADS-B", RX, Color::green(), &bitmap_icon_adsb, new ViewFactory<ADSBRxView>()},
|
||||||
|
{"ais", "AIS Boats", RX, Color::green(), &bitmap_icon_ais, new ViewFactory<AISAppView>()},
|
||||||
|
{"aprsrx", "APRS", RX, Color::green(), &bitmap_icon_aprs, new ViewFactory<APRSRXView>()},
|
||||||
|
{"audio", "Audio", RX, Color::green(), &bitmap_icon_speaker, new ViewFactory<AnalogAudioView>()},
|
||||||
|
//{"btle", "BTLE", RX, Color::yellow(), &bitmap_icon_btle, new ViewFactory<BTLERxView>()},
|
||||||
|
//{"blecomm", "BLE Comm", RX, ui::Color::orange(), &bitmap_icon_btle, new ViewFactory<BLECommView>()},
|
||||||
|
{"blerx", "BLE Rx", RX, Color::green(), &bitmap_icon_btle, new ViewFactory<BLERxView>()},
|
||||||
|
{"ert", "ERT Meter", RX, Color::green(), &bitmap_icon_ert, new ViewFactory<ERTAppView>()},
|
||||||
|
{"level", "Level", RX, Color::green(), &bitmap_icon_options_radio, new ViewFactory<LevelView>()},
|
||||||
|
{"pocsag", "POCSAG", RX, Color::green(), &bitmap_icon_pocsag, new ViewFactory<POCSAGAppView>()},
|
||||||
|
{"radiosonde", "Radiosnde", RX, Color::green(), &bitmap_icon_sonde, new ViewFactory<SondeView>()},
|
||||||
|
{"recon", "Recon", RX, Color::green(), &bitmap_icon_scanner, new ViewFactory<ReconView>()},
|
||||||
|
{"search", "Search", RX, Color::yellow(), &bitmap_icon_search, new ViewFactory<SearchView>()},
|
||||||
|
{"tmps", "TPMS Cars", RX, Color::green(), &bitmap_icon_tpms, new ViewFactory<TPMSAppView>()},
|
||||||
|
{"weather", "Weather", RX, Color::green(), &bitmap_icon_thermometer, new ViewFactory<WeatherView>()},
|
||||||
|
{"subghzd", "SubGhzD", RX, Color::yellow(), &bitmap_icon_remote, new ViewFactory<SubGhzDView>()},
|
||||||
|
//{"fskrx", "FSK RX", RX, Color::yellow(), &bitmap_icon_remote, new ViewFactory<FskxRxMainView>()},
|
||||||
|
//{"dmr", "DMR", RX, Color::dark_grey(), &bitmap_icon_dmr, new ViewFactory<NotImplementedView>()},
|
||||||
|
//{"sigfox", "SIGFOX", RX, Color::dark_grey(), &bitmap_icon_fox, new ViewFactory<NotImplementedView>()},
|
||||||
|
//{"lora", "LoRa", RX, Color::dark_grey(), &bitmap_icon_lora, new ViewFactory<NotImplementedView>()},
|
||||||
|
//{"sstv", "SSTV", RX, Color::dark_grey(), &bitmap_icon_sstv, new ViewFactory<NotImplementedView>()},
|
||||||
|
//{"tetra", "TETRA", RX, Color::dark_grey(), &bitmap_icon_tetra, new ViewFactory<NotImplementedView>()},
|
||||||
|
/* TX ********************************************************************/
|
||||||
|
{"adsbtx", "ADS-B TX", TX, ui::Color::green(), &bitmap_icon_adsb, new ViewFactory<ADSBTxView>()},
|
||||||
|
{"aprstx", "APRS TX", TX, ui::Color::green(), &bitmap_icon_aprs, new ViewFactory<APRSTXView>()},
|
||||||
|
{"bht", "BHT Xy/EP", TX, ui::Color::green(), &bitmap_icon_bht, new ViewFactory<BHTView>()},
|
||||||
|
{"bletx", "BLE Tx", TX, ui::Color::green(), &bitmap_icon_btle, new ViewFactory<BLETxView>()},
|
||||||
|
//{"keyfob", "Key fob", TX, ui::Color::orange(), &bitmap_icon_keyfob, new ViewFactory<KeyfobView>()},
|
||||||
|
{"morse", "Morse", TX, ui::Color::green(), &bitmap_icon_morse, new ViewFactory<MorseView>()},
|
||||||
|
//{"nuoptixdtmf", "Nuoptix DTMF", TX, ui::Color::green(), &bitmap_icon_nuoptix, new ViewFactory<NuoptixView>()},
|
||||||
|
{"ooktx", "OOK", TX, ui::Color::yellow(), &bitmap_icon_remote, new ViewFactory<EncodersView>()},
|
||||||
|
{"pocsagtx", "POCSAG TX", TX, ui::Color::green(), &bitmap_icon_pocsag, new ViewFactory<POCSAGTXView>()},
|
||||||
|
{"rdstx", "RDS", TX, ui::Color::green(), &bitmap_icon_rds, new ViewFactory<RDSView>()},
|
||||||
|
{"soundbrd", "Soundbrd", TX, ui::Color::green(), &bitmap_icon_soundboard, new ViewFactory<SoundBoardView>()},
|
||||||
|
{"sstvtx", "SSTV", TX, ui::Color::green(), &bitmap_icon_sstv, new ViewFactory<SSTVTXView>()},
|
||||||
|
{"touchtune", "TouchTune", TX, ui::Color::green(), &bitmap_icon_touchtunes, new ViewFactory<TouchTunesView>()},
|
||||||
|
/* UTILITIES *************************************************************/
|
||||||
|
{"antennalength", "Antenna Length", UTILITIES, Color::green(), &bitmap_icon_tools_antenna, new ViewFactory<WhipCalcView>()},
|
||||||
|
{"filemanager", "File Manager", UTILITIES, Color::green(), &bitmap_icon_dir, new ViewFactory<FileManagerView>()},
|
||||||
|
{"freqman", "Freq. Manager", UTILITIES, Color::green(), &bitmap_icon_freqman, new ViewFactory<FrequencyManagerView>()},
|
||||||
|
{"notepad", "Notepad", UTILITIES, Color::dark_cyan(), &bitmap_icon_notepad, new ViewFactory<TextEditorView>()},
|
||||||
|
{"iqtrim", "IQ Trim", UTILITIES, Color::orange(), &bitmap_icon_trim, new ViewFactory<IQTrimView>()},
|
||||||
|
{nullptr, "SD Over USB", UTILITIES, Color::yellow(), &bitmap_icon_hackrf, new ViewFactory<SdOverUsbView>()},
|
||||||
|
{"signalgen", "Signal Gen", UTILITIES, Color::green(), &bitmap_icon_cwgen, new ViewFactory<SigGenView>()},
|
||||||
|
//{"testapp", "Test App", UTILITIES, Color::dark_grey(), nullptr, new ViewFactory<TestView>()},
|
||||||
|
//{"tonesearch", "Tone Search", UTILITIES, Color::dark_grey(), nullptr, new ViewFactory<ToneSearchView>()},
|
||||||
|
{"wavview", "Wav View", UTILITIES, Color::yellow(), &bitmap_icon_soundboard, new ViewFactory<ViewWavView>()},
|
||||||
|
// Dangerous apps.
|
||||||
|
{nullptr, "Flash Utility", UTILITIES, Color::red(), &bitmap_icon_temperature, new ViewFactory<FlashUtilityView>()},
|
||||||
|
{nullptr, "Wipe SD card", UTILITIES, Color::red(), &bitmap_icon_tools_wipesd, new ViewFactory<WipeSDView>()},
|
||||||
|
};
|
||||||
|
|
||||||
|
const NavigationView::AppMap NavigationView::appMap = generate_app_map(NavigationView::appList);
|
||||||
|
|
||||||
bool NavigationView::StartAppByName(const char* name) {
|
bool NavigationView::StartAppByName(const char* name) {
|
||||||
home(false);
|
home(false);
|
||||||
if (strcmp(name, "adsbrx") == 0) {
|
|
||||||
push<ADSBRxView>();
|
auto it = appMap.find(name);
|
||||||
return true;
|
if (it != appMap.end()) {
|
||||||
}
|
push_view(std::unique_ptr<View>(it->second.viewFactory->produce(*this)));
|
||||||
if (strcmp(name, "ais") == 0) {
|
|
||||||
push<AISAppView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "aprsrx") == 0) {
|
|
||||||
push<APRSRXView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "audio") == 0) {
|
|
||||||
push<AnalogAudioView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "blerx") == 0) {
|
|
||||||
push<BLERxView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "ert") == 0) {
|
|
||||||
push<ERTAppView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "level") == 0) {
|
|
||||||
push<LevelView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "pocsagrx") == 0) {
|
|
||||||
push<POCSAGAppView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "radiosnode") == 0) {
|
|
||||||
push<SondeView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "recon") == 0) {
|
|
||||||
push<ReconView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "search") == 0) {
|
|
||||||
push<SearchView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "tpms") == 0) {
|
|
||||||
push<TPMSAppView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "weather") == 0) {
|
|
||||||
push<WeatherView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "subghzd") == 0) {
|
|
||||||
push<SubGhzDView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "adsbtx") == 0) {
|
|
||||||
push<ADSBTxView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "aprstx") == 0) {
|
|
||||||
push<APRSTXView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "bht") == 0) {
|
|
||||||
push<BHTView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "bletx") == 0) {
|
|
||||||
push<BLETxView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "morsetx") == 0) {
|
|
||||||
push<MorseView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "ooktx") == 0) {
|
|
||||||
push<EncodersView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "pocsatx") == 0) {
|
|
||||||
push<POCSAGTXView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "rdstx") == 0) {
|
|
||||||
push<RDSView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "soundbrd") == 0) {
|
|
||||||
push<SoundBoardView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "sstvtx") == 0) {
|
|
||||||
push<SSTVTXView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "touchtune") == 0) {
|
|
||||||
push<TouchTunesView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "capture") == 0) {
|
|
||||||
push<CaptureAppView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "replay") == 0) {
|
|
||||||
push<PlaylistView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "remote") == 0) {
|
|
||||||
push<RemoteView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "scanner") == 0) {
|
|
||||||
push<ScannerView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "microphone") == 0) {
|
|
||||||
push<MicTXView>();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (strcmp(name, "lookingglass") == 0) {
|
|
||||||
push<GlassView>();
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -727,39 +670,25 @@ bool NavigationView::set_on_pop(std::function<void()> on_pop) {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Helpers **************************************************************/
|
||||||
|
|
||||||
|
static void add_apps(NavigationView& nav, BtnGridView& grid, app_location_t loc) {
|
||||||
|
for (auto& app : NavigationView::appList) {
|
||||||
|
if (app.menuLocation == loc) {
|
||||||
|
grid.add_item({app.displayName, app.iconColor, app.icon,
|
||||||
|
[&nav, &app]() { nav.push_view(std::unique_ptr<View>(app.viewFactory->produce(nav))); }});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
/* ReceiversMenuView *****************************************************/
|
/* ReceiversMenuView *****************************************************/
|
||||||
|
|
||||||
ReceiversMenuView::ReceiversMenuView(NavigationView& nav) {
|
ReceiversMenuView::ReceiversMenuView(NavigationView& nav) {
|
||||||
if (pmem::show_gui_return_icon()) {
|
if (pmem::show_gui_return_icon()) {
|
||||||
add_items({{"..", Color::light_grey(), &bitmap_icon_previous, [&nav]() { nav.pop(); }}});
|
add_item({"..", Color::light_grey(), &bitmap_icon_previous, [&nav]() { nav.pop(); }});
|
||||||
}
|
}
|
||||||
add_items({
|
|
||||||
// {"ACARS", Color::yellow(), &bitmap_icon_adsb, [&nav](){ nav.push<ACARSAppView>(); }},
|
add_apps(nav, *this, RX);
|
||||||
{"ADS-B", Color::green(), &bitmap_icon_adsb, [&nav]() { nav.push<ADSBRxView>(); }},
|
|
||||||
{"AIS Boats", Color::green(), &bitmap_icon_ais, [&nav]() { nav.push<AISAppView>(); }},
|
|
||||||
//{"Analog TV", Color::yellow(), &bitmap_icon_sstv, [&nav]() { nav.push<AnalogTvView>(); }}, //moved to ext
|
|
||||||
{"APRS", Color::green(), &bitmap_icon_aprs, [&nav]() { nav.push<APRSRXView>(); }},
|
|
||||||
{"Audio", Color::green(), &bitmap_icon_speaker, [&nav]() { nav.push<AnalogAudioView>(); }},
|
|
||||||
//{"BTLE", Color::yellow(), &bitmap_icon_btle, [&nav]() { nav.push<BTLERxView>(); }},
|
|
||||||
//{"BLE Comm", ui::Color::orange(), &bitmap_icon_btle, [&nav]() { nav.push<BLECommView>(); }},
|
|
||||||
{"BLE Rx", Color::green(), &bitmap_icon_btle, [&nav]() { nav.push<BLERxView>(); }},
|
|
||||||
{"ERT Meter", Color::green(), &bitmap_icon_ert, [&nav]() { nav.push<ERTAppView>(); }},
|
|
||||||
{"Level", Color::green(), &bitmap_icon_options_radio, [&nav]() { nav.push<LevelView>(); }},
|
|
||||||
//{"NRF", Color::yellow(), &bitmap_icon_nrf, [&nav]() { nav.push<NRFRxView>(); }}, //moved to ext
|
|
||||||
{"POCSAG", Color::green(), &bitmap_icon_pocsag, [&nav]() { nav.push<POCSAGAppView>(); }},
|
|
||||||
{"Radiosnde", Color::green(), &bitmap_icon_sonde, [&nav]() { nav.push<SondeView>(); }},
|
|
||||||
{"Recon", Color::green(), &bitmap_icon_scanner, [&nav]() { nav.push<ReconView>(); }},
|
|
||||||
{"Search", Color::yellow(), &bitmap_icon_search, [&nav]() { nav.push<SearchView>(); }},
|
|
||||||
{"TPMS Cars", Color::green(), &bitmap_icon_tpms, [&nav]() { nav.push<TPMSAppView>(); }},
|
|
||||||
{"Weather", Color::green(), &bitmap_icon_thermometer, [&nav]() { nav.push<WeatherView>(); }},
|
|
||||||
{"SubGhzD", Color::yellow(), &bitmap_icon_remote, [&nav]() { nav.push<SubGhzDView>(); }},
|
|
||||||
// {"FSK RX", Color::yellow(), &bitmap_icon_remote, [&nav]() { nav.push<FskxRxMainView>(); }},
|
|
||||||
// {"DMR", Color::dark_grey(), &bitmap_icon_dmr, [&nav](){ nav.push<NotImplementedView>(); }},
|
|
||||||
// {"SIGFOX", Color::dark_grey(), &bitmap_icon_fox, [&nav](){ nav.push<NotImplementedView>(); }},
|
|
||||||
// {"LoRa", Color::dark_grey(), &bitmap_icon_lora, [&nav](){ nav.push<NotImplementedView>(); }},
|
|
||||||
// {"SSTV", Color::dark_grey(), &bitmap_icon_sstv, [&nav](){ nav.push<NotImplementedView>(); }},
|
|
||||||
// {"TETRA", Color::dark_grey(), &bitmap_icon_tetra, [&nav](){ nav.push<NotImplementedView>(); }},
|
|
||||||
});
|
|
||||||
|
|
||||||
for (auto const& gridItem : ExternalItemsMenuLoader::load_external_items(app_location_t::RX, nav)) {
|
for (auto const& gridItem : ExternalItemsMenuLoader::load_external_items(app_location_t::RX, nav)) {
|
||||||
add_item(gridItem);
|
add_item(gridItem);
|
||||||
@ -772,27 +701,8 @@ TransmittersMenuView::TransmittersMenuView(NavigationView& nav) {
|
|||||||
if (pmem::show_gui_return_icon()) {
|
if (pmem::show_gui_return_icon()) {
|
||||||
add_items({{"..", Color::light_grey(), &bitmap_icon_previous, [&nav]() { nav.pop(); }}});
|
add_items({{"..", Color::light_grey(), &bitmap_icon_previous, [&nav]() { nav.pop(); }}});
|
||||||
}
|
}
|
||||||
add_items({
|
|
||||||
{"ADS-B TX", ui::Color::green(), &bitmap_icon_adsb, [&nav]() { nav.push<ADSBTxView>(); }},
|
add_apps(nav, *this, TX);
|
||||||
{"APRS TX", ui::Color::green(), &bitmap_icon_aprs, [&nav]() { nav.push<APRSTXView>(); }},
|
|
||||||
{"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>(); }},
|
|
||||||
// {"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>(); }}, //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>(); }},
|
|
||||||
// {"LGE", ui::Color::yellow(), &bitmap_icon_lge, [&nav]() { nav.push<LGEView>(); }}, //moved to ext
|
|
||||||
{"Morse", ui::Color::green(), &bitmap_icon_morse, [&nav]() { nav.push<MorseView>(); }},
|
|
||||||
// { "Nuoptix DTMF", ui::Color::green(), &bitmap_icon_nuoptix, [&nav](){ nav.push<NuoptixView>(); }},
|
|
||||||
{"OOK", ui::Color::yellow(), &bitmap_icon_remote, [&nav]() { nav.push<EncodersView>(); }},
|
|
||||||
{"POCSAG TX", ui::Color::green(), &bitmap_icon_pocsag, [&nav]() { nav.push<POCSAGTXView>(); }},
|
|
||||||
{"RDS", ui::Color::green(), &bitmap_icon_rds, [&nav]() { nav.push<RDSView>(); }},
|
|
||||||
{"Soundbrd", ui::Color::green(), &bitmap_icon_soundboard, [&nav]() { nav.push<SoundBoardView>(); }},
|
|
||||||
//{"S.Painter", ui::Color::orange(), &bitmap_icon_paint, [&nav]() { nav.push<SpectrumPainterView>(); }},
|
|
||||||
{"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
|
|
||||||
{"TouchTune", ui::Color::green(), &bitmap_icon_touchtunes, [&nav]() { nav.push<TouchTunesView>(); }},
|
|
||||||
});
|
|
||||||
|
|
||||||
for (auto const& gridItem : ExternalItemsMenuLoader::load_external_items(app_location_t::TX, nav)) {
|
for (auto const& gridItem : ExternalItemsMenuLoader::load_external_items(app_location_t::TX, nav)) {
|
||||||
add_item(gridItem);
|
add_item(gridItem);
|
||||||
@ -805,22 +715,8 @@ UtilitiesMenuView::UtilitiesMenuView(NavigationView& nav) {
|
|||||||
if (pmem::show_gui_return_icon()) {
|
if (pmem::show_gui_return_icon()) {
|
||||||
add_items({{"..", Color::light_grey(), &bitmap_icon_previous, [&nav]() { nav.pop(); }}});
|
add_items({{"..", Color::light_grey(), &bitmap_icon_previous, [&nav]() { nav.pop(); }}});
|
||||||
}
|
}
|
||||||
add_items({
|
|
||||||
{"Antenna Length", Color::green(), &bitmap_icon_tools_antenna, [&nav]() { nav.push<WhipCalcView>(); }},
|
|
||||||
{"File Manager", Color::green(), &bitmap_icon_dir, [&nav]() { nav.push<FileManagerView>(); }},
|
|
||||||
{"Freq. Manager", Color::green(), &bitmap_icon_freqman, [&nav]() { nav.push<FrequencyManagerView>(); }},
|
|
||||||
{"Notepad", Color::dark_cyan(), &bitmap_icon_notepad, [&nav]() { nav.push<TextEditorView>(); }},
|
|
||||||
{"IQ Trim", Color::orange(), &bitmap_icon_trim, [&nav]() { nav.push<IQTrimView>(); }},
|
|
||||||
{"SD Over USB", Color::yellow(), &bitmap_icon_hackrf, [&nav]() { nav.push<SdOverUsbView>(); }},
|
|
||||||
{"Signal Gen", Color::green(), &bitmap_icon_cwgen, [&nav]() { nav.push<SigGenView>(); }},
|
|
||||||
// {"Test App", Color::dark_grey(), nullptr, [&nav](){ nav.push<TestView>(); }},
|
|
||||||
// {"Tone Search", Color::dark_grey(), nullptr, [&nav](){ nav.push<ToneSearchView>(); }},
|
|
||||||
{"Wav View", Color::yellow(), &bitmap_icon_soundboard, [&nav]() { nav.push<ViewWavView>(); }},
|
|
||||||
|
|
||||||
// Dangerous apps.
|
add_apps(nav, *this, UTILITIES);
|
||||||
{"Flash Utility", Color::red(), &bitmap_icon_temperature, [&nav]() { nav.push<FlashUtilityView>(); }},
|
|
||||||
{"Wipe SD card", Color::red(), &bitmap_icon_tools_wipesd, [&nav]() { nav.push<WipeSDView>(); }},
|
|
||||||
});
|
|
||||||
|
|
||||||
for (auto const& gridItem : ExternalItemsMenuLoader::load_external_items(app_location_t::UTILITIES, nav)) {
|
for (auto const& gridItem : ExternalItemsMenuLoader::load_external_items(app_location_t::UTILITIES, nav)) {
|
||||||
add_item(gridItem);
|
add_item(gridItem);
|
||||||
@ -844,22 +740,9 @@ void SystemMenuView::hackrf_mode(NavigationView& nav) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
SystemMenuView::SystemMenuView(NavigationView& nav) {
|
SystemMenuView::SystemMenuView(NavigationView& nav) {
|
||||||
add_items({
|
add_apps(nav, *this, HOME);
|
||||||
// {"Play dead", Color::red(), &bitmap_icon_playdead, [&nav]() { nav.push<PlayDeadView>(); }},
|
|
||||||
{"Receive", Color::cyan(), &bitmap_icon_receivers, [&nav]() { nav.push<ReceiversMenuView>(); }},
|
add_item({"HackRF", Color::cyan(), &bitmap_icon_hackrf, [this, &nav]() { hackrf_mode(nav); }});
|
||||||
{"Transmit", Color::cyan(), &bitmap_icon_transmit, [&nav]() { nav.push<TransmittersMenuView>(); }},
|
|
||||||
{"Capture", Color::red(), &bitmap_icon_capture, [&nav]() { nav.push<CaptureAppView>(); }},
|
|
||||||
{"Replay", Color::green(), &bitmap_icon_replay, [&nav]() { nav.push<PlaylistView>(); }},
|
|
||||||
{"Remote", ui::Color::green(), &bitmap_icon_remote, [&nav]() { nav.push<RemoteView>(); }},
|
|
||||||
{"Scanner", Color::green(), &bitmap_icon_scanner, [&nav]() { nav.push<ScannerView>(); }},
|
|
||||||
{"Microphone", Color::green(), &bitmap_icon_microphone, [&nav]() { nav.push<MicTXView>(); }},
|
|
||||||
{"Looking Glass", Color::green(), &bitmap_icon_looking, [&nav]() { nav.push<GlassView>(); }},
|
|
||||||
{"Utilities", Color::cyan(), &bitmap_icon_utilities, [&nav]() { nav.push<UtilitiesMenuView>(); }},
|
|
||||||
{"Settings", Color::cyan(), &bitmap_icon_setup, [&nav]() { nav.push<SettingsMenuView>(); }},
|
|
||||||
{"Debug", Color::light_grey(), &bitmap_icon_debug, [&nav]() { nav.push<DebugMenuView>(); }},
|
|
||||||
{"HackRF", Color::cyan(), &bitmap_icon_hackrf, [this, &nav]() { hackrf_mode(nav); }},
|
|
||||||
// {"About", Color::cyan(), nullptr, [&nav]() { nav.push<AboutView>(); }},
|
|
||||||
});
|
|
||||||
|
|
||||||
set_max_rows(2); // allow wider buttons
|
set_max_rows(2); // allow wider buttons
|
||||||
set_arrow_enabled(false);
|
set_arrow_enabled(false);
|
||||||
|
@ -23,6 +23,10 @@
|
|||||||
#ifndef __UI_NAVIGATION_H__
|
#ifndef __UI_NAVIGATION_H__
|
||||||
#define __UI_NAVIGATION_H__
|
#define __UI_NAVIGATION_H__
|
||||||
|
|
||||||
|
#include <vector>
|
||||||
|
#include <map>
|
||||||
|
#include <utility>
|
||||||
|
|
||||||
#include "ui.hpp"
|
#include "ui.hpp"
|
||||||
#include "ui_widget.hpp"
|
#include "ui_widget.hpp"
|
||||||
#include "ui_focus.hpp"
|
#include "ui_focus.hpp"
|
||||||
@ -41,8 +45,7 @@
|
|||||||
#include "lfsr_random.hpp"
|
#include "lfsr_random.hpp"
|
||||||
#include "sd_card.hpp"
|
#include "sd_card.hpp"
|
||||||
#include "external_app.hpp"
|
#include "external_app.hpp"
|
||||||
#include <vector>
|
#include "view_factory.hpp"
|
||||||
#include <utility>
|
|
||||||
|
|
||||||
// for incrementing fake date when RTC battery is dead
|
// for incrementing fake date when RTC battery is dead
|
||||||
#define DATE_FILEFLAG u"/SETTINGS/DATE_FILEFLAG"
|
#define DATE_FILEFLAG u"/SETTINGS/DATE_FILEFLAG"
|
||||||
@ -57,6 +60,22 @@ enum modal_t {
|
|||||||
ABORT
|
ABORT
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class CstrCmp {
|
||||||
|
public:
|
||||||
|
bool operator()(const char* a, const char* b) const;
|
||||||
|
};
|
||||||
|
|
||||||
|
// Should only be used as part of the appList in NavigationView, the viewFactory will never be destroyed.
|
||||||
|
class AppInfo {
|
||||||
|
public:
|
||||||
|
const char* id; // MUST be unique! Used by serial command to start the app so it also has to make sense
|
||||||
|
const char* displayName;
|
||||||
|
app_location_t menuLocation;
|
||||||
|
Color iconColor;
|
||||||
|
const Bitmap* icon;
|
||||||
|
ViewFactoryBase* viewFactory; // Never destroyed, and I believe it's ok ;) Having a unique_ptr here breaks the initializer list of appList
|
||||||
|
};
|
||||||
|
|
||||||
struct AppInfoConsole {
|
struct AppInfoConsole {
|
||||||
const char* appCallName;
|
const char* appCallName;
|
||||||
const char* appFriendlyName;
|
const char* appFriendlyName;
|
||||||
@ -106,8 +125,14 @@ class NavigationView : public View {
|
|||||||
* Returns true if the handler was bound successfully. */
|
* Returns true if the handler was bound successfully. */
|
||||||
bool set_on_pop(std::function<void()> on_pop);
|
bool set_on_pop(std::function<void()> on_pop);
|
||||||
|
|
||||||
static std::vector<AppInfoConsole> fixedAppListFC; // fixed app list for console. vector, so can be incomplete and still iterateable
|
// App list is used to preserve order, so the menu items in the menu grid can stay in place
|
||||||
bool StartAppByName(const char* name); // Starts a View (app) by name stored in fixedAppListFC. This is to start apps from console
|
// App map is used to look up apps by id used by serial app start
|
||||||
|
using AppMap = std::map<const char*, const AppInfo&, CstrCmp>;
|
||||||
|
using AppList = std::vector<AppInfo>;
|
||||||
|
static const AppMap appMap;
|
||||||
|
static const AppList appList;
|
||||||
|
|
||||||
|
bool StartAppByName(const char* name); // Starts a View (app) by name stored in appListFC. This is to start apps from console
|
||||||
private:
|
private:
|
||||||
struct ViewState {
|
struct ViewState {
|
||||||
std::unique_ptr<View> view;
|
std::unique_ptr<View> view;
|
||||||
|
@ -710,6 +710,30 @@ static void printAppInfo(BaseSequentialStream* chp, ui::AppInfoConsole& element)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void printAppInfo(BaseSequentialStream* chp, const ui::AppInfo& element) {
|
||||||
|
if (strlen(element.id) == 0) return;
|
||||||
|
chprintf(chp, element.id);
|
||||||
|
chprintf(chp, " ");
|
||||||
|
chprintf(chp, element.displayName);
|
||||||
|
chprintf(chp, " ");
|
||||||
|
switch (element.menuLocation) {
|
||||||
|
case RX:
|
||||||
|
chprintf(chp, "[RX]\r\n");
|
||||||
|
break;
|
||||||
|
case TX:
|
||||||
|
chprintf(chp, "[TX]\r\n");
|
||||||
|
break;
|
||||||
|
case UTILITIES:
|
||||||
|
chprintf(chp, "[UTIL]\r\n");
|
||||||
|
break;
|
||||||
|
case DEBUG:
|
||||||
|
chprintf(chp, "[DEBUG]\r\n");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// returns the installed apps, those can be called by appstart APPNAME
|
// returns the installed apps, those can be called by appstart APPNAME
|
||||||
static void cmd_applist(BaseSequentialStream* chp, int argc, char* argv[]) {
|
static void cmd_applist(BaseSequentialStream* chp, int argc, char* argv[]) {
|
||||||
(void)argc;
|
(void)argc;
|
||||||
@ -720,8 +744,9 @@ static void cmd_applist(BaseSequentialStream* chp, int argc, char* argv[]) {
|
|||||||
if (!top_widget) return;
|
if (!top_widget) return;
|
||||||
auto nav = static_cast<ui::SystemView*>(top_widget)->get_navigation_view();
|
auto nav = static_cast<ui::SystemView*>(top_widget)->get_navigation_view();
|
||||||
if (!nav) return;
|
if (!nav) return;
|
||||||
for (auto element : ui::NavigationView::fixedAppListFC) {
|
// TODO(u-foka): Somehow order static and dynamic app lists together
|
||||||
printAppInfo(chp, element);
|
for (auto& element : ui::NavigationView::appMap) { // Use the map as its ordered by id
|
||||||
|
printAppInfo(chp, element.second);
|
||||||
}
|
}
|
||||||
ui::ExternalItemsMenuLoader::load_all_external_items_callback([chp](ui::AppInfoConsole& info) {
|
ui::ExternalItemsMenuLoader::load_all_external_items_callback([chp](ui::AppInfoConsole& info) {
|
||||||
printAppInfo(chp, info);
|
printAppInfo(chp, info);
|
||||||
|
39
firmware/application/view_factory.hpp
Normal file
39
firmware/application/view_factory.hpp
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2024 Tamas Eisenberger <e.tamas@iwstudio.hu>
|
||||||
|
*
|
||||||
|
* 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 __VIEW_FACTORY_HPP__
|
||||||
|
#define __VIEW_FACTORY_HPP__
|
||||||
|
|
||||||
|
#include "view_factory_base.hpp"
|
||||||
|
|
||||||
|
namespace ui {
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
class ViewFactory : public ViewFactoryBase {
|
||||||
|
public:
|
||||||
|
virtual std::unique_ptr<View> produce(NavigationView& nav) const override {
|
||||||
|
return std::unique_ptr<View>(new T(nav));
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace ui
|
||||||
|
|
||||||
|
#endif //__VIEW_FACTORY_HPP__
|
28
firmware/application/view_factory_base.cpp
Normal file
28
firmware/application/view_factory_base.cpp
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2024 Tamas Eisenberger <e.tamas@iwstudio.hu>
|
||||||
|
*
|
||||||
|
* 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 "view_factory_base.hpp"
|
||||||
|
|
||||||
|
namespace ui {
|
||||||
|
|
||||||
|
ViewFactoryBase::~ViewFactoryBase() {}
|
||||||
|
|
||||||
|
} // namespace ui
|
40
firmware/application/view_factory_base.hpp
Normal file
40
firmware/application/view_factory_base.hpp
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2024 Tamas Eisenberger <e.tamas@iwstudio.hu>
|
||||||
|
*
|
||||||
|
* 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 __VIEW_FACTORY_BASE_HPP__
|
||||||
|
#define __VIEW_FACTORY_BASE_HPP__
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
#include "ui_widget.hpp"
|
||||||
|
|
||||||
|
namespace ui {
|
||||||
|
|
||||||
|
class NavigationView;
|
||||||
|
|
||||||
|
class ViewFactoryBase {
|
||||||
|
public:
|
||||||
|
virtual ~ViewFactoryBase();
|
||||||
|
virtual std::unique_ptr<View> produce(NavigationView& nav) const = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace ui
|
||||||
|
|
||||||
|
#endif //__VIEW_FACTORY_BASE_HPP__
|
@ -34,7 +34,8 @@ enum app_location_t : uint32_t {
|
|||||||
UTILITIES = 0,
|
UTILITIES = 0,
|
||||||
RX,
|
RX,
|
||||||
TX,
|
TX,
|
||||||
DEBUG
|
DEBUG,
|
||||||
|
HOME
|
||||||
};
|
};
|
||||||
|
|
||||||
struct application_information_t {
|
struct application_information_t {
|
||||||
|
Loading…
Reference in New Issue
Block a user