Enroute Flight Navigation
A navigation app for VFR pilots
|
Manages the list of geographic maps. More...
#include <DataManager.h>
Public Slots | |
void | updateRemoteDataItemListIfOutdated () |
Triggers an update of the list of remotely available data items. | |
Signals | |
void | appUpdateRequiredChanged () |
void | error (const QString &message) |
Error message for user. | |
void | whatsNewChanged () |
Notifier signal. | |
Public Member Functions | |
DataManager (QObject *parent=nullptr) | |
Standard constructor. | |
void | deferredInitialization () override |
Non-constructor initialization. | |
bool | appUpdateRequired () const |
Getter function for the property with the same name. | |
DataManagement::Downloadable_MultiFile * | aviationMaps () |
Getter function for the property with the same name. | |
DataManagement::Downloadable_MultiFile * | baseMaps () |
Getter function for the property with the same name. | |
DataManagement::Downloadable_MultiFile * | baseMapsRaster () |
Getter function for the property with the same name. | |
DataManagement::Downloadable_MultiFile * | baseMapsVector () |
Getter function for the property with the same name. | |
DataManagement::Downloadable_MultiFile * | databases () |
Getter function for the property with the same name. | |
DataManagement::Downloadable_MultiFile * | items () |
Getter function for the property with the same name. | |
DataManagement::Downloadable_SingleFile * | mapList () |
Getter function for the property with the same name. | |
DataManagement::Downloadable_MultiFile * | mapsAndData () |
Getter function for the property with the same name. | |
DataManagement::Downloadable_MultiFile * | mapSets () |
Getter function for the property with the same name. | |
DataManagement::Downloadable_MultiFile * | terrainMaps () |
Getter function for the property with the same name. | |
QString | whatsNew () const |
Getter function for the property with the same name. | |
Units::ByteSize | whatsNewHash () const |
Getter function for the property with the same name. | |
Q_INVOKABLE QString | import (const QString &fileName, const QString &newName) |
Import raster or vector map into the library of locally installed maps. | |
Q_INVOKABLE QString | importOpenAir (const QString &fileName, const QString &newName) |
Import airspace data into the library of locally installed maps. | |
![]() | |
GlobalObject (QObject *parent=nullptr) | |
Standard constructor. | |
~GlobalObject () override=default | |
Standard deconstructor. | |
Additional Inherited Members | |
![]() | |
static void | clear () |
Deletes all globally defined objects. | |
static Q_INVOKABLE bool | canConstruct () |
Indicates if the static methods are ready to be used. | |
static Q_INVOKABLE Navigation::Clock * | clock () |
Pointer to appplication-wide static Navigation::Clock instance. | |
static Q_INVOKABLE DataManagement::DataManager * | dataManager () |
Pointer to appplication-wide static GeoMaps::DataManager instance. | |
static Q_INVOKABLE DemoRunner * | demoRunner () |
Pointer to appplication-wide static DemoRunner instance. | |
static Q_INVOKABLE Traffic::FlarmnetDB * | flarmnetDB () |
Pointer to appplication-wide static FlarmnetDB instance. | |
static Q_INVOKABLE Platform::FileExchange_Abstract * | fileExchange () |
Pointer to appplication-wide static FileExchange instance. | |
static Q_INVOKABLE GeoMaps::GeoMapProvider * | geoMapProvider () |
Pointer to appplication-wide static GeoMaps::GeoMapProvider instance. | |
static Q_INVOKABLE GlobalSettings * | globalSettings () |
Pointer to appplication-wide static Settings instance. | |
static Q_INVOKABLE Librarian * | librarian () |
Pointer to appplication-wide static librarian instance. | |
static Q_INVOKABLE Platform::PlatformAdaptor_Abstract * | platformAdaptor () |
Pointer to appplication-wide static PlatformAdaptor instance. | |
static Q_INVOKABLE Sensors * | sensors () |
Pointer to appplication-wide static Navigation::Clock instance. | |
static Q_INVOKABLE Navigation::Navigator * | navigator () |
Pointer to appplication-wide static Navigation::Navigator instance. | |
static Q_INVOKABLE Traffic::PasswordDB * | passwordDB () |
Pointer to appplication-wide static PasswordDB instance. | |
static Q_INVOKABLE Positioning::PositionProvider * | positionProvider () |
Pointer to appplication-wide static PositionProvider instance. | |
static Q_INVOKABLE NOTAM::NOTAMProvider * | notamProvider () |
Pointer to appplication-wide static notification manager instance. | |
static Q_INVOKABLE Notifications::NotificationManager * | notificationManager () |
Pointer to appplication-wide static notification manager instance. | |
static Q_INVOKABLE QNetworkAccessManager * | networkAccessManager () |
Pointer to appplication-wide static QNetworkAccessManager instance. | |
static Q_INVOKABLE DataManagement::SSLErrorHandler * | sslErrorHandler () |
Pointer to appplication-wide static QNetworkAccessManager instance. | |
static Q_INVOKABLE Traffic::TrafficDataProvider * | trafficDataProvider () |
Pointer to appplication-wide static TrafficDataProvider instance. | |
static Q_INVOKABLE GeoMaps::WaypointLibrary * | waypointLibrary () |
Pointer to appplication-wide static WaypointLibrary instance. | |
static Q_INVOKABLE Weather::WeatherDataProvider * | weatherDataProvider () |
Pointer to appplication-wide static WeatherDataProvider instance. | |
Manages the list of geographic maps.
This class manages a list of remotely available and locally installed databases and geographic maps. More specifically, it manages the following items.
In addition, it allows access to the following data.
The class retrieves the list of available items from a remote server on a regular basis, updates the list automatically once a week, and maintains a list of Downloadable objects that corresponds to the remotely available and locally installed items.
The address of the remote server is hardcoded into the binary. The list is downloaded to a file "maps.json" in QStandardPaths::writableLocation(QStandardPaths::AppDataLocation). The format of the file is described at this URL:
https://github.com/Akaflieg-Freiburg/enrouteServer/wiki/The-file-maps.json
Locally installed items are saved in the directory "aviation_maps" in QStandardPaths::writableLocation(QStandardPaths::AppDataLocation), or into a suitable subdirectory of this.
The implementation assumes that no other program interferes with the file "maps.json" and with the directory "aviation_maps".
Definition at line 70 of file DataManager.h.
|
explicit |
Standard constructor.
This constructor reads the file "maps.json" and initiates a download of the file if no file is available or if the last download is more than one week old.
parent | The standard QObject parent pointer. |
|
inlinenodiscard |
Getter function for the property with the same name.
Definition at line 186 of file DataManager.h.
|
signal |
Notifier signal
|
inlinenodiscard |
Getter function for the property with the same name.
Definition at line 192 of file DataManager.h.
|
inlinenodiscard |
Getter function for the property with the same name.
Definition at line 198 of file DataManager.h.
|
inlinenodiscard |
Getter function for the property with the same name.
Definition at line 204 of file DataManager.h.
|
inlinenodiscard |
Getter function for the property with the same name.
Definition at line 210 of file DataManager.h.
|
inlinenodiscard |
Getter function for the property with the same name.
Definition at line 216 of file DataManager.h.
|
overridevirtual |
Non-constructor initialization.
This method is called by the static methods that create global instances immediately after the constructor returns. This class can be re-implemented to perform initialization steps that refer to other singleton objects.
Reimplemented from GlobalObject.
|
signal |
Error message for user.
This signal is emitted if an error occurs and the GUI should display a prominent error message. This signal can be emitted anytime.
message | A brief, human-readable, translated error message. |
Q_INVOKABLE QString DataManagement::DataManager::import | ( | const QString & | fileName, |
const QString & | newName ) |
Import raster or vector map into the library of locally installed maps.
This method imports a raster or vector map in MBTILES format into the library of locally installed maps. To avoid clashes and inconsistencies, the map will delete all locally install vector maps when importing a raster map, and all raster maps when importing a vector map.
fileName | File name of locally raster or vector map, in MBTILES format. |
newName | Name under which the map is available in the library. If the name exists, the library entry will be replaced. |
Q_INVOKABLE QString DataManagement::DataManager::importOpenAir | ( | const QString & | fileName, |
const QString & | newName ) |
Import airspace data into the library of locally installed maps.
This method imports airspace data in OpenAir format into the library of locally installed maps.
fileName | File name of locally raster or vector map, in OpenAir format. |
newName | Name under which the map is available in the library. If the name exists, the library entry will be replaced. |
|
inlinenodiscard |
Getter function for the property with the same name.
Definition at line 222 of file DataManager.h.
|
inlinenodiscard |
Getter function for the property with the same name.
Definition at line 228 of file DataManager.h.
|
inlinenodiscard |
Getter function for the property with the same name.
Definition at line 234 of file DataManager.h.
|
inlinenodiscard |
Getter function for the property with the same name.
Definition at line 240 of file DataManager.h.
|
inlinenodiscard |
Getter function for the property with the same name.
Definition at line 246 of file DataManager.h.
|
slot |
Triggers an update of the list of remotely available data items.
This will trigger a download the file maps.json from the remote server if the last update is more than one day ago.
|
inlinenodiscard |
Getter function for the property with the same name.
Definition at line 252 of file DataManager.h.
|
inlinenodiscard |
Getter function for the property with the same name.
Definition at line 258 of file DataManager.h.
|
read |
Indiates that the app needs to be updated.
This property indicates that this version of the app is too old and cannot interpret maps and data that reside on the server. If this is the case, the GUI should yell at the user and block any attempt to download or update maps and data.
Definition at line 114 of file DataManager.h.
|
read |
Downloadable_MultiFile that holds all aviation maps.
Pointer to a Downloadable_MultiFile that holds all aviation maps.
Definition at line 120 of file DataManager.h.
|
read |
Downloadable_MultiFile that holds all base maps.
Pointer to a Downloadable_MultiFile that holds all base maps.
Definition at line 138 of file DataManager.h.
|
read |
Downloadable_MultiFile that holds all base maps in raster format.
Pointer to a Downloadable_MultiFile that holds all base maps in raster format.
Definition at line 126 of file DataManager.h.
|
read |
Downloadable_MultiFile that holds all base maps in vector format.
Pointer to a Downloadable_MultiFile that holds all base maps in vector format.
Definition at line 132 of file DataManager.h.
|
read |
Downloadable_MultiFile that holds all databases.
Pointer to a Downloadable_MultiFile that holds all databases.
Definition at line 144 of file DataManager.h.
|
read |
Downloadable_MultiFile that holds all data items.
Pointer to a Downloadable_MultiFile that holds all data items. This includes aviation maps, base maps, and databases.
Definition at line 151 of file DataManager.h.
|
read |
Downloadable_MultiFile that holds all map sets.
Pointer to a Downloadable_MultiFile that holds all map sets.
Definition at line 163 of file DataManager.h.
|
read |
Downloadable_MultiFile that holds all terrain maps.
Pointer to a Downloadable_MultiFile that holds all terrain maps.
Definition at line 169 of file DataManager.h.