Commit 605c285e authored by Gus Grubba's avatar Gus Grubba

Replace overly redundant code with macros for settings.

parent fa8172e7
...@@ -13,18 +13,10 @@ ...@@ -13,18 +13,10 @@
#include <QQmlEngine> #include <QQmlEngine>
#include <QtQml> #include <QtQml>
DECLARE_SETTINGGROUP(AirMap) DECLARE_SETTINGGROUP(AirMap, "AirMap")
{ {
INIT_SETTINGFACT(usePersonalApiKey); QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership); \
INIT_SETTINGFACT(apiKey); qmlRegisterUncreatableType<AirMapSettings>("QGroundControl.SettingsManager", 1, 0, "AirMapSettings", "Reference only"); \
INIT_SETTINGFACT(clientID);
INIT_SETTINGFACT(userName);
INIT_SETTINGFACT(password);
INIT_SETTINGFACT(enableAirMap);
INIT_SETTINGFACT(enableAirspace);
INIT_SETTINGFACT(enableTelemetry);
QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership);
qmlRegisterUncreatableType<AirMapSettings>("QGroundControl.SettingsManager", 1, 0, "AirMapSettings", "Reference only");
} }
DECLARE_SETTINGSFACT(AirMapSettings, usePersonalApiKey) DECLARE_SETTINGSFACT(AirMapSettings, usePersonalApiKey)
......
...@@ -17,7 +17,7 @@ class AirMapSettings : public SettingsGroup ...@@ -17,7 +17,7 @@ class AirMapSettings : public SettingsGroup
public: public:
AirMapSettings(QObject* parent = nullptr); AirMapSettings(QObject* parent = nullptr);
DEFINE_SETTINGGROUP(AirMap) DEFINE_SETTING_NAME_GROUP()
DEFINE_SETTINGFACT(usePersonalApiKey) DEFINE_SETTINGFACT(usePersonalApiKey)
DEFINE_SETTINGFACT(apiKey) DEFINE_SETTINGFACT(apiKey)
......
...@@ -10,6 +10,6 @@ ...@@ -10,6 +10,6 @@
// If you need to make an incompatible changes to stored settings, bump this version number // If you need to make an incompatible changes to stored settings, bump this version number
// up by 1. This will caused store settings to be cleared on next boot. // up by 1. This will caused store settings to be cleared on next boot.
#define QGC_SETTINGS_VERSION 7 #define QGC_SETTINGS_VERSION 8
#endif // QGC_CONFIGURATION_H #endif // QGC_CONFIGURATION_H
...@@ -161,7 +161,7 @@ QGCView { ...@@ -161,7 +161,7 @@ QGCView {
anchors.baseline: gstCombo.baseline anchors.baseline: gstCombo.baseline
anchors.right: gstCombo.left anchors.right: gstCombo.left
anchors.rightMargin: ScreenTools.defaultFontPixelWidth anchors.rightMargin: ScreenTools.defaultFontPixelWidth
text: "gstreamer debug level:" text: qsTr("GStreamer Debug Level:")
} }
FactComboBox { FactComboBox {
...@@ -171,7 +171,7 @@ QGCView { ...@@ -171,7 +171,7 @@ QGCView {
anchors.bottom: parent.bottom anchors.bottom: parent.bottom
width: ScreenTools.defaultFontPixelWidth*20 width: ScreenTools.defaultFontPixelWidth*20
model: ["disabled", "1", "2", "3", "4", "5", "6", "7", "8"] model: ["disabled", "1", "2", "3", "4", "5", "6", "7", "8"]
fact: QGroundControl.settingsManager.appSettings.gstDebug fact: QGroundControl.settingsManager.appSettings.gstDebugLevel
} }
BusyIndicator { BusyIndicator {
......
[ [
{ {
"name": "OfflineEditingFirmwareType", "name": "offlineEditingFirmwareType",
"shortDescription": "Offline editing firmware type", "shortDescription": "Offline editing firmware type",
"type": "uint32", "type": "uint32",
"enumStrings": "ArduPilot,PX4 Pro,Mavlink Generic", "enumStrings": "ArduPilot,PX4 Pro,Mavlink Generic",
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
"defaultValue": 12 "defaultValue": 12
}, },
{ {
"name": "OfflineEditingVehicleType", "name": "offlineEditingVehicleType",
"shortDescription": "Offline editing vehicle type", "shortDescription": "Offline editing vehicle type",
"type": "uint32", "type": "uint32",
"enumStrings": "Fixed Wing,Multi-Rotor,VTOL,Rover,Sub", "enumStrings": "Fixed Wing,Multi-Rotor,VTOL,Rover,Sub",
...@@ -16,7 +16,7 @@ ...@@ -16,7 +16,7 @@
"defaultValue": 2 "defaultValue": 2
}, },
{ {
"name": "OfflineEditingCruiseSpeed", "name": "offlineEditingCruiseSpeed",
"shortDescription": "Offline editing cruise speed", "shortDescription": "Offline editing cruise speed",
"longDescription": "This value defines the default cruising speed for forward flight vehicles for use in calculating mission statistics. It does not modify the flight speed for a specific flight plan.", "longDescription": "This value defines the default cruising speed for forward flight vehicles for use in calculating mission statistics. It does not modify the flight speed for a specific flight plan.",
"type": "double", "type": "double",
...@@ -26,7 +26,7 @@ ...@@ -26,7 +26,7 @@
"decimalPlaces": 2 "decimalPlaces": 2
}, },
{ {
"name": "OfflineEditingHoverSpeed", "name": "offlineEditingHoverSpeed",
"shortDescription": "Offline editing hover speed", "shortDescription": "Offline editing hover speed",
"longDescription": "This value defines the default cruising speed for multi-rotor vehicles for use in calculating mission statistics. It does not modify the flight speed for a specific flight plan.", "longDescription": "This value defines the default cruising speed for multi-rotor vehicles for use in calculating mission statistics. It does not modify the flight speed for a specific flight plan.",
"type": "double", "type": "double",
...@@ -36,7 +36,7 @@ ...@@ -36,7 +36,7 @@
"decimalPlaces": 2 "decimalPlaces": 2
}, },
{ {
"name": "OfflineEditingAscentSpeed", "name": "offlineEditingAscentSpeed",
"shortDescription": "Offline editing ascent speed", "shortDescription": "Offline editing ascent speed",
"longDescription": "This value defines the ascent speed for multi-rotor vehicles for use in calculating mission duration.", "longDescription": "This value defines the ascent speed for multi-rotor vehicles for use in calculating mission duration.",
"type": "double", "type": "double",
...@@ -46,7 +46,7 @@ ...@@ -46,7 +46,7 @@
"decimalPlaces": 2 "decimalPlaces": 2
}, },
{ {
"name": "OfflineEditingDescentSpeed", "name": "offlineEditingDescentSpeed",
"shortDescription": "Offline editing descent speed", "shortDescription": "Offline editing descent speed",
"longDescription": "This value defines the cruising speed for multi-rotor vehicles for use in calculating mission duration.", "longDescription": "This value defines the cruising speed for multi-rotor vehicles for use in calculating mission duration.",
"type": "double", "type": "double",
...@@ -66,7 +66,7 @@ ...@@ -66,7 +66,7 @@
"max": 100 "max": 100
}, },
{ {
"name": "DefaultMissionItemAltitude", "name": "defaultMissionItemAltitude",
"shortDescription": "Default value for altitude", "shortDescription": "Default value for altitude",
"longDescription": "This value specifies the default altitude for new items added to a mission.", "longDescription": "This value specifies the default altitude for new items added to a mission.",
"type": "double", "type": "double",
...@@ -76,56 +76,56 @@ ...@@ -76,56 +76,56 @@
"decimalPlaces": 1 "decimalPlaces": 1
}, },
{ {
"name": "PromptFLightDataSave", "name": "telemetrySave",
"shortDescription": "Save telemetry Log after each flight", "shortDescription": "Save telemetry Log after each flight",
"longDescription": "If this option is enabled a telemetry will be saved after each flight completes.", "longDescription": "If this option is enabled a telemetry will be saved after each flight completes.",
"type": "bool", "type": "bool",
"defaultValue": true "defaultValue": true
}, },
{ {
"name": "PromptFLightDataSaveNotArmed", "name": "telemetrySaveNotArmed",
"shortDescription": "Save telemetry log even if vehicle was not armed", "shortDescription": "Save telemetry log even if vehicle was not armed",
"longDescription": "If this option is enabled a telemtry log will be saved even if vehicle was never armed.", "longDescription": "If this option is enabled a telemtry log will be saved even if vehicle was never armed.",
"type": "bool", "type": "bool",
"defaultValue": false "defaultValue": false
}, },
{ {
"name": "AudioMuted", "name": "audioMuted",
"shortDescription": "Mute audio output", "shortDescription": "Mute audio output",
"longDescription": "If this option is enabled all audio output will be muted.", "longDescription": "If this option is enabled all audio output will be muted.",
"type": "bool", "type": "bool",
"defaultValue": false "defaultValue": false
}, },
{ {
"name": "VirtualTabletJoystick", "name": "virtualJoystick",
"shortDescription": "Show virtual joystick", "shortDescription": "Show virtual joystick",
"longDescription": "If this option is enabled the virtual joystick will be shown on the Fly view.", "longDescription": "If this option is enabled the virtual joystick will be shown on the Fly view.",
"type": "bool", "type": "bool",
"defaultValue": false "defaultValue": false
}, },
{ {
"name": "GstreamerDebugLevel", "name": "gstDebugLevel",
"shortDescription": "Video streaming debug", "shortDescription": "Video streaming debug",
"longDescription": "Sets the environment variable GST_DEBUG for all pipeline elements on boot.", "longDescription": "Sets the environment variable GST_DEBUG for all pipeline elements on boot.",
"type": "uint8", "type": "uint8",
"defaultValue": 0 "defaultValue": 0
}, },
{ {
"name": "AutoLoadMissions", "name": "autoLoadMissions",
"shortDescription": "AutoLoad mission on vehicle connect", "shortDescription": "AutoLoad mission on vehicle connect",
"longDescription": "Automatically load a mission file named AutoLoad#.mission when a vehicle with id # connects.", "longDescription": "Automatically load a mission file named AutoLoad#.mission when a vehicle with id # connects.",
"type": "bool", "type": "bool",
"defaultValue": false "defaultValue": false
}, },
{ {
"name": "UseChecklist", "name": "useChecklist",
"shortDescription": "Use preflight checklist", "shortDescription": "Use preflight checklist",
"longDescription": "If this option is enabled the preflight checklist will be used.", "longDescription": "If this option is enabled the preflight checklist will be used.",
"type": "bool", "type": "bool",
"defaultValue": false "defaultValue": false
}, },
{ {
"name": "BaseDeviceFontPointSize", "name": "appFontPointSize",
"shortDescription": "Application font size", "shortDescription": "Application font size",
"longDescription": "The point size for the default font used.", "longDescription": "The point size for the default font used.",
"type": "uint32", "type": "uint32",
...@@ -136,7 +136,7 @@ ...@@ -136,7 +136,7 @@
"qgcRebootRequired": true "qgcRebootRequired": true
}, },
{ {
"name": "StyleIsDark", "name": "indoorPalette",
"shortDescription": "Application color scheme", "shortDescription": "Application color scheme",
"longDescription": "The color scheme for the user interface.", "longDescription": "The color scheme for the user interface.",
"type": "uint32", "type": "uint32",
...@@ -145,55 +145,55 @@ ...@@ -145,55 +145,55 @@
"defaultValue": 0 "defaultValue": 0
}, },
{ {
"name": "ShowLargeCompass", "name": "showLargeCompass",
"shortDescription": "Show large compass", "shortDescription": "Show large compass",
"longDescription": "Show large compass on instrument panel", "longDescription": "Show large compass on instrument panel",
"type": "bool", "type": "bool",
"defaultValue": false "defaultValue": false
}, },
{ {
"name": "SavePath", "name": "savePath",
"shortDescription": "Application save directory", "shortDescription": "Application save directory",
"longDescription": "Directory to which all data files are saved/loaded from", "longDescription": "Directory to which all data files are saved/loaded from",
"type": "string", "type": "string",
"defaultValue": "" "defaultValue": ""
}, },
{ {
"name": "UserBrandImageIndoor", "name": "userBrandImageIndoor",
"shortDescription": "User-selected brand image", "shortDescription": "User-selected brand image",
"longDescription": "Location in file system of user-selected brand image (indoor)", "longDescription": "Location in file system of user-selected brand image (indoor)",
"type": "string", "type": "string",
"defaultValue": "" "defaultValue": ""
}, },
{ {
"name": "UserBrandImageOutdoor", "name": "userBrandImageOutdoor",
"shortDescription": "User-selected brand image", "shortDescription": "User-selected brand image",
"longDescription": "Location in file system of user-selected brand image (outdoor)", "longDescription": "Location in file system of user-selected brand image (outdoor)",
"type": "string", "type": "string",
"defaultValue": "" "defaultValue": ""
}, },
{ {
"name": "MapboxToken", "name": "mapboxToken",
"shortDescription": "Access token to Mapbox maps", "shortDescription": "Access token to Mapbox maps",
"longDescription": "Your personal access token for Mapbox maps", "longDescription": "Your personal access token for Mapbox maps",
"type": "string", "type": "string",
"defaultValue": "" "defaultValue": ""
}, },
{ {
"name": "EsriToken", "name": "esriToken",
"shortDescription": "Access token to Esri maps", "shortDescription": "Access token to Esri maps",
"longDescription": "Your personal access token for Esri maps", "longDescription": "Your personal access token for Esri maps",
"type": "string", "type": "string",
"defaultValue": "" "defaultValue": ""
}, },
{ {
"name": "DefaultFirmwareType", "name": "defaultFirmwareType",
"shortDescription": "Default firmware type for flashing", "shortDescription": "Default firmware type for flashing",
"type": "uint32", "type": "uint32",
"defaultValue": 12 "defaultValue": 12
}, },
{ {
"name": "FollowTarget", "name": "followTarget",
"shortDescription": "Stream GCS' coordinates to Autopilot", "shortDescription": "Stream GCS' coordinates to Autopilot",
"type": "uint32", "type": "uint32",
"enumStrings": "Never,Always,When in Follow Me Flight Mode", "enumStrings": "Never,Always,When in Follow Me Flight Mode",
......
This diff is collapsed.
...@@ -6,9 +6,7 @@ ...@@ -6,9 +6,7 @@
* COPYING.md in the root of the source code directory. * COPYING.md in the root of the source code directory.
* *
****************************************************************************/ ****************************************************************************/
#pragma once
#ifndef AppSettings_H
#define AppSettings_H
#include "SettingsGroup.h" #include "SettingsGroup.h"
#include "QGCMAVLink.h" #include "QGCMAVLink.h"
...@@ -20,29 +18,31 @@ class AppSettings : public SettingsGroup ...@@ -20,29 +18,31 @@ class AppSettings : public SettingsGroup
public: public:
AppSettings(QObject* parent = nullptr); AppSettings(QObject* parent = nullptr);
Q_PROPERTY(Fact* offlineEditingFirmwareType READ offlineEditingFirmwareType CONSTANT) DEFINE_SETTING_NAME_GROUP()
Q_PROPERTY(Fact* offlineEditingVehicleType READ offlineEditingVehicleType CONSTANT)
Q_PROPERTY(Fact* offlineEditingCruiseSpeed READ offlineEditingCruiseSpeed CONSTANT) DEFINE_SETTINGFACT(offlineEditingFirmwareType)
Q_PROPERTY(Fact* offlineEditingHoverSpeed READ offlineEditingHoverSpeed CONSTANT) DEFINE_SETTINGFACT(offlineEditingVehicleType)
Q_PROPERTY(Fact* offlineEditingAscentSpeed READ offlineEditingAscentSpeed CONSTANT) DEFINE_SETTINGFACT(offlineEditingCruiseSpeed)
Q_PROPERTY(Fact* offlineEditingDescentSpeed READ offlineEditingDescentSpeed CONSTANT) DEFINE_SETTINGFACT(offlineEditingHoverSpeed)
Q_PROPERTY(Fact* batteryPercentRemainingAnnounce READ batteryPercentRemainingAnnounce CONSTANT) DEFINE_SETTINGFACT(offlineEditingAscentSpeed)
Q_PROPERTY(Fact* defaultMissionItemAltitude READ defaultMissionItemAltitude CONSTANT) DEFINE_SETTINGFACT(offlineEditingDescentSpeed)
Q_PROPERTY(Fact* telemetrySave READ telemetrySave CONSTANT) DEFINE_SETTINGFACT(batteryPercentRemainingAnnounce)
Q_PROPERTY(Fact* telemetrySaveNotArmed READ telemetrySaveNotArmed CONSTANT) DEFINE_SETTINGFACT(defaultMissionItemAltitude)
Q_PROPERTY(Fact* audioMuted READ audioMuted CONSTANT) DEFINE_SETTINGFACT(telemetrySave)
Q_PROPERTY(Fact* virtualJoystick READ virtualJoystick CONSTANT) DEFINE_SETTINGFACT(telemetrySaveNotArmed)
Q_PROPERTY(Fact* appFontPointSize READ appFontPointSize CONSTANT) DEFINE_SETTINGFACT(audioMuted)
Q_PROPERTY(Fact* indoorPalette READ indoorPalette CONSTANT) DEFINE_SETTINGFACT(virtualJoystick)
Q_PROPERTY(Fact* showLargeCompass READ showLargeCompass CONSTANT) DEFINE_SETTINGFACT(appFontPointSize)
Q_PROPERTY(Fact* savePath READ savePath CONSTANT) DEFINE_SETTINGFACT(indoorPalette)
Q_PROPERTY(Fact* autoLoadMissions READ autoLoadMissions CONSTANT) DEFINE_SETTINGFACT(showLargeCompass)
Q_PROPERTY(Fact* useChecklist READ useChecklist CONSTANT) DEFINE_SETTINGFACT(savePath)
Q_PROPERTY(Fact* mapboxToken READ mapboxToken CONSTANT) DEFINE_SETTINGFACT(autoLoadMissions)
Q_PROPERTY(Fact* esriToken READ esriToken CONSTANT) DEFINE_SETTINGFACT(useChecklist)
Q_PROPERTY(Fact* defaultFirmwareType READ defaultFirmwareType CONSTANT) DEFINE_SETTINGFACT(mapboxToken)
Q_PROPERTY(Fact* gstDebug READ gstDebug CONSTANT) DEFINE_SETTINGFACT(esriToken)
Q_PROPERTY(Fact* followTarget READ followTarget CONSTANT) DEFINE_SETTINGFACT(defaultFirmwareType)
DEFINE_SETTINGFACT(gstDebugLevel)
DEFINE_SETTINGFACT(followTarget)
Q_PROPERTY(QString missionSavePath READ missionSavePath NOTIFY savePathsChanged) Q_PROPERTY(QString missionSavePath READ missionSavePath NOTIFY savePathsChanged)
Q_PROPERTY(QString parameterSavePath READ parameterSavePath NOTIFY savePathsChanged) Q_PROPERTY(QString parameterSavePath READ parameterSavePath NOTIFY savePathsChanged)
...@@ -60,66 +60,15 @@ public: ...@@ -60,66 +60,15 @@ public:
Q_PROPERTY(QString shpFileExtension MEMBER shpFileExtension CONSTANT) Q_PROPERTY(QString shpFileExtension MEMBER shpFileExtension CONSTANT)
Q_PROPERTY(QString logFileExtension MEMBER logFileExtension CONSTANT) Q_PROPERTY(QString logFileExtension MEMBER logFileExtension CONSTANT)
Fact* offlineEditingFirmwareType (void); QString missionSavePath ();
Fact* offlineEditingVehicleType (void); QString parameterSavePath ();
Fact* offlineEditingCruiseSpeed (void); QString telemetrySavePath ();
Fact* offlineEditingHoverSpeed (void); QString logSavePath ();
Fact* offlineEditingAscentSpeed (void); QString videoSavePath ();
Fact* offlineEditingDescentSpeed (void); QString crashSavePath ();
Fact* batteryPercentRemainingAnnounce (void);
Fact* defaultMissionItemAltitude (void);
Fact* telemetrySave (void);
Fact* telemetrySaveNotArmed (void);
Fact* audioMuted (void);
Fact* virtualJoystick (void);
Fact* appFontPointSize (void);
Fact* indoorPalette (void);
Fact* showLargeCompass (void);
Fact* savePath (void);
Fact* autoLoadMissions (void);
Fact* useChecklist (void);
Fact* mapboxToken (void);
Fact* esriToken (void);
Fact* defaultFirmwareType (void);
Fact* gstDebug (void);
Fact* followTarget (void);
QString missionSavePath (void);
QString parameterSavePath (void);
QString telemetrySavePath (void);
QString logSavePath (void);
QString videoSavePath (void);
QString crashSavePath (void);
static MAV_AUTOPILOT offlineEditingFirmwareTypeFromFirmwareType(MAV_AUTOPILOT firmwareType);
static MAV_TYPE offlineEditingVehicleTypeFromVehicleType(MAV_TYPE vehicleType);
static const char* name; static MAV_AUTOPILOT offlineEditingFirmwareTypeFromFirmwareType (MAV_AUTOPILOT firmwareType);
static const char* settingsGroup; static MAV_TYPE offlineEditingVehicleTypeFromVehicleType (MAV_TYPE vehicleType);
static const char* offlineEditingFirmwareTypeSettingsName;
static const char* offlineEditingVehicleTypeSettingsName;
static const char* offlineEditingCruiseSpeedSettingsName;
static const char* offlineEditingHoverSpeedSettingsName;
static const char* offlineEditingAscentSpeedSettingsName;
static const char* offlineEditingDescentSpeedSettingsName;
static const char* batteryPercentRemainingAnnounceSettingsName;
static const char* defaultMissionItemAltitudeSettingsName;
static const char* telemetrySaveName;
static const char* telemetrySaveNotArmedName;
static const char* audioMutedName;
static const char* virtualJoystickName;
static const char* appFontPointSizeName;
static const char* indoorPaletteName;
static const char* showLargeCompassName;
static const char* savePathName;
static const char* autoLoadMissionsName;
static const char* useChecklistName;
static const char* mapboxTokenName;
static const char* esriTokenName;
static const char* defaultFirmwareTypeName;
static const char* gstDebugName;
static const char* followTargetName;
// Application wide file extensions // Application wide file extensions
static const char* parameterFileExtension; static const char* parameterFileExtension;
...@@ -142,36 +91,10 @@ public: ...@@ -142,36 +91,10 @@ public:
static const char* crashDirectory; static const char* crashDirectory;
signals: signals:
void savePathsChanged(void); void savePathsChanged();
private slots: private slots:
void _indoorPaletteChanged(void); void _indoorPaletteChanged();
void _checkSavePathDirectories(void); void _checkSavePathDirectories();
private:
SettingsFact* _offlineEditingFirmwareTypeFact;
SettingsFact* _offlineEditingVehicleTypeFact;
SettingsFact* _offlineEditingCruiseSpeedFact;
SettingsFact* _offlineEditingHoverSpeedFact;
SettingsFact* _offlineEditingAscentSpeedFact;
SettingsFact* _offlineEditingDescentSpeedFact;
SettingsFact* _batteryPercentRemainingAnnounceFact;
SettingsFact* _defaultMissionItemAltitudeFact;
SettingsFact* _telemetrySaveFact;
SettingsFact* _telemetrySaveNotArmedFact;
SettingsFact* _audioMutedFact;
SettingsFact* _virtualJoystickFact;
SettingsFact* _appFontPointSizeFact;
SettingsFact* _indoorPaletteFact;
SettingsFact* _showLargeCompassFact;
SettingsFact* _savePathFact;
SettingsFact* _autoLoadMissionsFact;
SettingsFact* _useChecklistFact;
SettingsFact* _mapboxTokenFact;
SettingsFact* _esriTokenFact;
SettingsFact* _defaultFirmwareTypeFact;
SettingsFact* _gstDebugFact;
SettingsFact* _followTargetFact;
}; };
#endif
[ [
{ {
"name": "AutoconnectUDP", "name": "autoConnectUDP",
"shortDescription": "Automatically open a connection over UDP", "shortDescription": "Automatically open a connection over UDP",
"longDescription": "If this option is enabled GroundControl will automatically connect to a vehicle which is detected on a UDP communication link.", "longDescription": "If this option is enabled GroundControl will automatically connect to a vehicle which is detected on a UDP communication link.",
"type": "bool", "type": "bool",
"defaultValue": true "defaultValue": true
}, },
{ {
"name": "AutoconnectPixhawk", "name": "autoConnectPixhawk",
"shortDescription": "Automatically connect to a Pixhawk board", "shortDescription": "Automatically connect to a Pixhawk board",
"longDescription": "If this option is enabled GroundControl will automatically connect to a Pixhawk board which is connected via USB.", "longDescription": "If this option is enabled GroundControl will automatically connect to a Pixhawk board which is connected via USB.",
"type": "bool", "type": "bool",
"defaultValue": true "defaultValue": true
}, },
{ {
"name": "Autoconnect3DRRadio", "name": "autoConnectSiKRadio",
"shortDescription": "Automatically connect to a SiK Radio", "shortDescription": "Automatically connect to a SiK Radio",
"longDescription": "If this option is enabled GroundControl will automatically connect to a vehicle which is detected on a SiK Radio communication link.", "longDescription": "If this option is enabled GroundControl will automatically connect to a vehicle which is detected on a SiK Radio communication link.",
"type": "bool", "type": "bool",
"defaultValue": true "defaultValue": true
}, },
{ {
"name": "AutoconnectPX4Flow", "name": "autoConnectPX4Flow",
"shortDescription": "Automatically connect to a P4 Flow", "shortDescription": "Automatically connect to a P4 Flow",
"longDescription": "If this option is enabled GroundControl will automatically connect to a PX4 Flow board which is connected via USB.", "longDescription": "If this option is enabled GroundControl will automatically connect to a PX4 Flow board which is connected via USB.",
"type": "bool", "type": "bool",
"defaultValue": true "defaultValue": true
}, },
{ {
"name": "AutoconnectRTKGPS", "name": "autoConnectRTKGPS",
"shortDescription": "Automatically connect to an RTK GPS", "shortDescription": "Automatically connect to an RTK GPS",
"longDescription": "If this option is enabled GroundControl will automatically connect to an RTK GPS which is connected via USB.", "longDescription": "If this option is enabled GroundControl will automatically connect to an RTK GPS which is connected via USB.",
"type": "bool", "type": "bool",
"defaultValue": true "defaultValue": true
}, },
{ {
"name": "AutoconnectLibrePilot", "name": "autoConnectLibrePilot",
"shortDescription": "Automatically connect to a LibrePilot", "shortDescription": "Automatically connect to a LibrePilot",
"longDescription": "If this option is enabled GroundControl will automatically connect to a LibrePilot board which is connected via USB.", "longDescription": "If this option is enabled GroundControl will automatically connect to a LibrePilot board which is connected via USB.",
"type": "bool", "type": "bool",
"defaultValue": true "defaultValue": true
}, },
{ {
"name": "AutoconnectNmeaPort", "name": "autoConnectNmeaPort",
"shortDescription": "NMEA GPS device for GCS position", "shortDescription": "NMEA GPS device for GCS position",
"longDescription": "NMEA GPS device for GCS position", "longDescription": "NMEA GPS device for GCS position",
"type": "string", "type": "string",
"defaultValue": "disabled" "defaultValue": "disabled"
}, },
{ {
"name": "AutoconnectNmeaBaud", "name": "autoConnectNmeaBaud",
"shortDescription": "NMEA GPS Baudrate", "shortDescription": "NMEA GPS Baudrate",
"longDescription": "NMEA GPS Baudrate", "longDescription": "NMEA GPS Baudrate",
"type": "uint32", "type": "uint32",
"defaultValue": 4800 "defaultValue": 4800
}, },
{ {
"name": "AutoconnectUDPListenPort", "name": "udpListenPort",
"shortDescription": "UDP port for autoconnect", "shortDescription": "UDP port for autoconnect",
"type": "uint32", "type": "uint32",
"defaultValue": 14550 "defaultValue": 14550
}, },
{ {
"name": "AutoconnectUDPTargetHostIP", "name": "udpTargetHostIP",
"shortDescription": "UDP target host IP for autoconnect", "shortDescription": "UDP target host IP for autoconnect",
"type": "string", "type": "string",
"defaultValue": "" "defaultValue": ""
}, },
{ {
"name": "AutoconnectUDPTargetHostPort", "name": "udpTargetHostPort",
"shortDescription": "UDP target host port for autoconnect", "shortDescription": "UDP target host port for autoconnect",
"type": "uint32", "type": "uint32",
"defaultValue": 14550 "defaultValue": 14550
},
{
"name": "autoConnectTaisyncUSB",
"shortDescription": "Automatically connect to a Taisync Ground Module",
"longDescription": "If this option is enabled GroundControl will automatically connect to a Taisync Ground Module which is connected via USB.",
"type": "bool",
"defaultValue": false
} }
] ]
...@@ -13,110 +13,74 @@ ...@@ -13,110 +13,74 @@
#include <QQmlEngine> #include <QQmlEngine>
#include <QtQml> #include <QtQml>
const char* AutoConnectSettings::name = "AutoConnect"; DECLARE_SETTINGGROUP(AutoConnect, "LinkManager")
const char* AutoConnectSettings::settingsGroup = "LinkManager";
const char* AutoConnectSettings:: autoConnectUDPSettingsName = "AutoconnectUDP";
const char* AutoConnectSettings:: autoConnectPixhawkSettingsName = "AutoconnectPixhawk";
const char* AutoConnectSettings:: autoConnectSiKRadioSettingsName = "Autoconnect3DRRadio";
const char* AutoConnectSettings:: autoConnectPX4FlowSettingsName = "AutoconnectPX4Flow";
const char* AutoConnectSettings:: autoConnectRTKGPSSettingsName = "AutoconnectRTKGPS";
const char* AutoConnectSettings:: autoConnectLibrePilotSettingsName = "AutoconnectLibrePilot";
const char* AutoConnectSettings:: autoConnectNmeaPortName = "AutoconnectNmeaPort";
const char* AutoConnectSettings:: autoConnectNmeaBaudName = "AutoconnectNmeaBaud";
const char* AutoConnectSettings:: udpListenPortName = "AutoconnectUDPListenPort";
const char* AutoConnectSettings:: udpTargetHostIPName = "AutoconnectUDPTargetHostIP";
const char* AutoConnectSettings:: udpTargetHostPortName = "AutoconnectUDPTargetHostPort";
AutoConnectSettings::AutoConnectSettings(QObject* parent)
: SettingsGroup (name, settingsGroup, parent)
, _autoConnectUDPFact (NULL)
, _autoConnectPixhawkFact (NULL)
, _autoConnectSiKRadioFact (NULL)
, _autoConnectPX4FlowFact (NULL)
, _autoConnectRTKGPSFact (NULL)
, _autoConnectLibrePilotFact(NULL)
, _autoConnectNmeaPortFact (NULL)
, _autoConnectNmeaBaudFact (NULL)
, _udpListenPortFact (NULL)
, _udpTargetHostIPFact (NULL)
, _udpTargetHostPortFact (NULL)
{ {
QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership); QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership); \
qmlRegisterUncreatableType<AutoConnectSettings>("QGroundControl.SettingsManager", 1, 0, "AutoConnectSettings", "Reference only"); qmlRegisterUncreatableType<AutoConnectSettings>("QGroundControl.SettingsManager", 1, 0, "AutoConnectSettings", "Reference only"); \
} }
Fact* AutoConnectSettings::autoConnectUDP(void) DECLARE_SETTINGSFACT(AutoConnectSettings, autoConnectUDP)
{ DECLARE_SETTINGSFACT(AutoConnectSettings, udpListenPort)
if (!_autoConnectUDPFact) { DECLARE_SETTINGSFACT(AutoConnectSettings, udpTargetHostIP)
_autoConnectUDPFact = _createSettingsFact(autoConnectUDPSettingsName); DECLARE_SETTINGSFACT(AutoConnectSettings, udpTargetHostPort)
} DECLARE_SETTINGSFACT(AutoConnectSettings, autoconnectTaisyncUSB)
return _autoConnectUDPFact;
}
Fact* AutoConnectSettings::autoConnectPixhawk(void) DECLARE_SETTINGSFACT_NO_FUNC(AutoConnectSettings, autoConnectPixhawk)
{ {
if (!_autoConnectPixhawkFact) { if (!_autoConnectPixhawkFact) {
_autoConnectPixhawkFact = _createSettingsFact(autoConnectPixhawkSettingsName); _autoConnectPixhawkFact = _createSettingsFact(autoConnectPixhawkName);
#ifdef __ios__ #ifdef __ios__
_autoConnectPixhawkFact->setVisible(false); _autoConnectPixhawkFact->setVisible(false);
#endif #endif
} }
return _autoConnectPixhawkFact; return _autoConnectPixhawkFact;
} }
Fact* AutoConnectSettings::autoConnectSiKRadio(void) DECLARE_SETTINGSFACT_NO_FUNC(AutoConnectSettings, autoConnectSiKRadio)
{ {
if (!_autoConnectSiKRadioFact) { if (!_autoConnectSiKRadioFact) {
_autoConnectSiKRadioFact = _createSettingsFact(autoConnectSiKRadioSettingsName); _autoConnectSiKRadioFact = _createSettingsFact(autoConnectSiKRadioName);
#ifdef __ios__ #ifdef __ios__
_autoConnectSiKRadioFact->setVisible(false); _autoConnectSiKRadioFact->setVisible(false);
#endif #endif
} }
return _autoConnectSiKRadioFact; return _autoConnectSiKRadioFact;
} }
Fact* AutoConnectSettings::autoConnectPX4Flow(void) DECLARE_SETTINGSFACT_NO_FUNC(AutoConnectSettings, autoConnectPX4Flow)
{ {
if (!_autoConnectPX4FlowFact) { if (!_autoConnectPX4FlowFact) {
_autoConnectPX4FlowFact = _createSettingsFact(autoConnectPX4FlowSettingsName); _autoConnectPX4FlowFact = _createSettingsFact(autoConnectPX4FlowName);
#ifdef __ios__ #ifdef __ios__
_autoConnectPX4FlowFact->setVisible(false); _autoConnectPX4FlowFact->setVisible(false);
#endif #endif
} }
return _autoConnectPX4FlowFact; return _autoConnectPX4FlowFact;
} }
Fact* AutoConnectSettings::autoConnectRTKGPS(void) DECLARE_SETTINGSFACT_NO_FUNC(AutoConnectSettings, autoConnectRTKGPS)
{ {
if (!_autoConnectRTKGPSFact) { if (!_autoConnectRTKGPSFact) {
_autoConnectRTKGPSFact = _createSettingsFact(autoConnectRTKGPSSettingsName); _autoConnectRTKGPSFact = _createSettingsFact(autoConnectRTKGPSName);
#ifdef __ios__ #ifdef __ios__
_autoConnectRTKGPSFact->setVisible(false); _autoConnectRTKGPSFact->setVisible(false);
#endif #endif
} }
return _autoConnectRTKGPSFact; return _autoConnectRTKGPSFact;
} }
Fact* AutoConnectSettings::autoConnectLibrePilot(void) DECLARE_SETTINGSFACT_NO_FUNC(AutoConnectSettings, autoConnectLibrePilot)
{ {
if (!_autoConnectLibrePilotFact) { if (!_autoConnectLibrePilotFact) {
_autoConnectLibrePilotFact = _createSettingsFact(autoConnectLibrePilotSettingsName); _autoConnectLibrePilotFact = _createSettingsFact(autoConnectLibrePilotName);
#ifdef __ios__ #ifdef __ios__
_autoConnectLibrePilotFact->setVisible(false); _autoConnectLibrePilotFact->setVisible(false);
#endif #endif
} }
return _autoConnectLibrePilotFact; return _autoConnectLibrePilotFact;
} }
Fact* AutoConnectSettings::autoConnectNmeaPort(void) DECLARE_SETTINGSFACT_NO_FUNC(AutoConnectSettings, autoConnectNmeaPort)
{ {
if (!_autoConnectNmeaPortFact) { if (!_autoConnectNmeaPortFact) {
_autoConnectNmeaPortFact = _createSettingsFact(autoConnectNmeaPortName); _autoConnectNmeaPortFact = _createSettingsFact(autoConnectNmeaPortName);
...@@ -124,11 +88,10 @@ Fact* AutoConnectSettings::autoConnectNmeaPort(void) ...@@ -124,11 +88,10 @@ Fact* AutoConnectSettings::autoConnectNmeaPort(void)
_autoConnectNmeaPortFact->setVisible(false); _autoConnectNmeaPortFact->setVisible(false);
#endif #endif
} }
return _autoConnectNmeaPortFact; return _autoConnectNmeaPortFact;
} }
Fact* AutoConnectSettings::autoConnectNmeaBaud(void) DECLARE_SETTINGSFACT_NO_FUNC(AutoConnectSettings, autoConnectNmeaBaud)
{ {
if (!_autoConnectNmeaBaudFact) { if (!_autoConnectNmeaBaudFact) {
_autoConnectNmeaBaudFact = _createSettingsFact(autoConnectNmeaBaudName); _autoConnectNmeaBaudFact = _createSettingsFact(autoConnectNmeaBaudName);
...@@ -136,33 +99,5 @@ Fact* AutoConnectSettings::autoConnectNmeaBaud(void) ...@@ -136,33 +99,5 @@ Fact* AutoConnectSettings::autoConnectNmeaBaud(void)
_autoConnectNmeaBaudFact->setVisible(false); _autoConnectNmeaBaudFact->setVisible(false);
#endif #endif
} }
return _autoConnectNmeaBaudFact; return _autoConnectNmeaBaudFact;
} }
Fact* AutoConnectSettings::udpListenPort(void)
{
if (!_udpListenPortFact) {
_udpListenPortFact = _createSettingsFact(udpListenPortName);
}
return _udpListenPortFact;
}
Fact* AutoConnectSettings::udpTargetHostIP(void)
{
if (!_udpTargetHostIPFact) {
_udpTargetHostIPFact = _createSettingsFact(udpTargetHostIPName);
}
return _udpTargetHostIPFact;
}
Fact* AutoConnectSettings::udpTargetHostPort(void)
{
if (!_udpTargetHostPortFact) {
_udpTargetHostPortFact = _createSettingsFact(udpTargetHostPortName);
}
return _udpTargetHostPortFact;
}
...@@ -7,8 +7,7 @@ ...@@ -7,8 +7,7 @@
* *
****************************************************************************/ ****************************************************************************/
#ifndef AutoConnectSettings_H #pragma once
#define AutoConnectSettings_H
#include "SettingsGroup.h" #include "SettingsGroup.h"
...@@ -17,59 +16,21 @@ class AutoConnectSettings : public SettingsGroup ...@@ -17,59 +16,21 @@ class AutoConnectSettings : public SettingsGroup
Q_OBJECT Q_OBJECT
public: public:
AutoConnectSettings(QObject* parent = NULL); AutoConnectSettings(QObject* parent = nullptr);
DEFINE_SETTING_NAME_GROUP()
DEFINE_SETTINGFACT(autoConnectUDP)
DEFINE_SETTINGFACT(autoConnectPixhawk)
DEFINE_SETTINGFACT(autoConnectSiKRadio)
DEFINE_SETTINGFACT(autoConnectPX4Flow)
DEFINE_SETTINGFACT(autoConnectRTKGPS)
DEFINE_SETTINGFACT(autoConnectLibrePilot)
DEFINE_SETTINGFACT(autoConnectNmeaPort)
DEFINE_SETTINGFACT(autoConnectNmeaBaud)
DEFINE_SETTINGFACT(udpListenPort)
DEFINE_SETTINGFACT(udpTargetHostIP)
DEFINE_SETTINGFACT(udpTargetHostPort)
DEFINE_SETTINGFACT(autoconnectTaisyncUSB)
Q_PROPERTY(Fact* autoConnectUDP READ autoConnectUDP CONSTANT)
Q_PROPERTY(Fact* autoConnectPixhawk READ autoConnectPixhawk CONSTANT)
Q_PROPERTY(Fact* autoConnectSiKRadio READ autoConnectSiKRadio CONSTANT)
Q_PROPERTY(Fact* autoConnectPX4Flow READ autoConnectPX4Flow CONSTANT)
Q_PROPERTY(Fact* autoConnectRTKGPS READ autoConnectRTKGPS CONSTANT)
Q_PROPERTY(Fact* autoConnectLibrePilot READ autoConnectLibrePilot CONSTANT)
Q_PROPERTY(Fact* autoConnectNmeaPort READ autoConnectNmeaPort CONSTANT)
Q_PROPERTY(Fact* autoConnectNmeaBaud READ autoConnectNmeaBaud CONSTANT)
Q_PROPERTY(Fact* udpListenPort READ udpListenPort CONSTANT) ///< Port to listen on for UDP autoconnect
Q_PROPERTY(Fact* udpTargetHostIP READ udpTargetHostIP CONSTANT) ///< Target host IP for UDP autoconnect, empty string for none
Q_PROPERTY(Fact* udpTargetHostPort READ udpTargetHostPort CONSTANT) ///< Target host post for UDP autoconnect
Fact* autoConnectUDP (void);
Fact* autoConnectPixhawk (void);
Fact* autoConnectSiKRadio (void);
Fact* autoConnectPX4Flow (void);
Fact* autoConnectRTKGPS (void);
Fact* autoConnectLibrePilot (void);
Fact* autoConnectNmeaPort (void);
Fact* autoConnectNmeaBaud (void);
Fact* udpListenPort (void);
Fact* udpTargetHostIP (void);
Fact* udpTargetHostPort (void);
static const char* name;
static const char* settingsGroup;
static const char* autoConnectUDPSettingsName;
static const char* autoConnectPixhawkSettingsName;
static const char* autoConnectSiKRadioSettingsName;
static const char* autoConnectPX4FlowSettingsName;
static const char* autoConnectRTKGPSSettingsName;
static const char* autoConnectLibrePilotSettingsName;
static const char* autoConnectNmeaPortName;
static const char* autoConnectNmeaBaudName;
static const char* udpListenPortName;
static const char* udpTargetHostIPName;
static const char* udpTargetHostPortName;
private:
SettingsFact* _autoConnectUDPFact;
SettingsFact* _autoConnectPixhawkFact;
SettingsFact* _autoConnectSiKRadioFact;
SettingsFact* _autoConnectPX4FlowFact;
SettingsFact* _autoConnectRTKGPSFact;
SettingsFact* _autoConnectLibrePilotFact;
SettingsFact* _autoConnectNmeaPortFact;
SettingsFact* _autoConnectNmeaBaudFact;
SettingsFact* _udpListenPortFact;
SettingsFact* _udpTargetHostIPFact;
SettingsFact* _udpTargetHostPortFact;
}; };
#endif
[ [
{ {
"name": "UserBrandImageIndoor", "name": "userBrandImageIndoor",
"shortDescription": "User-selected brand image", "shortDescription": "User-selected brand image",
"longDescription": "Location in file system of user-selected brand image (indoor)", "longDescription": "Location in file system of user-selected brand image (indoor)",
"type": "string", "type": "string",
"defaultValue": "" "defaultValue": ""
}, },
{ {
"name": "UserBrandImageOutdoor", "name": "userBrandImageOutdoor",
"shortDescription": "User-selected brand image", "shortDescription": "User-selected brand image",
"longDescription": "Location in file system of user-selected brand image (outdoor)", "longDescription": "Location in file system of user-selected brand image (outdoor)",
"type": "string", "type": "string",
......
...@@ -12,35 +12,11 @@ ...@@ -12,35 +12,11 @@
#include <QQmlEngine> #include <QQmlEngine>
#include <QtQml> #include <QtQml>
const char* BrandImageSettings::name = "BrandImage"; DECLARE_SETTINGGROUP(BrandImage, "Branding")
const char* BrandImageSettings::settingsGroup = ""; // settings are in root group
const char* BrandImageSettings::userBrandImageIndoorName = "UserBrandImageIndoor";
const char* BrandImageSettings::userBrandImageOutdoorName = "UserBrandImageOutdoor";
BrandImageSettings::BrandImageSettings(QObject* parent)
: SettingsGroup(name, settingsGroup, parent)
, _userBrandImageIndoorFact(NULL)
, _userBrandImageOutdoorFact(NULL)
{ {
QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership); QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership); \
qmlRegisterUncreatableType<BrandImageSettings>("QGroundControl.SettingsManager", 1, 0, "BrandImageSettings", "Reference only"); qmlRegisterUncreatableType<BrandImageSettings>("QGroundControl.SettingsManager", 1, 0, "BrandImageSettings", "Reference only"); \
} }
Fact* BrandImageSettings::userBrandImageIndoor(void) DECLARE_SETTINGSFACT(BrandImageSettings, userBrandImageIndoor)
{ DECLARE_SETTINGSFACT(BrandImageSettings, userBrandImageOutdoor)
if (!_userBrandImageIndoorFact) {
_userBrandImageIndoorFact = _createSettingsFact(userBrandImageIndoorName);
}
return _userBrandImageIndoorFact;
}
Fact* BrandImageSettings::userBrandImageOutdoor(void)
{
if (!_userBrandImageOutdoorFact) {
_userBrandImageOutdoorFact = _createSettingsFact(userBrandImageOutdoorName);
}
return _userBrandImageOutdoorFact;
}
...@@ -7,33 +7,16 @@ ...@@ -7,33 +7,16 @@
* *
****************************************************************************/ ****************************************************************************/
#ifndef BrandImageSettings_H #pragma once
#define BrandImageSettings_H
#include "SettingsGroup.h" #include "SettingsGroup.h"
class BrandImageSettings : public SettingsGroup class BrandImageSettings : public SettingsGroup
{ {
Q_OBJECT Q_OBJECT
public: public:
BrandImageSettings(QObject* parent = NULL); BrandImageSettings(QObject* parent = nullptr);
DEFINE_SETTING_NAME_GROUP()
Q_PROPERTY(Fact* userBrandImageIndoor READ userBrandImageIndoor CONSTANT) DEFINE_SETTINGFACT(userBrandImageIndoor)
Q_PROPERTY(Fact* userBrandImageOutdoor READ userBrandImageOutdoor CONSTANT) DEFINE_SETTINGFACT(userBrandImageOutdoor)
Fact* userBrandImageIndoor (void);
Fact* userBrandImageOutdoor (void);
static const char* name;
static const char* settingsGroup;
static const char* userBrandImageIndoorName;
static const char* userBrandImageOutdoorName;
private:
SettingsFact* _userBrandImageIndoorFact;
SettingsFact* _userBrandImageOutdoorFact;
}; };
#endif
[ [
{ {
"name": "MapProvider", "name": "mapProvider",
"shortDescription": "Currently selected map provider for flight maps", "shortDescription": "Currently selected map provider for flight maps",
"type": "uint32", "type": "uint32",
"enumStrings": "Bing,Google,Statkart,Mapbox,Esri,Eniro,VWorld", "enumStrings": "Bing,Google,Statkart,Mapbox,Esri,Eniro,VWorld",
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
"defaultValue": 0 "defaultValue": 0
}, },
{ {
"name": "MapType", "name": "mapType",
"shortDescription": "Currently selected map type for flight maps", "shortDescription": "Currently selected map type for flight maps",
"type": "uint32", "type": "uint32",
"enumStrings": "Street Map,Satellite Map,Hybrid Map,Terrain Map", "enumStrings": "Street Map,Satellite Map,Hybrid Map,Terrain Map",
......
...@@ -16,23 +16,14 @@ ...@@ -16,23 +16,14 @@
#include <QQmlEngine> #include <QQmlEngine>
#include <QtQml> #include <QtQml>
const char* FlightMapSettings::name = "FlightMap"; DECLARE_SETTINGGROUP(FlightMap, "FlightMap")
const char* FlightMapSettings::settingsGroup = "FlightMap";
const char* FlightMapSettings::mapProviderSettingsName = "MapProvider";
const char* FlightMapSettings::mapTypeSettingsName = "MapType";
FlightMapSettings::FlightMapSettings(QObject* parent)
: SettingsGroup(name, settingsGroup, parent)
, _mapProviderFact(NULL)
, _mapTypeFact(NULL)
{ {
QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership); QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership);
qmlRegisterUncreatableType<FlightMapSettings>("QGroundControl.SettingsManager", 1, 0, "FlightMapSettings", "Reference only"); qmlRegisterUncreatableType<FlightMapSettings>("QGroundControl.SettingsManager", 1, 0, "FlightMapSettings", "Reference only");
// Save the original version since we modify based on map provider // Save the original version since we modify based on map provider
_savedMapTypeStrings = _nameToMetaDataMap[mapTypeSettingsName]->enumStrings(); _savedMapTypeStrings = _nameToMetaDataMap[mapTypeName]->enumStrings();
_savedMapTypeValues = _nameToMetaDataMap[mapTypeSettingsName]->enumValues(); _savedMapTypeValues = _nameToMetaDataMap[mapTypeName]->enumValues();
#ifdef QGC_NO_GOOGLE_MAPS #ifdef QGC_NO_GOOGLE_MAPS
//-- Remove Google //-- Remove Google
...@@ -47,28 +38,20 @@ FlightMapSettings::FlightMapSettings(QObject* parent) ...@@ -47,28 +38,20 @@ FlightMapSettings::FlightMapSettings(QObject* parent)
_newMapProvider(mapProvider()->rawValue()); _newMapProvider(mapProvider()->rawValue());
} }
Fact* FlightMapSettings::mapProvider(void) DECLARE_SETTINGSFACT(FlightMapSettings, mapType)
DECLARE_SETTINGSFACT_NO_FUNC(FlightMapSettings, mapProvider)
{ {
if (!_mapProviderFact) { if (!_mapProviderFact) {
_mapProviderFact = _createSettingsFact(mapProviderSettingsName); _mapProviderFact = _createSettingsFact(mapProviderName);
connect(_mapProviderFact, &Fact::rawValueChanged, this, &FlightMapSettings::_newMapProvider); connect(_mapProviderFact, &Fact::rawValueChanged, this, &FlightMapSettings::_newMapProvider);
} }
return _mapProviderFact; return _mapProviderFact;
} }
Fact* FlightMapSettings::mapType(void)
{
if (!_mapTypeFact) {
_mapTypeFact = _createSettingsFact(mapTypeSettingsName);
}
return _mapTypeFact;
}
void FlightMapSettings::_excludeProvider(MapProvider_t provider) void FlightMapSettings::_excludeProvider(MapProvider_t provider)
{ {
FactMetaData* metaData = _nameToMetaDataMap[mapProviderSettingsName]; FactMetaData* metaData = _nameToMetaDataMap[mapProviderName];
QVariantList enumValues = metaData->enumValues(); QVariantList enumValues = metaData->enumValues();
QStringList enumStrings = metaData->enumStrings(); QStringList enumStrings = metaData->enumStrings();
_removeEnumValue(provider, enumStrings, enumValues); _removeEnumValue(provider, enumStrings, enumValues);
...@@ -94,7 +77,7 @@ void FlightMapSettings::_removeEnumValue(int value, QStringList& enumStrings, QV ...@@ -94,7 +77,7 @@ void FlightMapSettings::_removeEnumValue(int value, QStringList& enumStrings, QV
void FlightMapSettings::_newMapProvider(QVariant value) void FlightMapSettings::_newMapProvider(QVariant value)
{ {
FactMetaData* metaData = _nameToMetaDataMap[mapTypeSettingsName]; FactMetaData* metaData = _nameToMetaDataMap[mapTypeName];
QStringList enumStrings = _savedMapTypeStrings; QStringList enumStrings = _savedMapTypeStrings;
QVariantList enumValues = _savedMapTypeValues; QVariantList enumValues = _savedMapTypeValues;
......
...@@ -7,8 +7,7 @@ ...@@ -7,8 +7,7 @@
* *
****************************************************************************/ ****************************************************************************/
#ifndef FlightMapSettings_H #pragma once
#define FlightMapSettings_H
#include "SettingsGroup.h" #include "SettingsGroup.h"
...@@ -17,7 +16,7 @@ class FlightMapSettings : public SettingsGroup ...@@ -17,7 +16,7 @@ class FlightMapSettings : public SettingsGroup
Q_OBJECT Q_OBJECT
public: public:
FlightMapSettings(QObject* parent = NULL); FlightMapSettings(QObject* parent = nullptr);
// This enum must match the json meta data // This enum must match the json meta data
typedef enum { typedef enum {
...@@ -38,17 +37,9 @@ public: ...@@ -38,17 +37,9 @@ public:
mapTypeTerrain mapTypeTerrain
} MapType_t; } MapType_t;
Q_PROPERTY(Fact* mapProvider READ mapProvider CONSTANT) ///< Currently selected map provider DEFINE_SETTING_NAME_GROUP()
Q_PROPERTY(Fact* mapType READ mapType NOTIFY mapTypeChanged) ///< Current selected map type DEFINE_SETTINGFACT(mapProvider)
DEFINE_SETTINGFACT(mapType)
Fact* mapProvider (void);
Fact* mapType (void);
static const char* name;
static const char* settingsGroup;
static const char* mapProviderSettingsName;
static const char* mapTypeSettingsName;
signals: signals:
void mapTypeChanged(void); void mapTypeChanged(void);
...@@ -60,10 +51,6 @@ private: ...@@ -60,10 +51,6 @@ private:
void _removeEnumValue(int value, QStringList& enumStrings, QVariantList& enumValues); void _removeEnumValue(int value, QStringList& enumStrings, QVariantList& enumValues);
void _excludeProvider(MapProvider_t provider); void _excludeProvider(MapProvider_t provider);
SettingsFact* _mapProviderFact;
SettingsFact* _mapTypeFact;
QStringList _savedMapTypeStrings; QStringList _savedMapTypeStrings;
QVariantList _savedMapTypeValues; QVariantList _savedMapTypeValues;
}; };
#endif
[ [
{ {
"name": "GuidedMinimumAltitude", "name": "guidedMinimumAltitude",
"shortDescription": "Minimum altitude for guided actions altitude slider.", "shortDescription": "Minimum altitude for guided actions altitude slider.",
"type": "double", "type": "double",
"units": "m", "units": "m",
"defaultValue": 2 "defaultValue": 2
}, },
{ {
"name": "GuidedMaximumAltitude", "name": "guidedMaximumAltitude",
"shortDescription": "Maximum altitude for guided actions altitude slider.", "shortDescription": "Maximum altitude for guided actions altitude slider.",
"type": "double", "type": "double",
"units": "m", "units": "m",
......
...@@ -8,40 +8,15 @@ ...@@ -8,40 +8,15 @@
****************************************************************************/ ****************************************************************************/
#include "FlyViewSettings.h" #include "FlyViewSettings.h"
#include "QGCPalette.h"
#include "QGCApplication.h"
#include <QQmlEngine> #include <QQmlEngine>
#include <QtQml> #include <QtQml>
#include <QStandardPaths>
const char* FlyViewSettings::name = "FlyView"; DECLARE_SETTINGGROUP(FlyView, "FlyView")
const char* FlyViewSettings::settingsGroup = "FlyView";
const char* FlyViewSettings::guidedMinimumAltitudeName = "GuidedMinimumAltitude";
const char* FlyViewSettings::guidedMaximumAltitudeName = "GuidedMaximumAltitude";
FlyViewSettings::FlyViewSettings(QObject* parent)
: SettingsGroup (name, settingsGroup, parent)
, _guidedMinimumAltitudeFact(NULL)
, _guidedMaximumAltitudeFact(NULL)
{ {
QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership); QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership); \
qmlRegisterUncreatableType<FlyViewSettings>("QGroundControl.SettingsManager", 1, 0, "FlyViewSettings", "Reference only"); qmlRegisterUncreatableType<FlyViewSettings>("QGroundControl.SettingsManager", 1, 0, "FlyViewSettings", "Reference only"); \
} }
Fact* FlyViewSettings::guidedMinimumAltitude(void) DECLARE_SETTINGSFACT(FlyViewSettings, guidedMinimumAltitude)
{ DECLARE_SETTINGSFACT(FlyViewSettings, guidedMaximumAltitude)
if (!_guidedMinimumAltitudeFact) {
_guidedMinimumAltitudeFact = _createSettingsFact(guidedMinimumAltitudeName);
}
return _guidedMinimumAltitudeFact;
}
Fact* FlyViewSettings::guidedMaximumAltitude(void)
{
if (!_guidedMaximumAltitudeFact) {
_guidedMaximumAltitudeFact = _createSettingsFact(guidedMaximumAltitudeName);
}
return _guidedMaximumAltitudeFact;
}
...@@ -14,23 +14,9 @@ ...@@ -14,23 +14,9 @@
class FlyViewSettings : public SettingsGroup class FlyViewSettings : public SettingsGroup
{ {
Q_OBJECT Q_OBJECT
public: public:
FlyViewSettings(QObject* parent = NULL); FlyViewSettings(QObject* parent = nullptr);
DEFINE_SETTING_NAME_GROUP()
Q_PROPERTY(Fact* guidedMinimumAltitude READ guidedMinimumAltitude CONSTANT) DEFINE_SETTINGFACT(guidedMinimumAltitude)
Q_PROPERTY(Fact* guidedMaximumAltitude READ guidedMaximumAltitude CONSTANT) DEFINE_SETTINGFACT(guidedMaximumAltitude)
Fact* guidedMinimumAltitude(void);
Fact* guidedMaximumAltitude(void);
static const char* name;
static const char* settingsGroup;
static const char* guidedMinimumAltitudeName;
static const char* guidedMaximumAltitudeName;
private:
SettingsFact* _guidedMinimumAltitudeFact;
SettingsFact* _guidedMaximumAltitudeFact;
}; };
...@@ -12,12 +12,8 @@ ...@@ -12,12 +12,8 @@
#include <QQmlEngine> #include <QQmlEngine>
#include <QtQml> #include <QtQml>
const char* PlanViewSettings::name = "PlanView"; DECLARE_SETTINGGROUP(PlanView, "PlanView")
const char* PlanViewSettings::settingsGroup = "PlanView";
PlanViewSettings::PlanViewSettings(QObject* parent)
: SettingsGroup(name, settingsGroup, parent)
{ {
QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership); QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership); \
qmlRegisterUncreatableType<PlanViewSettings>("QGroundControl.SettingsManager", 1, 0, "PlanViewSettings", "Reference only"); qmlRegisterUncreatableType<PlanViewSettings>("QGroundControl.SettingsManager", 1, 0, "PlanViewSettings", "Reference only"); \
} }
...@@ -14,13 +14,9 @@ ...@@ -14,13 +14,9 @@
class PlanViewSettings : public SettingsGroup class PlanViewSettings : public SettingsGroup
{ {
Q_OBJECT Q_OBJECT
public: public:
PlanViewSettings(QObject* parent = NULL); PlanViewSettings(QObject* parent = nullptr);
DEFINE_SETTING_NAME_GROUP()
// This is currently only used to set custom build visibility of the Plan view settings ui. // This is currently only used to set custom build visibility of the Plan view settings ui.
// The settings themselves related to PlanView are in still in AppSettings due to historical reasons. // The settings themselves related to PlanView are in still in AppSettings due to historical reasons.
static const char* name;
static const char* settingsGroup;
}; };
[ [
{ {
"name": "SurveyInAccuracyLimit", "name": "surveyInAccuracyLimit",
"shortDescription": "Survey in accuracy (U-blox only)", "shortDescription": "Survey in accuracy (U-blox only)",
"longDescription": "The maximum accuracy allowed prior to completing survey in.", "longDescription": "The maximum accuracy allowed prior to completing survey in.",
"type": "double", "type": "double",
...@@ -11,7 +11,7 @@ ...@@ -11,7 +11,7 @@
"qgcRebootRequired": true "qgcRebootRequired": true
}, },
{ {
"name": "SurveyInMinObservationDuration", "name": "surveyInMinObservationDuration",
"shortDescription": "Minimum observation time", "shortDescription": "Minimum observation time",
"longDescription": "Defines the minimum amount of observation time for the position calculation.", "longDescription": "Defines the minimum amount of observation time for the position calculation.",
"type": "Uint32", "type": "Uint32",
...@@ -22,7 +22,7 @@ ...@@ -22,7 +22,7 @@
"qgcRebootRequired": true "qgcRebootRequired": true
}, },
{ {
"name": "UseFixedBasePosition", "name": "useFixedBasePosition",
"shortDescription": "Use specified base position", "shortDescription": "Use specified base position",
"longDescription": "Specify the values for the RTK base position without having to do a survey in.", "longDescription": "Specify the values for the RTK base position without having to do a survey in.",
"type": "bool", "type": "bool",
...@@ -30,7 +30,7 @@ ...@@ -30,7 +30,7 @@
"qgcRebootRequired": true "qgcRebootRequired": true
}, },
{ {
"name": "FixedBasePositionLatitude", "name": "fixedBasePositionLatitude",
"shortDescription": "Base Position Latitude", "shortDescription": "Base Position Latitude",
"longDescription": "Defines the latitude of the fixed RTK base position.", "longDescription": "Defines the latitude of the fixed RTK base position.",
"type": "double", "type": "double",
...@@ -41,7 +41,7 @@ ...@@ -41,7 +41,7 @@
"qgcRebootRequired": true "qgcRebootRequired": true
}, },
{ {
"name": "FixedBasePositionLongitude", "name": "fixedBasePositionLongitude",
"shortDescription": "Base Position Longitude", "shortDescription": "Base Position Longitude",
"longDescription": "Defines the longitude of the fixed RTK base position.", "longDescription": "Defines the longitude of the fixed RTK base position.",
"type": "double", "type": "double",
...@@ -52,7 +52,7 @@ ...@@ -52,7 +52,7 @@
"qgcRebootRequired": true "qgcRebootRequired": true
}, },
{ {
"name": "FixedBasePositionAltitude", "name": "fixedBasePositionAltitude",
"shortDescription": "Base Position Alt (WGS84)", "shortDescription": "Base Position Alt (WGS84)",
"longDescription": "Defines the altitude of the fixed RTK base position.", "longDescription": "Defines the altitude of the fixed RTK base position.",
"type": "float", "type": "float",
...@@ -62,7 +62,7 @@ ...@@ -62,7 +62,7 @@
"qgcRebootRequired": true "qgcRebootRequired": true
}, },
{ {
"name": "FixedBasePositionAccuracy", "name": "fixedBasePositionAccuracy",
"shortDescription": "Base Position Accuracy", "shortDescription": "Base Position Accuracy",
"longDescription": "Defines the accuracy of the fixed RTK base position.", "longDescription": "Defines the accuracy of the fixed RTK base position.",
"type": "float", "type": "float",
......
...@@ -12,90 +12,16 @@ ...@@ -12,90 +12,16 @@
#include <QQmlEngine> #include <QQmlEngine>
#include <QtQml> #include <QtQml>
const char* RTKSettings::name = "RTK"; DECLARE_SETTINGGROUP(RTK, "RTK")
const char* RTKSettings::settingsGroup = "RTK";
const char* RTKSettings::surveyInAccuracyLimitName = "SurveyInAccuracyLimit";
const char* RTKSettings::surveyInMinObservationDurationName = "SurveyInMinObservationDuration";
const char* RTKSettings::useFixedBasePositionName = "UseFixedBasePosition";
const char* RTKSettings::fixedBasePositionLatitudeName = "FixedBasePositionLatitude";
const char* RTKSettings::fixedBasePositionLongitudeName = "FixedBasePositionLongitude";
const char* RTKSettings::fixedBasePositionAltitudeName = "FixedBasePositionAltitude";
const char* RTKSettings::fixedBasePositionAccuracyName = "FixedBasePositionAccuracy";
RTKSettings::RTKSettings(QObject* parent)
: SettingsGroup (name, settingsGroup, parent)
, _surveyInAccuracyLimitFact (nullptr)
, _surveyInMinObservationDurationFact (nullptr)
, _useFixedBasePositionFact (nullptr)
, _fixedBasePositionLatitudeFact (nullptr)
, _fixedBasePositionLongitudeFact (nullptr)
, _fixedBasePositionAltitudeFact (nullptr)
, _fixedBasePositionAccuracyFact (nullptr)
{
QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership);
qmlRegisterUncreatableType<RTKSettings>("QGroundControl.SettingsManager", 1, 0, "RTKSettings", "Reference only");
}
Fact* RTKSettings::surveyInAccuracyLimit(void)
{ {
if (!_surveyInAccuracyLimitFact) { QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership); \
_surveyInAccuracyLimitFact = _createSettingsFact(surveyInAccuracyLimitName); qmlRegisterUncreatableType<RTKSettings>("QGroundControl.SettingsManager", 1, 0, "RTKSettings", "Reference only"); \
}
return _surveyInAccuracyLimitFact;
} }
Fact* RTKSettings::surveyInMinObservationDuration(void) DECLARE_SETTINGSFACT(RTKSettings, surveyInAccuracyLimit)
{ DECLARE_SETTINGSFACT(RTKSettings, surveyInMinObservationDuration)
if (!_surveyInMinObservationDurationFact) { DECLARE_SETTINGSFACT(RTKSettings, useFixedBasePosition)
_surveyInMinObservationDurationFact = _createSettingsFact(surveyInMinObservationDurationName); DECLARE_SETTINGSFACT(RTKSettings, fixedBasePositionLatitude)
} DECLARE_SETTINGSFACT(RTKSettings, fixedBasePositionLongitude)
DECLARE_SETTINGSFACT(RTKSettings, fixedBasePositionAltitude)
return _surveyInMinObservationDurationFact; DECLARE_SETTINGSFACT(RTKSettings, fixedBasePositionAccuracy)
}
Fact* RTKSettings::useFixedBasePosition(void)
{
if (!_useFixedBasePositionFact) {
_useFixedBasePositionFact = _createSettingsFact(useFixedBasePositionName);
}
return _useFixedBasePositionFact;
}
Fact* RTKSettings::fixedBasePositionLatitude(void)
{
if (!_fixedBasePositionLatitudeFact) {
_fixedBasePositionLatitudeFact = _createSettingsFact(fixedBasePositionLatitudeName);
}
return _fixedBasePositionLatitudeFact;
}
Fact* RTKSettings::fixedBasePositionLongitude(void)
{
if (!_fixedBasePositionLongitudeFact) {
_fixedBasePositionLongitudeFact = _createSettingsFact(fixedBasePositionLongitudeName);
}
return _fixedBasePositionLongitudeFact;
}
Fact* RTKSettings::fixedBasePositionAltitude(void)
{
if (!_fixedBasePositionAltitudeFact) {
_fixedBasePositionAltitudeFact = _createSettingsFact(fixedBasePositionAltitudeName);
}
return _fixedBasePositionAltitudeFact;
}
Fact* RTKSettings::fixedBasePositionAccuracy(void)
{
if (!_fixedBasePositionAccuracyFact) {
_fixedBasePositionAccuracyFact = _createSettingsFact(fixedBasePositionAccuracyName);
}
return _fixedBasePositionAccuracyFact;
}
...@@ -14,43 +14,14 @@ ...@@ -14,43 +14,14 @@
class RTKSettings : public SettingsGroup class RTKSettings : public SettingsGroup
{ {
Q_OBJECT Q_OBJECT
public: public:
RTKSettings(QObject* parent = NULL); RTKSettings(QObject* parent = nullptr);
DEFINE_SETTING_NAME_GROUP()
Q_PROPERTY(Fact* surveyInAccuracyLimit READ surveyInAccuracyLimit CONSTANT) DEFINE_SETTINGFACT(surveyInAccuracyLimit)
Q_PROPERTY(Fact* surveyInMinObservationDuration READ surveyInMinObservationDuration CONSTANT) DEFINE_SETTINGFACT(surveyInMinObservationDuration)
Q_PROPERTY(Fact* useFixedBasePosition READ useFixedBasePosition CONSTANT) DEFINE_SETTINGFACT(useFixedBasePosition)
Q_PROPERTY(Fact* fixedBasePositionLatitude READ fixedBasePositionLatitude CONSTANT) DEFINE_SETTINGFACT(fixedBasePositionLatitude)
Q_PROPERTY(Fact* fixedBasePositionLongitude READ fixedBasePositionLongitude CONSTANT) DEFINE_SETTINGFACT(fixedBasePositionLongitude)
Q_PROPERTY(Fact* fixedBasePositionAltitude READ fixedBasePositionAltitude CONSTANT) DEFINE_SETTINGFACT(fixedBasePositionAltitude)
Q_PROPERTY(Fact* fixedBasePositionAccuracy READ fixedBasePositionAccuracy CONSTANT) DEFINE_SETTINGFACT(fixedBasePositionAccuracy)
Fact* surveyInAccuracyLimit (void);
Fact* surveyInMinObservationDuration(void);
Fact* useFixedBasePosition (void);
Fact* fixedBasePositionLatitude (void);
Fact* fixedBasePositionLongitude (void);
Fact* fixedBasePositionAltitude (void);
Fact* fixedBasePositionAccuracy (void);
static const char* name;
static const char* settingsGroup;
static const char* surveyInAccuracyLimitName;
static const char* surveyInMinObservationDurationName;
static const char* useFixedBasePositionName;
static const char* fixedBasePositionLatitudeName;
static const char* fixedBasePositionLongitudeName;
static const char* fixedBasePositionAltitudeName;
static const char* fixedBasePositionAccuracyName;
private:
SettingsFact* _surveyInAccuracyLimitFact;
SettingsFact* _surveyInMinObservationDurationFact;
SettingsFact* _useFixedBasePositionFact;
SettingsFact* _fixedBasePositionLatitudeFact;
SettingsFact* _fixedBasePositionLongitudeFact;
SettingsFact* _fixedBasePositionAltitudeFact;
SettingsFact* _fixedBasePositionAccuracyFact;
}; };
...@@ -17,17 +17,19 @@ ...@@ -17,17 +17,19 @@
#include <QVariantList> #include <QVariantList>
#define DEFINE_SETTINGGROUP(CLASS) \ #define DEFINE_SETTING_NAME_GROUP() \
static const char* CLASS ## Settings ## GroupName; static const char* name; \
static const char* settingsGroup;
#define DECLARE_SETTINGGROUP(CLASS) \ #define DECLARE_SETTINGGROUP(NAME, GROUP) \
const char* CLASS ## Settings::CLASS ## Settings ## GroupName = #CLASS; \ const char* NAME ## Settings::name = #NAME; \
CLASS ## Settings::CLASS ## Settings(QObject* parent) \ const char* NAME ## Settings::settingsGroup = GROUP; \
: SettingsGroup(CLASS ## Settings ## GroupName, QString() /* root settings group */, parent) NAME ## Settings::NAME ## Settings(QObject* parent) \
: SettingsGroup(name, settingsGroup, parent)
#define DECLARE_SETTINGSFACT(CLASS, NAME) \ #define DECLARE_SETTINGSFACT(CLASS, NAME) \
const char* CLASS::NAME ## Name = #NAME; \ const char* CLASS::NAME ## Name = #NAME; \
Fact* CLASS::NAME(void) \ Fact* CLASS::NAME() \
{ \ { \
if (!_ ## NAME ## Fact) { \ if (!_ ## NAME ## Fact) { \
_ ## NAME ## Fact = _createSettingsFact(NAME ## Name); \ _ ## NAME ## Fact = _createSettingsFact(NAME ## Name); \
...@@ -35,15 +37,17 @@ ...@@ -35,15 +37,17 @@
return _ ## NAME ## Fact; \ return _ ## NAME ## Fact; \
} }
#define DECLARE_SETTINGSFACT_NO_FUNC(CLASS, NAME) \
const char* CLASS::NAME ## Name = #NAME; \
Fact* CLASS::NAME()
#define DEFINE_SETTINGFACT(NAME) \ #define DEFINE_SETTINGFACT(NAME) \
private: \
SettingsFact* _ ## NAME ## Fact = nullptr; \
public: \ public: \
Q_PROPERTY(Fact* NAME READ NAME CONSTANT) \ Q_PROPERTY(Fact* NAME READ NAME CONSTANT) \
Fact* NAME(); \ Fact* NAME(); \
static const char* NAME ## Name; \ static const char* NAME ## Name;
private: \
SettingsFact* _ ## NAME ## Fact;
#define INIT_SETTINGFACT(NAME) _ ## NAME ## Fact = NULL
/// Provides access to group of settings. The group is named and has a visible property associated with which can control whether the group /// Provides access to group of settings. The group is named and has a visible property associated with which can control whether the group
/// is shows in the ui. /// is shows in the ui.
...@@ -54,16 +58,15 @@ class SettingsGroup : public QObject ...@@ -54,16 +58,15 @@ class SettingsGroup : public QObject
public: public:
/// @param name Name for this Settings group /// @param name Name for this Settings group
/// @param settingsGroup Group to place settings in for QSettings::setGroup /// @param settingsGroup Group to place settings in for QSettings::setGroup
SettingsGroup(const QString& name, const QString& settingsGroup, QObject* parent = NULL); SettingsGroup(const QString &name, const QString &settingsGroup, QObject* parent = nullptr);
Q_PROPERTY(bool visible MEMBER _visible CONSTANT) Q_PROPERTY(bool visible MEMBER _visible CONSTANT)
protected: protected:
SettingsFact* _createSettingsFact(const QString& factName); SettingsFact* _createSettingsFact(const QString& factName);
bool _visible;
QString _name; ///< Name for group. Used to generate name for loaded json meta data file. QString _name;
QString _settingsGroup; ///< QSettings group which contains these settings. empty for settings in root QString _settingsGroup;
bool _visible;
QMap<QString, FactMetaData*> _nameToMetaDataMap; QMap<QString, FactMetaData*> _nameToMetaDataMap;
}; };
......
...@@ -12,116 +12,95 @@ ...@@ -12,116 +12,95 @@
#include <QQmlEngine> #include <QQmlEngine>
#include <QtQml> #include <QtQml>
const char* UnitsSettings::name = "Units"; DECLARE_SETTINGGROUP(Units, "Units")
const char* UnitsSettings::settingsGroup = ""; // settings are in root group
const char* UnitsSettings::distanceUnitsSettingsName = "DistanceUnits";
const char* UnitsSettings::areaUnitsSettingsName = "AreaUnits";
const char* UnitsSettings::speedUnitsSettingsName = "SpeedUnits";
const char* UnitsSettings::temperatureUnitsSettingsName = "TemperatureUnits";
UnitsSettings::UnitsSettings(QObject* parent)
: SettingsGroup(name, settingsGroup, parent)
, _distanceUnitsFact(NULL)
, _areaUnitsFact(NULL)
, _speedUnitsFact(NULL)
, _temperatureUnitsFact(NULL)
{ {
QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership); QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership);
qmlRegisterUncreatableType<UnitsSettings>("QGroundControl.SettingsManager", 1, 0, "UnitsSettings", "Reference only"); qmlRegisterUncreatableType<UnitsSettings>("QGroundControl.SettingsManager", 1, 0, "UnitsSettings", "Reference only");
} }
Fact* UnitsSettings::distanceUnits(void) DECLARE_SETTINGSFACT_NO_FUNC(UnitsSettings, distanceUnits)
{ {
if (!_distanceUnitsFact) { if (!_distanceUnitsFact) {
// Distance/Area/Speed units settings can't be loaded from json since it creates an infinite loop of meta data loading. // Distance/Area/Speed units settings can't be loaded from json since it creates an infinite loop of meta data loading.
QStringList enumStrings; QStringList enumStrings;
QVariantList enumValues; QVariantList enumValues;
enumStrings << "Feet" << "Meters"; enumStrings << "Feet" << "Meters";
enumValues << QVariant::fromValue((uint32_t)DistanceUnitsFeet) << QVariant::fromValue((uint32_t)DistanceUnitsMeters); enumValues << QVariant::fromValue(static_cast<uint32_t>(DistanceUnitsFeet)) << QVariant::fromValue(static_cast<uint32_t>(DistanceUnitsMeters));
FactMetaData* metaData = new FactMetaData(FactMetaData::valueTypeUint32, this); FactMetaData* metaData = new FactMetaData(FactMetaData::valueTypeUint32, this);
metaData->setName(distanceUnitsSettingsName); metaData->setName(distanceUnitsName);
metaData->setShortDescription(tr("Distance units")); metaData->setShortDescription(tr("Distance units"));
metaData->setEnumInfo(enumStrings, enumValues); metaData->setEnumInfo(enumStrings, enumValues);
metaData->setRawDefaultValue(DistanceUnitsMeters); metaData->setRawDefaultValue(DistanceUnitsMeters);
metaData->setQGCRebootRequired(true); metaData->setQGCRebootRequired(true);
_distanceUnitsFact = new SettingsFact(_settingsGroup, metaData, this); _distanceUnitsFact = new SettingsFact(_settingsGroup, metaData, this);
} }
return _distanceUnitsFact; return _distanceUnitsFact;
} }
Fact* UnitsSettings::areaUnits(void) DECLARE_SETTINGSFACT_NO_FUNC(UnitsSettings, areaUnits)
{ {
if (!_areaUnitsFact) { if (!_areaUnitsFact) {
// Distance/Area/Speed units settings can't be loaded from json since it creates an infinite loop of meta data loading. // Distance/Area/Speed units settings can't be loaded from json since it creates an infinite loop of meta data loading.
QStringList enumStrings; QStringList enumStrings;
QVariantList enumValues; QVariantList enumValues;
enumStrings << "SquareFeet" << "SquareMeters" << "SquareKilometers" << "Hectares" << "Acres" << "SquareMiles"; enumStrings << "SquareFeet" << "SquareMeters" << "SquareKilometers" << "Hectares" << "Acres" << "SquareMiles";
enumValues << QVariant::fromValue((uint32_t)AreaUnitsSquareFeet) << QVariant::fromValue((uint32_t)AreaUnitsSquareMeters) << QVariant::fromValue((uint32_t)AreaUnitsSquareKilometers) << QVariant::fromValue((uint32_t)AreaUnitsHectares) << QVariant::fromValue((uint32_t)AreaUnitsAcres) << QVariant::fromValue((uint32_t)AreaUnitsSquareMiles); enumValues <<
QVariant::fromValue(static_cast<uint32_t>(AreaUnitsSquareFeet)) <<
QVariant::fromValue(static_cast<uint32_t>(AreaUnitsSquareMeters)) <<
QVariant::fromValue(static_cast<uint32_t>(AreaUnitsSquareKilometers)) <<
QVariant::fromValue(static_cast<uint32_t>(AreaUnitsHectares)) <<
QVariant::fromValue(static_cast<uint32_t>(AreaUnitsAcres)) <<
QVariant::fromValue(static_cast<uint32_t>(AreaUnitsSquareMiles));
FactMetaData* metaData = new FactMetaData(FactMetaData::valueTypeUint32, this); FactMetaData* metaData = new FactMetaData(FactMetaData::valueTypeUint32, this);
metaData->setName(areaUnitsSettingsName); metaData->setName(areaUnitsName);
metaData->setShortDescription(tr("Area units")); metaData->setShortDescription(tr("Area units"));
metaData->setEnumInfo(enumStrings, enumValues); metaData->setEnumInfo(enumStrings, enumValues);
metaData->setRawDefaultValue(AreaUnitsSquareMeters); metaData->setRawDefaultValue(AreaUnitsSquareMeters);
metaData->setQGCRebootRequired(true); metaData->setQGCRebootRequired(true);
_areaUnitsFact = new SettingsFact(_settingsGroup, metaData, this); _areaUnitsFact = new SettingsFact(_settingsGroup, metaData, this);
} }
return _areaUnitsFact; return _areaUnitsFact;
} }
Fact* UnitsSettings::speedUnits(void) DECLARE_SETTINGSFACT_NO_FUNC(UnitsSettings, speedUnits)
{ {
if (!_speedUnitsFact) { if (!_speedUnitsFact) {
// Distance/Area/Speed units settings can't be loaded from json since it creates an infinite loop of meta data loading. // Distance/Area/Speed units settings can't be loaded from json since it creates an infinite loop of meta data loading.
QStringList enumStrings; QStringList enumStrings;
QVariantList enumValues; QVariantList enumValues;
enumStrings << "Feet/second" << "Meters/second" << "Miles/hour" << "Kilometers/hour" << "Knots"; enumStrings << "Feet/second" << "Meters/second" << "Miles/hour" << "Kilometers/hour" << "Knots";
enumValues << QVariant::fromValue((uint32_t)SpeedUnitsFeetPerSecond) << QVariant::fromValue((uint32_t)SpeedUnitsMetersPerSecond) << QVariant::fromValue((uint32_t)SpeedUnitsMilesPerHour) << QVariant::fromValue((uint32_t)SpeedUnitsKilometersPerHour) << QVariant::fromValue((uint32_t)SpeedUnitsKnots); enumValues <<
QVariant::fromValue(static_cast<uint32_t>(SpeedUnitsFeetPerSecond)) <<
QVariant::fromValue(static_cast<uint32_t>(SpeedUnitsMetersPerSecond)) <<
QVariant::fromValue(static_cast<uint32_t>(SpeedUnitsMilesPerHour)) <<
QVariant::fromValue(static_cast<uint32_t>(SpeedUnitsKilometersPerHour)) <<
QVariant::fromValue(static_cast<uint32_t>(SpeedUnitsKnots));
FactMetaData* metaData = new FactMetaData(FactMetaData::valueTypeUint32, this); FactMetaData* metaData = new FactMetaData(FactMetaData::valueTypeUint32, this);
metaData->setName(speedUnitsSettingsName); metaData->setName(speedUnitsName);
metaData->setShortDescription(tr("Speed units")); metaData->setShortDescription(tr("Speed units"));
metaData->setEnumInfo(enumStrings, enumValues); metaData->setEnumInfo(enumStrings, enumValues);
metaData->setRawDefaultValue(SpeedUnitsMetersPerSecond); metaData->setRawDefaultValue(SpeedUnitsMetersPerSecond);
metaData->setQGCRebootRequired(true); metaData->setQGCRebootRequired(true);
_speedUnitsFact = new SettingsFact(_settingsGroup, metaData, this); _speedUnitsFact = new SettingsFact(_settingsGroup, metaData, this);
} }
return _speedUnitsFact; return _speedUnitsFact;
} }
Fact* UnitsSettings::temperatureUnits(void) DECLARE_SETTINGSFACT_NO_FUNC(UnitsSettings, temperatureUnits)
{ {
if (!_temperatureUnitsFact) { if (!_temperatureUnitsFact) {
// Units settings can't be loaded from json since it creates an infinite loop of meta data loading. // Units settings can't be loaded from json since it creates an infinite loop of meta data loading.
QStringList enumStrings; QStringList enumStrings;
QVariantList enumValues; QVariantList enumValues;
enumStrings << "Celsius" << "Farenheit"; enumStrings << "Celsius" << "Farenheit";
enumValues << QVariant::fromValue((uint32_t)TemperatureUnitsCelsius) << QVariant::fromValue((uint32_t)TemperatureUnitsFarenheit); enumValues << QVariant::fromValue(static_cast<uint32_t>(TemperatureUnitsCelsius)) << QVariant::fromValue(static_cast<uint32_t>(TemperatureUnitsFarenheit));
FactMetaData* metaData = new FactMetaData(FactMetaData::valueTypeUint32, this); FactMetaData* metaData = new FactMetaData(FactMetaData::valueTypeUint32, this);
metaData->setName(temperatureUnitsSettingsName); metaData->setName(temperatureUnitsName);
metaData->setShortDescription(tr("Temperature units")); metaData->setShortDescription(tr("Temperature units"));
metaData->setEnumInfo(enumStrings, enumValues); metaData->setEnumInfo(enumStrings, enumValues);
metaData->setRawDefaultValue(TemperatureUnitsCelsius); metaData->setRawDefaultValue(TemperatureUnitsCelsius);
metaData->setQGCRebootRequired(true); metaData->setQGCRebootRequired(true);
_temperatureUnitsFact = new SettingsFact(_settingsGroup, metaData, this); _temperatureUnitsFact = new SettingsFact(_settingsGroup, metaData, this);
} }
return _temperatureUnitsFact; return _temperatureUnitsFact;
} }
...@@ -17,7 +17,7 @@ class UnitsSettings : public SettingsGroup ...@@ -17,7 +17,7 @@ class UnitsSettings : public SettingsGroup
Q_OBJECT Q_OBJECT
public: public:
UnitsSettings(QObject* parent = NULL); UnitsSettings(QObject* parent = nullptr);
enum DistanceUnits { enum DistanceUnits {
DistanceUnitsFeet = 0, DistanceUnitsFeet = 0,
...@@ -51,29 +51,12 @@ public: ...@@ -51,29 +51,12 @@ public:
Q_ENUM(SpeedUnits) Q_ENUM(SpeedUnits)
Q_ENUM(TemperatureUnits) Q_ENUM(TemperatureUnits)
Q_PROPERTY(Fact* distanceUnits READ distanceUnits CONSTANT) DEFINE_SETTING_NAME_GROUP()
Q_PROPERTY(Fact* areaUnits READ areaUnits CONSTANT)
Q_PROPERTY(Fact* speedUnits READ speedUnits CONSTANT)
Q_PROPERTY(Fact* temperatureUnits READ temperatureUnits CONSTANT)
Fact* distanceUnits (void); DEFINE_SETTINGFACT(distanceUnits)
Fact* areaUnits (void); DEFINE_SETTINGFACT(areaUnits)
Fact* speedUnits (void); DEFINE_SETTINGFACT(speedUnits)
Fact* temperatureUnits (void); DEFINE_SETTINGFACT(temperatureUnits)
static const char* name;
static const char* settingsGroup;
static const char* distanceUnitsSettingsName;
static const char* areaUnitsSettingsName;
static const char* speedUnitsSettingsName;
static const char* temperatureUnitsSettingsName;
private:
SettingsFact* _distanceUnitsFact;
SettingsFact* _areaUnitsFact;
SettingsFact* _speedUnitsFact;
SettingsFact* _temperatureUnitsFact;
}; };
#endif #endif
[ [
{ {
"name": "VideoSource", "name": "videoSource",
"shortDescription": "Video source", "shortDescription": "Video source",
"longDescription": "Source for video. UDP, TCP, RTSP and UVC Cameras may be supported depending on Vehicle and ground station version.", "longDescription": "Source for video. UDP, TCP, RTSP and UVC Cameras may be supported depending on Vehicle and ground station version.",
"type": "string", "type": "string",
"defaultValue": "" "defaultValue": ""
}, },
{ {
"name": "VideoUDPPort", "name": "udpPort",
"shortDescription": "Video UDP Port", "shortDescription": "Video UDP Port",
"longDescription": "UDP port to bind to for video stream.", "longDescription": "UDP port to bind to for video stream.",
"type": "uint16", "type": "uint16",
...@@ -15,28 +15,28 @@ ...@@ -15,28 +15,28 @@
"defaultValue": 5600 "defaultValue": 5600
}, },
{ {
"name": "VideoRTSPUrl", "name": "rtspUrl",
"shortDescription": "Video RTSP Url", "shortDescription": "Video RTSP Url",
"longDescription": "RTSP url address and port to bind to for video stream. Example: rtsp://192.168.42.1:554/live", "longDescription": "RTSP url address and port to bind to for video stream. Example: rtsp://192.168.42.1:554/live",
"type": "string", "type": "string",
"defaultValue": "" "defaultValue": ""
}, },
{ {
"name": "VideoTCPUrl", "name": "tcpUrl",
"shortDescription": "Video TCP Url", "shortDescription": "Video TCP Url",
"longDescription": "TCP url address and port to bind to for video stream. Example: 192.168.143.200:3001", "longDescription": "TCP url address and port to bind to for video stream. Example: 192.168.143.200:3001",
"type": "string", "type": "string",
"defaultValue": "" "defaultValue": ""
}, },
{ {
"name": "VideoSavePath", "name": "videoSavePath",
"shortDescription": "Video save directory", "shortDescription": "Video save directory",
"longDescription": "Directory to save videos to.", "longDescription": "Directory to save videos to.",
"type": "string", "type": "string",
"defaultValue": "" "defaultValue": ""
}, },
{ {
"name": "VideoAspectRatio", "name": "aspectRatio",
"shortDescription": "Video Aspect Ratio", "shortDescription": "Video Aspect Ratio",
"longDescription": "Video Aspect Ratio (width / height). Use 0.0 to ignore it.", "longDescription": "Video Aspect Ratio (width / height). Use 0.0 to ignore it.",
"type": "float", "type": "float",
...@@ -44,7 +44,7 @@ ...@@ -44,7 +44,7 @@
"defaultValue": 1.777777 "defaultValue": 1.777777
}, },
{ {
"name": "VideoGridLines", "name": "gridLines",
"shortDescription": "Video Grid Lines", "shortDescription": "Video Grid Lines",
"longDescription": "Displays a grid overlaid over the video view.", "longDescription": "Displays a grid overlaid over the video view.",
"type": "uint32", "type": "uint32",
...@@ -53,14 +53,23 @@ ...@@ -53,14 +53,23 @@
"defaultValue": 0 "defaultValue": 0
}, },
{ {
"name": "ShowRecControl", "name": "videoFit",
"shortDescription": "Video Display Fit",
"longDescription": "Handle Video Aspect Ratio.",
"type": "uint32",
"enumStrings": "Fit Width,Fit Height,Stretch",
"enumValues": "0,1,2",
"defaultValue": 1
},
{
"name": "showRecControl",
"shortDescription": "Show Video Record Control", "shortDescription": "Show Video Record Control",
"longDescription": "Show recording control in the UI.", "longDescription": "Show recording control in the UI.",
"type": "bool", "type": "bool",
"defaultValue": true "defaultValue": true
}, },
{ {
"name": "RecordingFormat", "name": "recordingFormat",
"shortDescription": "Video Recording Format", "shortDescription": "Video Recording Format",
"longDescription": "Video recording file format.", "longDescription": "Video recording file format.",
"type": "uint32", "type": "uint32",
...@@ -69,7 +78,7 @@ ...@@ -69,7 +78,7 @@
"defaultValue": 0 "defaultValue": 0
}, },
{ {
"name": "MaxVideoSize", "name": "maxVideoSize",
"shortDescription": "Max Video Storage Usage", "shortDescription": "Max Video Storage Usage",
"longDescription": "Maximum amount of disk space used by video recording.", "longDescription": "Maximum amount of disk space used by video recording.",
"type": "uint32", "type": "uint32",
...@@ -79,7 +88,7 @@ ...@@ -79,7 +88,7 @@
"mobileDefaultValue": 2048 "mobileDefaultValue": 2048
}, },
{ {
"name": "EnableStorageLimit", "name": "enableStorageLimit",
"shortDescription": "Enable/Disable Limits on Storage Usage", "shortDescription": "Enable/Disable Limits on Storage Usage",
"longDescription": "When enabled, old video files will be auto-deleted when the total size of QGC-recorded video exceeds the maximum video storage usage.", "longDescription": "When enabled, old video files will be auto-deleted when the total size of QGC-recorded video exceeds the maximum video storage usage.",
"type": "bool", "type": "bool",
...@@ -87,7 +96,7 @@ ...@@ -87,7 +96,7 @@
"mobileDefaultValue": true "mobileDefaultValue": true
}, },
{ {
"name": "RtspTimeout", "name": "rtspTimeout",
"shortDescription": "RTSP Video Timeout", "shortDescription": "RTSP Video Timeout",
"longDescription": "How long to wait before assuming RTSP link is gone.", "longDescription": "How long to wait before assuming RTSP link is gone.",
"type": "uint32", "type": "uint32",
...@@ -96,14 +105,14 @@ ...@@ -96,14 +105,14 @@
"defaultValue": 2 "defaultValue": 2
}, },
{ {
"name": "StreamEnabled", "name": "streamEnabled",
"shortDescription": "Video Stream Enabled", "shortDescription": "Video Stream Enabled",
"longDescription": "Start/Stop Video Stream.", "longDescription": "Start/Stop Video Stream.",
"type": "bool", "type": "bool",
"defaultValue": true "defaultValue": true
}, },
{ {
"name": "DisableWhenDisarmed", "name": "disableWhenDisarmed",
"shortDescription": "Video Stream Disnabled When Armed", "shortDescription": "Video Stream Disnabled When Armed",
"longDescription": "Disable Video Stream when disarmed.", "longDescription": "Disable Video Stream when disarmed.",
"type": "bool", "type": "bool",
......
...@@ -17,44 +17,16 @@ ...@@ -17,44 +17,16 @@
#include <QCameraInfo> #include <QCameraInfo>
#endif #endif
const char* VideoSettings::name = "Video";
const char* VideoSettings::settingsGroup = ""; // settings are in root group
const char* VideoSettings::videoSourceName = "VideoSource";
const char* VideoSettings::udpPortName = "VideoUDPPort";
const char* VideoSettings::rtspUrlName = "VideoRTSPUrl";
const char* VideoSettings::tcpUrlName = "VideoTCPUrl";
const char* VideoSettings::videoAspectRatioName = "VideoAspectRatio";
const char* VideoSettings::videoGridLinesName = "VideoGridLines";
const char* VideoSettings::showRecControlName = "ShowRecControl";
const char* VideoSettings::recordingFormatName = "RecordingFormat";
const char* VideoSettings::maxVideoSizeName = "MaxVideoSize";
const char* VideoSettings::enableStorageLimitName = "EnableStorageLimit";
const char* VideoSettings::rtspTimeoutName = "RtspTimeout";
const char* VideoSettings::streamEnabledName = "StreamEnabled";
const char* VideoSettings::disableWhenDisarmedName ="DisableWhenDisarmed";
const char* VideoSettings::videoSourceNoVideo = "No Video Available"; const char* VideoSettings::videoSourceNoVideo = "No Video Available";
const char* VideoSettings::videoDisabled = "Video Stream Disabled"; const char* VideoSettings::videoDisabled = "Video Stream Disabled";
const char* VideoSettings::videoSourceUDP = "UDP Video Stream"; const char* VideoSettings::videoSourceUDP = "UDP Video Stream";
const char* VideoSettings::videoSourceRTSP = "RTSP Video Stream"; const char* VideoSettings::videoSourceRTSP = "RTSP Video Stream";
const char* VideoSettings::videoSourceTCP = "TCP-MPEG2 Video Stream"; const char* VideoSettings::videoSourceTCP = "TCP-MPEG2 Video Stream";
#ifdef QGC_GST_TAISYNC_USB
const char* VideoSettings::videoSourceTaiSyncUSB = "Taisync USB";
#endif
VideoSettings::VideoSettings(QObject* parent) DECLARE_SETTINGGROUP(Video, "Video")
: SettingsGroup(name, settingsGroup, parent)
, _videoSourceFact(NULL)
, _udpPortFact(NULL)
, _tcpUrlFact(NULL)
, _rtspUrlFact(NULL)
, _videoAspectRatioFact(NULL)
, _gridLinesFact(NULL)
, _showRecControlFact(NULL)
, _recordingFormatFact(NULL)
, _maxVideoSizeFact(NULL)
, _enableStorageLimitFact(NULL)
, _rtspTimeoutFact(NULL)
, _streamEnabledFact(NULL)
, _disableWhenDisarmedFact(NULL)
{ {
QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership); QQmlEngine::setObjectOwnership(this, QQmlEngine::CppOwnership);
qmlRegisterUncreatableType<VideoSettings>("QGroundControl.SettingsManager", 1, 0, "VideoSettings", "Reference only"); qmlRegisterUncreatableType<VideoSettings>("QGroundControl.SettingsManager", 1, 0, "VideoSettings", "Reference only");
...@@ -68,6 +40,9 @@ VideoSettings::VideoSettings(QObject* parent) ...@@ -68,6 +40,9 @@ VideoSettings::VideoSettings(QObject* parent)
#endif #endif
videoSourceList.append(videoSourceRTSP); videoSourceList.append(videoSourceRTSP);
videoSourceList.append(videoSourceTCP); videoSourceList.append(videoSourceTCP);
#ifdef QGC_GST_TAISYNC_USB
videoSourceList.append(videoSourceTaiSyncUSB);
#endif
#endif #endif
#ifndef QGC_DISABLE_UVC #ifndef QGC_DISABLE_UVC
QList<QCameraInfo> cameras = QCameraInfo::availableCameras(); QList<QCameraInfo> cameras = QCameraInfo::availableCameras();
...@@ -95,7 +70,18 @@ VideoSettings::VideoSettings(QObject* parent) ...@@ -95,7 +70,18 @@ VideoSettings::VideoSettings(QObject* parent)
} }
} }
Fact* VideoSettings::videoSource(void) DECLARE_SETTINGSFACT(VideoSettings, aspectRatio)
DECLARE_SETTINGSFACT(VideoSettings, videoFit)
DECLARE_SETTINGSFACT(VideoSettings, gridLines)
DECLARE_SETTINGSFACT(VideoSettings, showRecControl)
DECLARE_SETTINGSFACT(VideoSettings, recordingFormat)
DECLARE_SETTINGSFACT(VideoSettings, maxVideoSize)
DECLARE_SETTINGSFACT(VideoSettings, enableStorageLimit)
DECLARE_SETTINGSFACT(VideoSettings, rtspTimeout)
DECLARE_SETTINGSFACT(VideoSettings, streamEnabled)
DECLARE_SETTINGSFACT(VideoSettings, disableWhenDisarmed)
DECLARE_SETTINGSFACT_NO_FUNC(VideoSettings, videoSource)
{ {
if (!_videoSourceFact) { if (!_videoSourceFact) {
_videoSourceFact = _createSettingsFact(videoSourceName); _videoSourceFact = _createSettingsFact(videoSourceName);
...@@ -104,7 +90,7 @@ Fact* VideoSettings::videoSource(void) ...@@ -104,7 +90,7 @@ Fact* VideoSettings::videoSource(void)
return _videoSourceFact; return _videoSourceFact;
} }
Fact* VideoSettings::udpPort(void) DECLARE_SETTINGSFACT_NO_FUNC(VideoSettings, udpPort)
{ {
if (!_udpPortFact) { if (!_udpPortFact) {
_udpPortFact = _createSettingsFact(udpPortName); _udpPortFact = _createSettingsFact(udpPortName);
...@@ -113,7 +99,7 @@ Fact* VideoSettings::udpPort(void) ...@@ -113,7 +99,7 @@ Fact* VideoSettings::udpPort(void)
return _udpPortFact; return _udpPortFact;
} }
Fact* VideoSettings::rtspUrl(void) DECLARE_SETTINGSFACT_NO_FUNC(VideoSettings, rtspUrl)
{ {
if (!_rtspUrlFact) { if (!_rtspUrlFact) {
_rtspUrlFact = _createSettingsFact(rtspUrlName); _rtspUrlFact = _createSettingsFact(rtspUrlName);
...@@ -122,7 +108,7 @@ Fact* VideoSettings::rtspUrl(void) ...@@ -122,7 +108,7 @@ Fact* VideoSettings::rtspUrl(void)
return _rtspUrlFact; return _rtspUrlFact;
} }
Fact* VideoSettings::tcpUrl(void) DECLARE_SETTINGSFACT_NO_FUNC(VideoSettings, tcpUrl)
{ {
if (!_tcpUrlFact) { if (!_tcpUrlFact) {
_tcpUrlFact = _createSettingsFact(tcpUrlName); _tcpUrlFact = _createSettingsFact(tcpUrlName);
...@@ -131,78 +117,6 @@ Fact* VideoSettings::tcpUrl(void) ...@@ -131,78 +117,6 @@ Fact* VideoSettings::tcpUrl(void)
return _tcpUrlFact; return _tcpUrlFact;
} }
Fact* VideoSettings::aspectRatio(void)
{
if (!_videoAspectRatioFact) {
_videoAspectRatioFact = _createSettingsFact(videoAspectRatioName);
}
return _videoAspectRatioFact;
}
Fact* VideoSettings::gridLines(void)
{
if (!_gridLinesFact) {
_gridLinesFact = _createSettingsFact(videoGridLinesName);
}
return _gridLinesFact;
}
Fact* VideoSettings::showRecControl(void)
{
if (!_showRecControlFact) {
_showRecControlFact = _createSettingsFact(showRecControlName);
}
return _showRecControlFact;
}
Fact* VideoSettings::recordingFormat(void)
{
if (!_recordingFormatFact) {
_recordingFormatFact = _createSettingsFact(recordingFormatName);
}
return _recordingFormatFact;
}
Fact* VideoSettings::maxVideoSize(void)
{
if (!_maxVideoSizeFact) {
_maxVideoSizeFact = _createSettingsFact(maxVideoSizeName);
}
return _maxVideoSizeFact;
}
Fact* VideoSettings::enableStorageLimit(void)
{
if (!_enableStorageLimitFact) {
_enableStorageLimitFact = _createSettingsFact(enableStorageLimitName);
}
return _enableStorageLimitFact;
}
Fact* VideoSettings::rtspTimeout(void)
{
if (!_rtspTimeoutFact) {
_rtspTimeoutFact = _createSettingsFact(rtspTimeoutName);
}
return _rtspTimeoutFact;
}
Fact* VideoSettings::streamEnabled(void)
{
if (!_streamEnabledFact) {
_streamEnabledFact = _createSettingsFact(streamEnabledName);
}
return _streamEnabledFact;
}
Fact* VideoSettings::disableWhenDisarmed(void)
{
if (!_disableWhenDisarmedFact) {
_disableWhenDisarmedFact = _createSettingsFact(disableWhenDisarmedName);
}
return _disableWhenDisarmedFact;
}
bool VideoSettings::streamConfigured(void) bool VideoSettings::streamConfigured(void)
{ {
#if !defined(QGC_GST_STREAMING) #if !defined(QGC_GST_STREAMING)
...@@ -212,6 +126,11 @@ bool VideoSettings::streamConfigured(void) ...@@ -212,6 +126,11 @@ bool VideoSettings::streamConfigured(void)
if(vSource == videoSourceNoVideo || vSource == videoDisabled) { if(vSource == videoSourceNoVideo || vSource == videoDisabled) {
return false; return false;
} }
#ifdef QGC_GST_TAISYNC_USB
if(vSource == videoSourceTaiSyncUSB) {
return true;
}
#endif
//-- If UDP, check if port is set //-- If UDP, check if port is set
if(vSource == videoSourceUDP) { if(vSource == videoSourceUDP) {
return udpPort()->rawValue().toInt() != 0; return udpPort()->rawValue().toInt() != 0;
......
...@@ -17,60 +17,36 @@ class VideoSettings : public SettingsGroup ...@@ -17,60 +17,36 @@ class VideoSettings : public SettingsGroup
Q_OBJECT Q_OBJECT
public: public:
VideoSettings(QObject* parent = NULL); VideoSettings(QObject* parent = nullptr);
DEFINE_SETTING_NAME_GROUP()
DEFINE_SETTINGFACT(videoSource)
DEFINE_SETTINGFACT(udpPort)
DEFINE_SETTINGFACT(tcpUrl)
DEFINE_SETTINGFACT(rtspUrl)
DEFINE_SETTINGFACT(aspectRatio)
DEFINE_SETTINGFACT(videoFit)
DEFINE_SETTINGFACT(gridLines)
DEFINE_SETTINGFACT(showRecControl)
DEFINE_SETTINGFACT(recordingFormat)
DEFINE_SETTINGFACT(maxVideoSize)
DEFINE_SETTINGFACT(enableStorageLimit)
DEFINE_SETTINGFACT(rtspTimeout)
DEFINE_SETTINGFACT(streamEnabled)
DEFINE_SETTINGFACT(disableWhenDisarmed)
Q_PROPERTY(Fact* videoSource READ videoSource CONSTANT)
Q_PROPERTY(Fact* udpPort READ udpPort CONSTANT)
Q_PROPERTY(Fact* tcpUrl READ tcpUrl CONSTANT)
Q_PROPERTY(Fact* rtspUrl READ rtspUrl CONSTANT)
Q_PROPERTY(Fact* aspectRatio READ aspectRatio CONSTANT)
Q_PROPERTY(Fact* gridLines READ gridLines CONSTANT)
Q_PROPERTY(Fact* showRecControl READ showRecControl CONSTANT)
Q_PROPERTY(Fact* recordingFormat READ recordingFormat CONSTANT)
Q_PROPERTY(Fact* maxVideoSize READ maxVideoSize CONSTANT)
Q_PROPERTY(Fact* enableStorageLimit READ enableStorageLimit CONSTANT)
Q_PROPERTY(Fact* rtspTimeout READ rtspTimeout CONSTANT)
Q_PROPERTY(Fact* streamEnabled READ streamEnabled CONSTANT)
Q_PROPERTY(Fact* disableWhenDisarmed READ disableWhenDisarmed CONSTANT)
Q_PROPERTY(bool streamConfigured READ streamConfigured NOTIFY streamConfiguredChanged) Q_PROPERTY(bool streamConfigured READ streamConfigured NOTIFY streamConfiguredChanged)
Fact* videoSource (void); bool streamConfigured ();
Fact* udpPort (void);
Fact* rtspUrl (void);
Fact* tcpUrl (void);
Fact* aspectRatio (void);
Fact* gridLines (void);
Fact* showRecControl (void);
Fact* recordingFormat (void);
Fact* maxVideoSize (void);
Fact* enableStorageLimit (void);
Fact* rtspTimeout (void);
Fact* streamEnabled (void);
Fact* disableWhenDisarmed (void);
bool streamConfigured (void);
static const char* name;
static const char* settingsGroup;
static const char* videoSourceName;
static const char* udpPortName;
static const char* rtspUrlName;
static const char* tcpUrlName;
static const char* videoAspectRatioName;
static const char* videoGridLinesName;
static const char* showRecControlName;
static const char* recordingFormatName;
static const char* maxVideoSizeName;
static const char* enableStorageLimitName;
static const char* rtspTimeoutName;
static const char* streamEnabledName;
static const char* disableWhenDisarmedName;
static const char* videoSourceNoVideo; static const char* videoSourceNoVideo;
static const char* videoDisabled; static const char* videoDisabled;
static const char* videoSourceUDP; static const char* videoSourceUDP;
static const char* videoSourceRTSP; static const char* videoSourceRTSP;
static const char* videoSourceTCP; static const char* videoSourceTCP;
#ifdef QGC_GST_TAISYNC_USB
static const char* videoSourceTaiSyncUSB;
#endif
signals: signals:
void streamConfiguredChanged (); void streamConfiguredChanged ();
...@@ -79,19 +55,6 @@ private slots: ...@@ -79,19 +55,6 @@ private slots:
void _configChanged (QVariant value); void _configChanged (QVariant value);
private: private:
SettingsFact* _videoSourceFact;
SettingsFact* _udpPortFact;
SettingsFact* _tcpUrlFact;
SettingsFact* _rtspUrlFact;
SettingsFact* _videoAspectRatioFact;
SettingsFact* _gridLinesFact;
SettingsFact* _showRecControlFact;
SettingsFact* _recordingFormatFact;
SettingsFact* _maxVideoSizeFact;
SettingsFact* _enableStorageLimitFact;
SettingsFact* _rtspTimeoutFact;
SettingsFact* _streamEnabledFact;
SettingsFact* _disableWhenDisarmedFact;
}; };
#endif #endif
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment