added aircraft info to ADS-B app

This commit is contained in:
Arjan Onwezen 2021-12-01 17:23:40 -05:00
parent 96db26e884
commit 2a2abac244
2 changed files with 250 additions and 6 deletions

View File

@ -91,6 +91,141 @@ void ADSBLogger::log_str(std::string& logline) {
log_file.write_entry(datetime,logline); log_file.write_entry(datetime,logline);
} }
// Aircraft Details
void ADSBRxAircraftDetailsView::focus() {
button_close.focus();
}
ADSBRxAircraftDetailsView::~ADSBRxAircraftDetailsView() {
on_close_();
}
ADSBRxAircraftDetailsView::ADSBRxAircraftDetailsView(
NavigationView& nav,
const AircraftRecentEntry& entry,
const std::function<void(void)> on_close
) : entry_copy(entry),
on_close_(on_close)
{
char file_buffer[32] { 0 };
bool found = false;
size_t number_of_icao_codes = 0;
std::string icao_code;
add_children({
&labels,
&text_icao_address,
&text_registration,
&text_manufacturer,
&text_model,
&text_type,
&text_number_of_engines,
&text_engine_type,
&text_owner,
&button_close
});
std::unique_ptr<ADSBLogger> logger { };
//update(entry_copy);
text_icao_address.set(to_string_hex(entry_copy.ICAO_address, 6));
// Try getting the aircraft information from icao24.db
auto result = db_file.open("ADSB/icao24.db");
if (!result.is_valid()) {
number_of_icao_codes = (db_file.size() / 115); // determine number of ICAO24 codes in file
icao_code = to_string_hex(entry_copy.ICAO_address, 6);
// binary search
int first = 0, // First search element
last = number_of_icao_codes - 1, // Last search element
middle, // Mid point of search
position = -1; // Position of search value
while (!found && first <= last) {
middle = (first + last) / 2; // Calculate mid point
db_file.seek(middle * 7);
db_file.read(file_buffer, 6);
if (file_buffer == icao_code) { // If value is found at mid
found = true;
position = middle;
}
else if (file_buffer > icao_code) // If value is in lower half
last = middle - 1;
else
first = middle + 1; // If value is in upper half
}
if (position > -1) {
db_file.seek((number_of_icao_codes * 7) + (position * 108)); // seek starting after index
db_file.read(file_buffer, 8);
text_registration.set(file_buffer);
db_file.read(file_buffer, 32);
text_manufacturer.set(file_buffer);
db_file.read(file_buffer, 32);
text_model.set(file_buffer);
db_file.read(file_buffer, 4); //todo split in engine type, numbe rof engines,etc
if(strlen(file_buffer) == 3) {
switch(file_buffer[0]) {
case 'L':
text_type.set("Landplane");
break;
case 'S':
text_type.set("Seaplane");
break;
case 'A':
text_type.set("Amphibian");
break;
case 'H':
text_type.set("Helicopter");
break;
case 'G':
text_type.set("Gyrocopter");
break;
case 'T':
text_type.set("Tilt-wing aircraft");
break;
}
text_number_of_engines.set(std::string(1, file_buffer[1]));
switch(file_buffer[2]) {
case 'P':
text_engine_type.set("Piston engine");
break;
case 'T':
text_engine_type.set("Turboprop/Turboshaft engine");
break;
case 'J':
text_engine_type.set("Jet engine");
break;
case 'E':
text_engine_type.set("Electric engine");
break;
}
}
db_file.read(file_buffer, 32);
text_owner.set(file_buffer);
} else {
text_registration.set("Unknown");
text_manufacturer.set("Unknown");
}
} else {
text_manufacturer.set("No icao24.db file");
}
button_close.on_select = [&nav](Button&){
nav.pop();
};
};
// End of Aicraft details
void ADSBRxDetailsView::focus() { void ADSBRxDetailsView::focus() {
button_see_map.focus(); button_see_map.focus();
} }
@ -130,12 +265,13 @@ ADSBRxDetailsView::ADSBRxDetailsView(
{ {
char file_buffer[32] { 0 }; char file_buffer[32] { 0 };
bool found = false; bool found = false;
int number_of_airlines = 0; size_t number_of_airlines = 0;
std::string airline_code; std::string airline_code;
size_t c; size_t c;
add_children({ add_children({
&labels, &labels,
&text_icao_address,
&text_callsign, &text_callsign,
&text_last_seen, &text_last_seen,
&text_airline, &text_airline,
@ -144,6 +280,7 @@ ADSBRxDetailsView::ADSBRxDetailsView(
&text_info2, &text_info2,
&text_frame_pos_even, &text_frame_pos_even,
&text_frame_pos_odd, &text_frame_pos_odd,
&button_aircraft_details,
&button_see_map &button_see_map
}); });
@ -184,9 +321,20 @@ ADSBRxDetailsView::ADSBRxDetailsView(
} }
text_callsign.set(entry_copy.callsign); text_callsign.set(entry_copy.callsign);
text_icao_address.set(to_string_hex(entry_copy.ICAO_address, 6));
button_aircraft_details.on_select = [this, &nav](Button&) {
//detailed_entry_key = entry.key();
aircraft_details_view = nav.push<ADSBRxAircraftDetailsView>(
entry_copy,
[this]() {
send_updates = false;
});
send_updates = false;
};
button_see_map.on_select = [this, &nav](Button&) { button_see_map.on_select = [this, &nav](Button&) {
if (!send_updates) { // Prevent recursivley launching the map if (!send_updates) { // Prevent recursively launching the map
geomap_view = nav.push<GeoMapView>( geomap_view = nav.push<GeoMapView>(
entry_copy.callsign, entry_copy.callsign,
entry_copy.pos.altitude, entry_copy.pos.altitude,
@ -202,6 +350,7 @@ ADSBRxDetailsView::ADSBRxDetailsView(
}; };
}; };
void ADSBRxView::focus() { void ADSBRxView::focus() {
field_vga.focus(); field_vga.focus();
} }

View File

@ -159,6 +159,88 @@ private:
}; };
class ADSBRxAircraftDetailsView : public View {
public:
ADSBRxAircraftDetailsView(NavigationView&, const AircraftRecentEntry& entry, const std::function<void(void)> on_close);
~ADSBRxAircraftDetailsView();
ADSBRxAircraftDetailsView(const ADSBRxAircraftDetailsView&) = delete;
ADSBRxAircraftDetailsView(ADSBRxAircraftDetailsView&&) = delete;
ADSBRxAircraftDetailsView& operator=(const ADSBRxAircraftDetailsView&) = delete;
ADSBRxAircraftDetailsView& operator=(ADSBRxAircraftDetailsView&&) = delete;
void focus() override;
void update(const AircraftRecentEntry& entry);
std::string title() const override { return "AC Details"; };
AircraftRecentEntry get_current_entry() { return entry_copy; }
private:
AircraftRecentEntry entry_copy { 0 };
std::function<void(void)> on_close_ { };
bool send_updates { false };
File db_file { };
Labels labels {
{ { 0 * 8, 1 * 16 }, "ICAO:", Color::light_grey() },
{ { 0 * 8, 2 * 16 }, "Registration:", Color::light_grey() },
{ { 0 * 8, 3 * 16 }, "Manufacturer:", Color::light_grey() },
{ { 0 * 8, 5 * 16 }, "Model:", Color::light_grey() },
{ { 0 * 8, 7 * 16 }, "Type:", Color::light_grey() },
{ { 0 * 8, 8 * 16 }, "Number of engines:", Color::light_grey() },
{ { 0 * 8, 9 * 16 }, "Engine type:", Color::light_grey() },
{ { 0 * 8, 10 * 16 }, "Owner:", Color::light_grey() }
};
Text text_icao_address {
{ 5 * 8, 1 * 16, 6 * 8, 16},
"-"
};
Text text_registration {
{ 13 * 8, 2 * 16, 8 * 8, 16 },
"-"
};
Text text_manufacturer {
{ 0 * 8, 4 * 16, 19 * 8, 16 },
"-"
};
Text text_model {
{ 0 * 8, 6 * 16, 30 * 8, 16 },
"-"
};
Text text_type {
{ 5 * 8, 7 * 16, 22 * 8, 16 },
"-"
};
Text text_number_of_engines {
{ 18 * 8, 8 * 16, 30 * 8, 16 },
"-"
};
Text text_engine_type {
{ 12 * 8, 9 * 16, 30 * 8, 16},
"-"
};
Text text_owner {
{ 0 * 8, 11 * 16, 30 * 8, 16 },
"-"
};
Button button_close {
{ 9 * 8, 16 * 16, 12 * 8, 3 * 16 },
"Back"
};
};
class ADSBRxDetailsView : public View { class ADSBRxDetailsView : public View {
public: public:
ADSBRxDetailsView(NavigationView&, const AircraftRecentEntry& entry, const std::function<void(void)> on_close); ADSBRxDetailsView(NavigationView&, const AircraftRecentEntry& entry, const std::function<void(void)> on_close);
@ -181,11 +263,13 @@ private:
AircraftRecentEntry entry_copy { 0 }; AircraftRecentEntry entry_copy { 0 };
std::function<void(void)> on_close_ { }; std::function<void(void)> on_close_ { };
GeoMapView* geomap_view { nullptr }; GeoMapView* geomap_view { nullptr };
ADSBRxAircraftDetailsView* aircraft_details_view { nullptr };
bool send_updates { false }; bool send_updates { false };
File db_file { }; File db_file { };
Labels labels { Labels labels {
{ { 0 * 8, 1 * 16 }, "Callsign:", Color::light_grey() }, { { 0 * 8, 1 * 16 }, "ICAO:", Color::light_grey() },
{ { 13 * 8, 1 * 16 }, "Callsign:", Color::light_grey() },
{ { 0 * 8, 2 * 16 }, "Last seen:", Color::light_grey() }, { { 0 * 8, 2 * 16 }, "Last seen:", Color::light_grey() },
{ { 0 * 8, 3 * 16 }, "Airline:", Color::light_grey() }, { { 0 * 8, 3 * 16 }, "Airline:", Color::light_grey() },
{ { 0 * 8, 5 * 16 }, "Country:", Color::light_grey() }, { { 0 * 8, 5 * 16 }, "Country:", Color::light_grey() },
@ -193,8 +277,13 @@ private:
{ { 0 * 8, 15 * 16 }, "Odd position frame:", Color::light_grey() } { { 0 * 8, 15 * 16 }, "Odd position frame:", Color::light_grey() }
}; };
Text text_icao_address {
{ 5 * 8, 1 * 16, 6 * 8, 16},
"-"
};
Text text_callsign { Text text_callsign {
{ 9 * 8, 1 * 16, 8 * 8, 16 }, { 22 * 8, 1 * 16, 8 * 8, 16 },
"-" "-"
}; };
@ -232,11 +321,17 @@ private:
"-" "-"
}; };
Button button_aircraft_details {
{ 2 * 8, 9 * 16, 12 * 8, 3 * 16 },
"A/C details"
};
Button button_see_map { Button button_see_map {
{ 8 * 8, 9 * 16, 14 * 8, 3 * 16 }, { 16 * 8, 9 * 16, 12 * 8, 3 * 16 },
"See on map" "See on map"
}; };
}; };
class ADSBRxView : public View { class ADSBRxView : public View {
public: public: