diff --git a/QGCApplication.pro b/QGCApplication.pro index c9d94598f9afb9be1f35be205b8e08744673c342..08f0eeedd77d57bad01e6a1f90571ca39a678e11 100644 --- a/QGCApplication.pro +++ b/QGCApplication.pro @@ -153,7 +153,6 @@ INCLUDEPATH += \ src/ui/linechart \ src/ui/map \ src/ui/mapdisplay \ - src/ui/mavlink \ src/ui/mission \ src/ui/px4_configuration \ src/ui/toolbar \ @@ -166,28 +165,18 @@ FORMS += \ src/ui/Linechart.ui \ src/ui/LogReplayLinkConfigurationWidget.ui \ src/ui/MainWindow.ui \ - src/ui/mavlink/QGCMAVLinkMessageSender.ui \ src/ui/MAVLinkSettingsWidget.ui \ - src/ui/MultiVehicleDockWidget.ui \ src/ui/QGCCommConfiguration.ui \ src/ui/QGCDataPlot2D.ui \ src/ui/QGCLinkConfiguration.ui \ src/ui/QGCMapRCToParamDialog.ui \ - src/ui/QGCMAVLinkInspector.ui \ src/ui/QGCMAVLinkLogPlayer.ui \ src/ui/QGCPluginHost.ui \ - src/ui/QGCTabbedInfoView.ui \ src/ui/QGCTCPLinkConfiguration.ui \ - src/ui/QGCUASFileView.ui \ - src/ui/QGCUASFileViewMulti.ui \ src/ui/QGCUDPLinkConfiguration.ui \ src/ui/SettingsDialog.ui \ src/ui/uas/QGCUnconnectedInfoWidget.ui \ src/ui/uas/UASMessageView.ui \ - src/ui/uas/UASQuickView.ui \ - src/ui/uas/UASQuickViewItemSelect.ui \ - src/ui/UASInfo.ui \ - src/ui/UASRawStatusView.ui \ !iOSBuild { FORMS += \ @@ -196,10 +185,19 @@ FORMS += \ !MobileBuild { FORMS += \ + src/ui/MultiVehicleDockWidget.ui \ src/ui/QGCHilConfiguration.ui \ src/ui/QGCHilFlightGearConfiguration.ui \ src/ui/QGCHilJSBSimConfiguration.ui \ src/ui/QGCHilXPlaneConfiguration.ui \ + src/ui/QGCMAVLinkInspector.ui \ + src/ui/QGCTabbedInfoView.ui \ + src/ui/QGCUASFileView.ui \ + src/ui/QGCUASFileViewMulti.ui \ + src/ui/uas/UASQuickView.ui \ + src/ui/uas/UASQuickViewItemSelect.ui \ + src/ui/UASInfo.ui \ + src/ui/UASRawStatusView.ui \ } HEADERS += \ @@ -232,7 +230,6 @@ HEADERS += \ src/QGCApplication.h \ src/QGCComboBox.h \ src/QGCConfig.h \ - src/QGCDockWidget.h \ src/QGCFileDialog.h \ src/QGCGeo.h \ src/QGCLoggingCategory.h \ @@ -263,37 +260,20 @@ HEADERS += \ src/ui/linechart/ScrollZoomer.h \ src/ui/LogReplayLinkConfigurationWidget.h \ src/ui/MainWindow.h \ - src/ui/mavlink/QGCMAVLinkMessageSender.h \ src/ui/MAVLinkDecoder.h \ src/ui/MAVLinkSettingsWidget.h \ - src/ui/MultiVehicleDockWidget.h \ src/ui/QGCCommConfiguration.h \ src/ui/QGCDataPlot2D.h \ src/ui/QGCLinkConfiguration.h \ - src/ui/QGCMainWindowAPConfigurator.h \ src/ui/QGCMapRCToParamDialog.h \ - src/ui/QGCMAVLinkInspector.h \ src/ui/QGCMAVLinkLogPlayer.h \ src/ui/QGCPluginHost.h \ - src/ui/QGCTabbedInfoView.h \ src/ui/QGCTCPLinkConfiguration.h \ - src/ui/QGCUASFileView.h \ - src/ui/QGCUASFileViewMulti.h \ src/ui/QGCUDPLinkConfiguration.h \ src/ui/SettingsDialog.h \ src/ui/toolbar/MainToolBar.h \ src/ui/uas/QGCUnconnectedInfoWidget.h \ - src/ui/uas/UASInfoWidget.h \ src/ui/uas/UASMessageView.h \ - src/ui/uas/UASQuickView.h \ - src/ui/uas/UASQuickViewGaugeItem.h \ - src/ui/uas/UASQuickViewItem.h \ - src/ui/uas/UASQuickViewItemSelect.h \ - src/ui/uas/UASQuickViewTextItem.h \ - src/ui/UASRawStatusView.h \ - src/ViewWidgets/CustomCommandWidget.h \ - src/ViewWidgets/CustomCommandWidgetController.h \ - src/ViewWidgets/ViewWidgetController.h \ src/MissionItem.h \ src/AutoPilotPlugins/PX4/PX4AirframeLoader.h @@ -309,13 +289,29 @@ HEADERS += \ src/comm/QGCHilLink.h \ src/comm/QGCJSBSimLink.h \ src/comm/QGCXPlaneLink.h \ + src/QGCDockWidget.h \ src/ui/CameraView.h \ src/ui/HILDockWidget.h \ + src/ui/MultiVehicleDockWidget.h \ src/ui/QGCHilConfiguration.h \ src/ui/QGCHilFlightGearConfiguration.h \ src/ui/QGCHilJSBSimConfiguration.h \ src/ui/QGCHilXPlaneConfiguration.h \ + src/ui/QGCMAVLinkInspector.h \ + src/ui/QGCTabbedInfoView.h \ + src/ui/QGCUASFileView.h \ + src/ui/QGCUASFileViewMulti.h \ + src/ui/uas/UASInfoWidget.h \ + src/ui/uas/UASQuickView.h \ + src/ui/uas/UASQuickViewGaugeItem.h \ + src/ui/uas/UASQuickViewItem.h \ + src/ui/uas/UASQuickViewItemSelect.h \ + src/ui/uas/UASQuickViewTextItem.h \ + src/ui/UASRawStatusView.h \ src/VehicleSetup/JoystickConfigController.h \ + src/ViewWidgets/CustomCommandWidget.h \ + src/ViewWidgets/CustomCommandWidgetController.h \ + src/ViewWidgets/ViewWidgetController.h \ } SOURCES += \ @@ -344,7 +340,6 @@ SOURCES += \ src/QGC.cc \ src/QGCApplication.cc \ src/QGCComboBox.cc \ - src/QGCDockWidget.cc \ src/QGCFileDialog.cc \ src/QGCLoggingCategory.cc \ src/QGCPalette.cc \ @@ -370,37 +365,20 @@ SOURCES += \ src/ui/linechart/ScrollZoomer.cc \ src/ui/LogReplayLinkConfigurationWidget.cc \ src/ui/MainWindow.cc \ - src/ui/mavlink/QGCMAVLinkMessageSender.cc \ src/ui/MAVLinkDecoder.cc \ src/ui/MAVLinkSettingsWidget.cc \ - src/ui/MultiVehicleDockWidget.cc \ src/ui/QGCCommConfiguration.cc \ src/ui/QGCDataPlot2D.cc \ src/ui/QGCLinkConfiguration.cc \ - src/ui/QGCMainWindowAPConfigurator.cc \ src/ui/QGCMapRCToParamDialog.cpp \ - src/ui/QGCMAVLinkInspector.cc \ src/ui/QGCMAVLinkLogPlayer.cc \ src/ui/QGCPluginHost.cc \ - src/ui/QGCTabbedInfoView.cpp \ src/ui/QGCTCPLinkConfiguration.cc \ - src/ui/QGCUASFileView.cc \ - src/ui/QGCUASFileViewMulti.cc \ src/ui/QGCUDPLinkConfiguration.cc \ src/ui/SettingsDialog.cc \ src/ui/toolbar/MainToolBar.cc \ src/ui/uas/QGCUnconnectedInfoWidget.cc \ - src/ui/uas/UASInfoWidget.cc \ src/ui/uas/UASMessageView.cc \ - src/ui/uas/UASQuickView.cc \ - src/ui/uas/UASQuickViewGaugeItem.cc \ - src/ui/uas/UASQuickViewItem.cc \ - src/ui/uas/UASQuickViewItemSelect.cc \ - src/ui/uas/UASQuickViewTextItem.cc \ - src/ui/UASRawStatusView.cpp \ - src/ViewWidgets/CustomCommandWidget.cc \ - src/ViewWidgets/CustomCommandWidgetController.cc \ - src/ViewWidgets/ViewWidgetController.cc \ src/MissionItem.cc \ src/AutoPilotPlugins/PX4/PX4AirframeLoader.cc @@ -415,13 +393,29 @@ SOURCES += \ src/comm/QGCFlightGearLink.cc \ src/comm/QGCJSBSimLink.cc \ src/comm/QGCXPlaneLink.cc \ + src/QGCDockWidget.cc \ src/ui/CameraView.cc \ src/ui/HILDockWidget.cc \ + src/ui/MultiVehicleDockWidget.cc \ src/ui/QGCHilConfiguration.cc \ src/ui/QGCHilFlightGearConfiguration.cc \ src/ui/QGCHilJSBSimConfiguration.cc \ src/ui/QGCHilXPlaneConfiguration.cc \ + src/ui/QGCMAVLinkInspector.cc \ + src/ui/QGCTabbedInfoView.cpp \ + src/ui/QGCUASFileView.cc \ + src/ui/QGCUASFileViewMulti.cc \ + src/ui/uas/UASInfoWidget.cc \ + src/ui/uas/UASQuickView.cc \ + src/ui/uas/UASQuickViewGaugeItem.cc \ + src/ui/uas/UASQuickViewItem.cc \ + src/ui/uas/UASQuickViewItemSelect.cc \ + src/ui/uas/UASQuickViewTextItem.cc \ + src/ui/UASRawStatusView.cpp \ src/VehicleSetup/JoystickConfigController.cc \ + src/ViewWidgets/CustomCommandWidget.cc \ + src/ViewWidgets/CustomCommandWidgetController.cc \ + src/ViewWidgets/ViewWidgetController.cc \ } # diff --git a/src/AutoPilotPlugins/AutoPilotPlugin.cc b/src/AutoPilotPlugins/AutoPilotPlugin.cc index c72b95c7e37e7eaf7f65132ab9be25e0b0fcd98c..142643a9f6ef95c9ef1c6bfc06c6bdc7b27d7595 100644 --- a/src/AutoPilotPlugins/AutoPilotPlugin.cc +++ b/src/AutoPilotPlugins/AutoPilotPlugin.cc @@ -29,6 +29,7 @@ #include "QGCMessageBox.h" #include "MainWindow.h" #include "ParameterLoader.h" +#include "UAS.h" AutoPilotPlugin::AutoPilotPlugin(Vehicle* vehicle, QObject* parent) : QObject(parent) diff --git a/src/AutoPilotPlugins/PX4/PX4AutoPilotPlugin.cc b/src/AutoPilotPlugins/PX4/PX4AutoPilotPlugin.cc index eb682c82239be88bc903af7ddf73767bd6bd6925..2507d349226ee6778e29f803a07b816611ab2a16 100644 --- a/src/AutoPilotPlugins/PX4/PX4AutoPilotPlugin.cc +++ b/src/AutoPilotPlugins/PX4/PX4AutoPilotPlugin.cc @@ -28,6 +28,7 @@ #include "FlightModesComponentController.h" #include "AirframeComponentController.h" #include "QGCMessageBox.h" +#include "UAS.h" /// @file /// @brief This is the AutoPilotPlugin implementatin for the MAV_AUTOPILOT_PX4 type. diff --git a/src/AutoPilotPlugins/PX4/PowerComponentController.cc b/src/AutoPilotPlugins/PX4/PowerComponentController.cc index d9cd80fb04fa3100bc9eb939aa3a23984f0932a8..416caf928c2f18d8f2186ae518201c8849382038 100644 --- a/src/AutoPilotPlugins/PX4/PowerComponentController.cc +++ b/src/AutoPilotPlugins/PX4/PowerComponentController.cc @@ -27,6 +27,7 @@ #include "PowerComponentController.h" #include "QGCMAVLink.h" #include "QGCMessageBox.h" +#include "UAS.h" #include #include diff --git a/src/AutoPilotPlugins/PX4/SensorsComponentController.cc b/src/AutoPilotPlugins/PX4/SensorsComponentController.cc index 81c0f16f0915cef4b60f9f26259825aff44b12c5..77693e7c3734e568cce51c6f942ae688926f248f 100644 --- a/src/AutoPilotPlugins/PX4/SensorsComponentController.cc +++ b/src/AutoPilotPlugins/PX4/SensorsComponentController.cc @@ -27,6 +27,7 @@ #include "SensorsComponentController.h" #include "QGCMAVLink.h" #include "QGCMessageBox.h" +#include "UAS.h" #include #include diff --git a/src/FactSystem/FactControls/FactPanelController.cc b/src/FactSystem/FactControls/FactPanelController.cc index 1d26c215988bec3f6d816697625202060642afd9..b828e0771c551896e2d2dd8ef0fb672865ca576e 100644 --- a/src/FactSystem/FactControls/FactPanelController.cc +++ b/src/FactSystem/FactControls/FactPanelController.cc @@ -24,6 +24,7 @@ #include "FactPanelController.h" #include "MultiVehicleManager.h" #include "QGCMessageBox.h" +#include "UAS.h" #include diff --git a/src/FactSystem/ParameterLoader.cc b/src/FactSystem/ParameterLoader.cc index fa4c38122c3e5d997ae6f30255010bc5536a7e09..9fad146c4a6e3544ce0ee77260a521417fa30116 100644 --- a/src/FactSystem/ParameterLoader.cc +++ b/src/FactSystem/ParameterLoader.cc @@ -31,6 +31,7 @@ #include "QGCMessageBox.h" #include "UASMessageHandler.h" #include "FirmwarePlugin.h" +#include "UAS.h" #include #include diff --git a/src/QGCApplication.cc b/src/QGCApplication.cc index cefc505929f53db642e04ddfef7baea24cdb40ab..4230ee0f14410fa0ccb0f90e43c4934036bb457d 100644 --- a/src/QGCApplication.cc +++ b/src/QGCApplication.cc @@ -163,9 +163,6 @@ QGCApplication::QGCApplication(int &argc, char* argv[], bool unitTesting) , _runningUnitTests(unitTesting) , _styleIsDark(true) , _fakeMobile(false) -#ifdef UNITTEST_BUILD - , _useNewMissionEditor(true) // Unit Tests run new mission editor -#endif #ifdef QT_DEBUG , _testHighDPI(false) #endif @@ -337,9 +334,7 @@ void QGCApplication::_initCommon(void) qmlRegisterUncreatableType ("QGroundControl", 1, 0, "QGCQGeoCoordinate", "Reference only"); qmlRegisterUncreatableType ("QGroundControl", 1, 0, "CoordinateVector", "Reference only"); - qmlRegisterType ("QGroundControl.Controllers", 1, 0, "ViewWidgetController"); qmlRegisterType ("QGroundControl.Controllers", 1, 0, "ParameterEditorController"); - qmlRegisterType ("QGroundControl.Controllers", 1, 0, "CustomCommandWidgetController"); qmlRegisterType ("QGroundControl.Controllers", 1, 0, "FlightModesComponentController"); qmlRegisterType ("QGroundControl.Controllers", 1, 0, "AirframeComponentController"); qmlRegisterType ("QGroundControl.Controllers", 1, 0, "SensorsComponentController"); @@ -348,6 +343,8 @@ void QGCApplication::_initCommon(void) qmlRegisterType ("QGroundControl.Controllers", 1, 0, "ScreenToolsController"); #ifndef __mobile__ + qmlRegisterType ("QGroundControl.Controllers", 1, 0, "ViewWidgetController"); + qmlRegisterType ("QGroundControl.Controllers", 1, 0, "CustomCommandWidgetController"); qmlRegisterType ("QGroundControl.Controllers", 1, 0, "FirmwareUpgradeController"); qmlRegisterType ("QGroundControl.Controllers", 1, 0, "JoystickConfigController"); #endif @@ -420,14 +417,6 @@ bool QGCApplication::_initForNormalAppBoot(void) _styleIsDark = settings.value(_styleKey, _styleIsDark).toBool(); _loadCurrentStyle(); - // Temp hack for new mission editor -#ifdef __mobile__ - // Mobile builds always use new Mission Editor - _useNewMissionEditor = true; -#else - _useNewMissionEditor = settings.value("UseNewMissionEditor", false).toBool(); -#endif - // Show splash screen QPixmap splashImage(":/res/SplashScreen"); QSplashScreen* splashScreen = new QSplashScreen(splashImage); diff --git a/src/QGCApplication.h b/src/QGCApplication.h index 1e98b7e30d27efba40068147cb176caf905689c9..f503a7f915ce5a87c4f549f947c2db8dc9c565f8 100644 --- a/src/QGCApplication.h +++ b/src/QGCApplication.h @@ -178,8 +178,6 @@ private: QStringList _missingParams; ///< List of missing facts to be displayed bool _fakeMobile; ///< true: Fake ui into displaying mobile interface - - bool _useNewMissionEditor; ///< true: Use new Mission Editor #ifdef QT_DEBUG bool _testHighDPI; ///< true: double fonts sizes for simulating high dpi devices diff --git a/src/QGCFileDialog.cc b/src/QGCFileDialog.cc index effb91d7c8852042de544011bd02a1304522c9c8..ca28c1ef3e58c942a55759e18c7dccf28f809fd6 100644 --- a/src/QGCFileDialog.cc +++ b/src/QGCFileDialog.cc @@ -32,6 +32,7 @@ #include #include +#include QString QGCFileDialog::getExistingDirectory( QWidget* parent, diff --git a/src/main.cc b/src/main.cc index 80d0fea868a49da270d265ea9dd0e3b91dc795ff..1b48c55ca2565b1860afe24dcbe1f5832b4b7923 100644 --- a/src/main.cc +++ b/src/main.cc @@ -31,21 +31,25 @@ This file is part of the QGROUNDCONTROL project #include #include #include +#include + #ifndef __mobile__ -#include + #include #endif -#include + #include "QGCApplication.h" #include "MainWindow.h" + #ifdef QT_DEBUG -#ifndef __mobile__ -#include "UnitTest.h" -#endif -#include "CmdLineOptParser.h" -#ifdef Q_OS_WIN -#include -#endif + #ifndef __mobile__ + #include "UnitTest.h" + #endif + #include "CmdLineOptParser.h" + #ifdef Q_OS_WIN + #include + #endif #endif + #include /* SDL does ugly things to main() */ diff --git a/src/ui/MainWindow.cc b/src/ui/MainWindow.cc index 37ba7e2f373b5c218142130938adc4cf559866dd..18c414c4cf85dcac3f596e5a45924ab33fb7dddb 100644 --- a/src/ui/MainWindow.cc +++ b/src/ui/MainWindow.cc @@ -33,11 +33,11 @@ This file is part of the QGROUNDCONTROL project #include #include #include - #include #include #include #include +#include #include "QGC.h" #include "MAVLinkProtocol.h" @@ -46,27 +46,28 @@ This file is part of the QGROUNDCONTROL project #include "QGCMAVLinkLogPlayer.h" #include "SettingsDialog.h" #include "MAVLinkDecoder.h" -#include "QGCMAVLinkMessageSender.h" -#include "UASQuickView.h" #include "QGCDataPlot2D.h" #include "Linecharts.h" -#include "QGCTabbedInfoView.h" -#include "UASRawStatusView.h" #include "FlightDisplayView.h" -#include "FlightDisplayWidget.h" #include "SetupView.h" -#include "QGCUASFileViewMulti.h" #include "QGCApplication.h" #include "QGCFileDialog.h" #include "QGCMessageBox.h" -#include "QGCDockWidget.h" #include "MultiVehicleManager.h" -#include "CustomCommandWidget.h" #include "HomePositionManager.h" #include "MissionEditor.h" #include "LogCompressor.h" +#include "UAS.h" #ifndef __mobile__ +#include "QGCUASFileViewMulti.h" +#include "UASQuickView.h" +#include "QGCTabbedInfoView.h" +#include "UASRawStatusView.h" +#include "CustomCommandWidget.h" +#include "QGCDockWidget.h" +#include "FlightDisplayWidget.h" +#include "UASInfoWidget.h" #include "HILDockWidget.h" #endif @@ -86,6 +87,7 @@ This file is part of the QGROUNDCONTROL project /// The key under which the Main Window settings are saved const char* MAIN_SETTINGS_GROUP = "QGC_MAINWINDOW"; +#ifndef __mobile__ const char* MainWindow::_mavlinkDockWidgetName = "MAVLINK_INSPECTOR_DOCKWIDGET"; const char* MainWindow::_customCommandWidgetName = "CUSTOM_COMMAND_DOCKWIDGET"; const char* MainWindow::_filesDockWidgetName = "FILE_VIEW_DOCKWIDGET"; @@ -94,6 +96,7 @@ const char* MainWindow::_mapViewDockWidgetName = "MAP_VIEW_DOCKWIDGET"; const char* MainWindow::_pfdDockWidgetName = "PRIMARY_FLIGHT_DISPLAY_DOCKWIDGET"; const char* MainWindow::_uasInfoViewDockWidgetName = "UAS_INFO_INFOVIEW_DOCKWIDGET"; const char* MainWindow::_hilDockWidgetName = "HIL_DOCKWIDGET"; +#endif static MainWindow* _instance = NULL; ///< @brief MainWindow singleton @@ -162,10 +165,12 @@ MainWindow::MainWindow(QSplashScreen* splashScreen) menuBar()->setNativeMenuBar(false); #endif +#ifndef __mobile__ #ifdef UNITTEST_BUILD QAction* qmlTestAction = new QAction("Test QML palette and controls", NULL); connect(qmlTestAction, &QAction::triggered, this, &MainWindow::_showQmlTestWidget); _ui.menuWidgets->addAction(qmlTestAction); +#endif #endif // Load QML Toolbar @@ -184,9 +189,12 @@ MainWindow::MainWindow(QSplashScreen* splashScreen) setStatusBar(new QStatusBar(this)); statusBar()->setSizeGripEnabled(true); +#ifndef __mobile__ emit initStatusChanged(tr("Building common widgets."), Qt::AlignLeft | Qt::AlignBottom, QColor(62, 93, 141)); _buildCommonWidgets(); emit initStatusChanged(tr("Building common actions"), Qt::AlignLeft | Qt::AlignBottom, QColor(62, 93, 141)); +#endif + // Create actions connectCommonActions(); // Connect user interface devices @@ -332,6 +340,7 @@ QString MainWindow::_getWindowGeometryKey() return "_geometry"; } +#ifndef __mobile__ void MainWindow::_createDockWidget(const QString& title, const QString& name, Qt::DockWidgetArea area, QWidget* innerWidget) { Q_ASSERT(!_mapName2DockWidget.contains(name)); @@ -401,46 +410,6 @@ void MainWindow::_buildCommonWidgets(void) } } -void MainWindow::_buildMissionEditorView(void) -{ - if (!_missionEditorView) { - _missionEditorView = new MissionEditor(this); - _missionEditorView->setVisible(false); - } -} - -void MainWindow::_buildFlightView(void) -{ - if (!_flightView) { - _flightView = new FlightDisplayView(this); - _flightView->setVisible(false); - } -} - -void MainWindow::_buildSetupView(void) -{ - if (!_setupView) { - _setupView = new SetupView(this); - _setupView->setVisible(false); - } -} - -void MainWindow::_buildAnalyzeView(void) -{ - if (!_analyzeView) { - _analyzeView = new QGCDataPlot2D(this); - _analyzeView->setVisible(false); - } -} - -void MainWindow::_buildSimView(void) -{ - if (!_simView) { - _simView = new FlightDisplayView(this); - _simView->setVisible(false); - } -} - /// Shows or hides the specified dock widget, creating if necessary void MainWindow::_showDockWidget(const QString& name, bool show) { @@ -449,18 +418,18 @@ void MainWindow::_showDockWidget(const QString& name, bool show) // Which would cause us to end up here. return; } - + // Create the inner widget if we need to if (!_mapName2DockWidget[name]->widget()) { _createInnerDockWidget(name); } - + Q_ASSERT(_mapName2DockWidget.contains(name)); QDockWidget* dockWidget = _mapName2DockWidget[name]; Q_ASSERT(dockWidget); - + dockWidget->setVisible(show); - + Q_ASSERT(_mapDockWidget2Action.contains(dockWidget)); _mapDockWidget2Action[dockWidget]->setChecked(show); } @@ -470,9 +439,9 @@ void MainWindow::_createInnerDockWidget(const QString& widgetName) { Q_ASSERT(_mapName2DockWidget.contains(widgetName)); // QDockWidget should already exist Q_ASSERT(!_mapName2DockWidget[widgetName]->widget()); // Inner widget should not - + QWidget* widget = NULL; - + if (widgetName == _mavlinkDockWidgetName) { widget = new QGCMAVLinkInspector(MAVLinkProtocol::instance(),this); } else if (widgetName == _customCommandWidgetName) { @@ -494,7 +463,7 @@ void MainWindow::_createInnerDockWidget(const QString& widgetName) } else { qWarning() << "Attempt to create unknown Inner Dock Widget" << widgetName; } - + if (widget) { QDockWidget* dockWidget = _mapName2DockWidget[widgetName]; Q_CHECK_PTR(dockWidget); @@ -503,6 +472,53 @@ void MainWindow::_createInnerDockWidget(const QString& widgetName) } } +void MainWindow::_hideAllDockWidgets(void) +{ + foreach(QDockWidget* dockWidget, _mapName2DockWidget) { + dockWidget->setVisible(false); + } +} + +void MainWindow::_showDockWidgetAction(bool show) +{ + QAction* action = dynamic_cast(QObject::sender()); + Q_ASSERT(action); + _showDockWidget(action->data().toString(), show); +} +#endif + +void MainWindow::_buildMissionEditorView(void) +{ + if (!_missionEditorView) { + _missionEditorView = new MissionEditor(this); + _missionEditorView->setVisible(false); + } +} + +void MainWindow::_buildFlightView(void) +{ + if (!_flightView) { + _flightView = new FlightDisplayView(this); + _flightView->setVisible(false); + } +} + +void MainWindow::_buildSetupView(void) +{ + if (!_setupView) { + _setupView = new SetupView(this); + _setupView->setVisible(false); + } +} + +void MainWindow::_buildAnalyzeView(void) +{ + if (!_analyzeView) { + _analyzeView = new QGCDataPlot2D(this); + _analyzeView->setVisible(false); + } +} + void MainWindow::fullScreenActionItemCallback(bool) { _ui.actionNormal->setChecked(false); @@ -804,10 +820,10 @@ void MainWindow::_loadCurrentViewState(void) _centralLayout->setContentsMargins(0, 0, 0, 0); _currentViewWidget->setVisible(true); +#ifndef __mobile__ // Hide all widgets from previous view _hideAllDockWidgets(); -#ifndef __mobile__ // Restore the widgets for the new view QString widgetNames = settings.value(_getWindowStateKey() + "WIDGETS", defaultWidgets).toString(); qDebug() << widgetNames; @@ -829,21 +845,6 @@ void MainWindow::_loadCurrentViewState(void) emit repaintCanvas(); } -void MainWindow::_hideAllDockWidgets(void) -{ - foreach(QDockWidget* dockWidget, _mapName2DockWidget) { - dockWidget->setVisible(false); - } -} - -void MainWindow::_showDockWidgetAction(bool show) -{ - QAction* action = dynamic_cast(QObject::sender()); - Q_ASSERT(action); - _showDockWidget(action->data().toString(), show); -} - - void MainWindow::loadAnalyzeView() { if (_currentView != VIEW_ANALYZE) diff --git a/src/ui/MainWindow.h b/src/ui/MainWindow.h index fb83aed8b2a9e95c6e0f79524abef0b2a2350b37..da1e2de63712aabb89433f0bf4646e7858e35bc2 100644 --- a/src/ui/MainWindow.h +++ b/src/ui/MainWindow.h @@ -41,7 +41,6 @@ This file is part of the QGROUNDCONTROL project #include "LinkManager.h" #include "LinkInterface.h" #include "UASInterface.h" -#include "UASInfoWidget.h" #include "CameraView.h" #if (defined QGC_MOUSE_ENABLED_WIN) | (defined QGC_MOUSE_ENABLED_LINUX) #include "Mouse6dofInput.h" @@ -53,16 +52,13 @@ This file is part of the QGROUNDCONTROL project #include "QGCMAVLinkInspector.h" #include "QGCMAVLinkLogPlayer.h" #include "MAVLinkDecoder.h" -#include "QGCUASFileViewMulti.h" #include "Vehicle.h" -class QGCMAVLinkMessageSender; class QGCFirmwareUpdate; class QSplashScreen; class QGCStatusBar; class Linecharts; class QGCDataPlot2D; -class QGCUASFileViewMulti; /** * @brief Main Application Window @@ -212,19 +208,11 @@ protected: // Center widgets QPointer linechartWidget; -#ifdef QGC_OSG_ENABLED - QPointer q3DWidget; -#endif - QPointer firmwareUpdateWidget; QPointer _mainToolBar; - QPointer mavlinkInspectorWidget; QPointer mavlinkDecoder; - QPointer mavlinkSenderWidget; QGCMAVLinkLogPlayer* logPlayer; - QPointer fileWidget; - #ifdef QGC_MOUSE_ENABLED_WIN /** @brief 3d Mouse support (WIN only) */ Mouse3DInput* mouseInput; ///< 3dConnexion 3dMouse SDK @@ -251,15 +239,17 @@ protected: QTimer windowNameUpdateTimer; private slots: - void _showDockWidgetAction(bool show); void _linkStateChange(LinkInterface*); + void _closeWindow(void) { close(); } + void _vehicleAdded(Vehicle* vehicle); + +#ifndef __mobile__ + void _showDockWidgetAction(bool show); +#endif + #ifdef UNITTEST_BUILD void _showQmlTestWidget(void); #endif - void _closeWindow(void) { close(); } - -private slots: - void _vehicleAdded(Vehicle* vehicle); private: /// Constructor is private since all creation should be through MainWindow::_create @@ -272,10 +262,9 @@ private: QPointer _flightView; QPointer _setupView; QPointer _analyzeView; - QPointer _simView; - QPointer _terminalView; QPointer _missionEditorView; +#ifndef __mobile__ // Dock widget names static const char* _mavlinkDockWidgetName; static const char* _customCommandWidgetName; @@ -288,23 +277,25 @@ private: QMap _mapName2DockWidget; QMap _mapDockWidget2Action; +#endif void _buildPlanView(void); void _buildFlightView(void); void _buildSetupView(void); void _buildAnalyzeView(void); - void _buildSimView(void); void _buildTerminalView(void); void _buildMissionEditorView(void); void _storeCurrentViewState(void); void _loadCurrentViewState(void); +#ifndef __mobile__ void _createDockWidget(const QString& title, const QString& name, Qt::DockWidgetArea area, QWidget* innerWidget); void _createInnerDockWidget(const QString& widgetName); void _buildCommonWidgets(void); void _hideAllDockWidgets(void); void _showDockWidget(const QString &name, bool show); +#endif bool _autoReconnect; bool _lowPowerMode; ///< If enabled, QGC reduces the update rates of all widgets diff --git a/src/ui/QGCMainWindowAPConfigurator.cc b/src/ui/QGCMainWindowAPConfigurator.cc deleted file mode 100644 index 69da8c599ed6460879cd74c5d5f53df28802a93b..0000000000000000000000000000000000000000 --- a/src/ui/QGCMainWindowAPConfigurator.cc +++ /dev/null @@ -1,6 +0,0 @@ -#include "QGCMainWindowAPConfigurator.h" - -QGCMainWindowAPConfigurator::QGCMainWindowAPConfigurator(QObject *parent) : - QObject(parent) -{ -} diff --git a/src/ui/QGCMainWindowAPConfigurator.h b/src/ui/QGCMainWindowAPConfigurator.h deleted file mode 100644 index f4806f8202c7dee906868232fd013f3cf5980d78..0000000000000000000000000000000000000000 --- a/src/ui/QGCMainWindowAPConfigurator.h +++ /dev/null @@ -1,18 +0,0 @@ -#ifndef QGCMAINWINDOWAPCONFIGURATOR_H -#define QGCMAINWINDOWAPCONFIGURATOR_H - -#include - -class QGCMainWindowAPConfigurator : public QObject -{ - Q_OBJECT -public: - explicit QGCMainWindowAPConfigurator(QObject *parent = 0); - -signals: - -public slots: - -}; - -#endif // QGCMAINWINDOWAPCONFIGURATOR_H diff --git a/src/ui/linechart/Linecharts.cc b/src/ui/linechart/Linecharts.cc index f4f69a62561efd24955a97a0fd50193819195627..9b8dc33d8f646955c24dd7064193e5d0b11e42c6 100644 --- a/src/ui/linechart/Linecharts.cc +++ b/src/ui/linechart/Linecharts.cc @@ -2,8 +2,8 @@ #include "Linecharts.h" #include "MultiVehicleManager.h" - #include "MainWindow.h" +#include "UAS.h" Linecharts::Linecharts(QWidget *parent) : QStackedWidget(parent), diff --git a/src/ui/mavlink/QGCMAVLinkMessageSender.cc b/src/ui/mavlink/QGCMAVLinkMessageSender.cc deleted file mode 100644 index 6a93ed1950feb2ffd03439c33d9528c7cdad657e..0000000000000000000000000000000000000000 --- a/src/ui/mavlink/QGCMAVLinkMessageSender.cc +++ /dev/null @@ -1,510 +0,0 @@ -#include "QGCMAVLinkMessageSender.h" -#include "ui_QGCMAVLinkMessageSender.h" -#include "MAVLinkProtocol.h" - -QGCMAVLinkMessageSender::QGCMAVLinkMessageSender(MAVLinkProtocol* mavlink, QWidget *parent) : - QWidget(parent), - protocol(mavlink), - ui(new Ui::QGCMAVLinkMessageSender) -{ - ui->setupUi(this); - mavlink_message_info_t msg[256] = MAVLINK_MESSAGE_INFO; - memcpy(messageInfo, msg, sizeof(mavlink_message_info_t)*256); - - QStringList header; - header << tr("Name"); - header << tr("Value"); - header << tr("Type"); - ui->treeWidget->setHeaderLabels(header); - createTreeView(); - connect(&refreshTimer, SIGNAL(timeout()), this, SLOT(refresh())); - //refreshTimer.start(1000); // Refresh at 1 Hz interval - - connect(ui->sendButton, SIGNAL(pressed()), this, SLOT(sendMessage())); -} - -void QGCMAVLinkMessageSender::refresh() -{ - // Send messages - foreach (unsigned int i, managementItems.keys()) - { - if (!sendTimers.contains(i)) - { - //sendTimers.insert(i, new QTimer()) - } - } - - // ui->treeWidget->topLevelItem(0)->children(); -} - -bool QGCMAVLinkMessageSender::sendMessage() -{ - return sendMessage(ui->messageIdSpinBox->value()); -} - -bool QGCMAVLinkMessageSender::sendMessage(unsigned int msgid) -{ - QString msgname(messageInfo[msgid].name); - if (msgid == 0 || msgid > 255 || messageInfo[msgid].name == NULL || msgname.compare(QString("EMPTY"))) - { - return false; - } - bool result = true; - - if (treeWidgetItems.contains(msgid)) - { - // Fill message fields - - mavlink_message_t msg; - QList fields;// = treeWidgetItems.value(msgid)->; - - for (unsigned int i = 0; i < messageInfo[msgid].num_fields; ++i) - { - QTreeWidgetItem* field = fields.at(i); - int fieldid = i; - uint8_t* m = ((uint8_t*)(&msg))+8; - switch (messageInfo[msgid].fields[fieldid].type) - { - case MAVLINK_TYPE_CHAR: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - char* str = (char*)(m+messageInfo[msgid].fields[fieldid].wire_offset); - // Copy data - QString string = field->data(1, Qt::DisplayRole).toString(); - // Copy string size - int len = qMin((unsigned int)string.length(), messageInfo[msgid].fields[fieldid].array_length); - memcpy(str, string.toStdString().c_str(), len); - // Enforce null termination - str[len-1] = '\0'; - } - else - { - // Single char - char* b = ((char*)(m+messageInfo[msgid].fields[fieldid].wire_offset)); - *b = field->data(1, Qt::DisplayRole).toChar().toLatin1(); - } - break; - case MAVLINK_TYPE_UINT8_T: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - uint8_t* nums = m+messageInfo[msgid].fields[fieldid].wire_offset; - for (unsigned int j = 0; j < messageInfo[msgid].fields[fieldid].array_length; ++j) - { - if ((unsigned int)(field->data(1, Qt::DisplayRole).toString().split(" ").size()) > j) - { - nums[j] = field->data(1, Qt::DisplayRole).toString().split(" ").at(j).toInt(); - } - } - } - else - { - // Single value - uint8_t* u = (m+messageInfo[msgid].fields[fieldid].wire_offset); - *u = field->data(1, Qt::DisplayRole).toChar().toLatin1(); - } - break; - case MAVLINK_TYPE_INT8_T: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - int8_t* nums = reinterpret_cast((m+messageInfo[msgid].fields[fieldid].wire_offset)); - for (unsigned int j = 0; j < messageInfo[msgid].fields[fieldid].array_length; ++j) - { - if ((unsigned int)(field->data(1, Qt::DisplayRole).toString().split(" ").size()) > j) - { - nums[j] = field->data(1, Qt::DisplayRole).toString().split(" ").at(j).toInt(); - } - } - } - else - { - // Single value - int8_t* u = reinterpret_cast(m+messageInfo[msgid].fields[fieldid].wire_offset); - *u = field->data(1, Qt::DisplayRole).toChar().toLatin1(); - } - break; - case MAVLINK_TYPE_INT16_T: - case MAVLINK_TYPE_UINT16_T: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - uint16_t* nums = reinterpret_cast(m+messageInfo[msgid].fields[fieldid].wire_offset); - for (unsigned int j = 0; j < messageInfo[msgid].fields[fieldid].array_length; ++j) - { - if ((unsigned int)(field->data(1, Qt::DisplayRole).toString().split(" ").size()) > j) - { - nums[j] = field->data(1, Qt::DisplayRole).toString().split(" ").at(j).toUInt(); - } - } - } - else - { - // Single value - uint16_t* u = reinterpret_cast(m+messageInfo[msgid].fields[fieldid].wire_offset); - *u = field->data(1, Qt::DisplayRole).toUInt(); - } - break; - case MAVLINK_TYPE_INT32_T: - case MAVLINK_TYPE_UINT32_T: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - int32_t* nums = reinterpret_cast(m+messageInfo[msgid].fields[fieldid].wire_offset); - for (unsigned int j = 0; j < messageInfo[msgid].fields[fieldid].array_length; ++j) - { - if ((unsigned int)(field->data(1, Qt::DisplayRole).toString().split(" ").size()) > j) - { - nums[j] = field->data(1, Qt::DisplayRole).toString().split(" ").at(j).toUInt(); - } - } - } - else - { - // Single value - int32_t* u = reinterpret_cast(m+messageInfo[msgid].fields[fieldid].wire_offset); - *u = field->data(1, Qt::DisplayRole).toUInt(); - } - break; - case MAVLINK_TYPE_INT64_T: - case MAVLINK_TYPE_UINT64_T: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - int64_t* nums = reinterpret_cast(m+messageInfo[msgid].fields[fieldid].wire_offset); - for (unsigned int j = 0; j < messageInfo[msgid].fields[fieldid].array_length; ++j) - { - if ((unsigned int)(field->data(1, Qt::DisplayRole).toString().split(" ").size()) > j) - { - nums[j] = field->data(1, Qt::DisplayRole).toString().split(" ").at(j).toULongLong(); - } - } - } - else - { - // Single value - int64_t* u = reinterpret_cast(m+messageInfo[msgid].fields[fieldid].wire_offset); - *u = field->data(1, Qt::DisplayRole).toULongLong(); - } - break; - case MAVLINK_TYPE_FLOAT: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - float* nums = reinterpret_cast(m+messageInfo[msgid].fields[fieldid].wire_offset); - for (unsigned int j = 0; j < messageInfo[msgid].fields[fieldid].array_length; ++j) - { - if ((unsigned int)(field->data(1, Qt::DisplayRole).toString().split(" ").size()) > j) - { - nums[j] = field->data(1, Qt::DisplayRole).toString().split(" ").at(j).toFloat(); - } - } - } - else - { - // Single value - float* u = reinterpret_cast(m+messageInfo[msgid].fields[fieldid].wire_offset); - *u = field->data(1, Qt::DisplayRole).toFloat(); - } - break; - case MAVLINK_TYPE_DOUBLE: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - double* nums = reinterpret_cast(m+messageInfo[msgid].fields[fieldid].wire_offset); - for (unsigned int j = 0; j < messageInfo[msgid].fields[fieldid].array_length; ++j) - { - if ((unsigned int)(field->data(1, Qt::DisplayRole).toString().split(" ").size()) > j) - { - nums[j] = field->data(1, Qt::DisplayRole).toString().split(" ").at(j).toDouble(); - } - } - } - else - { - // Single value - double* u = reinterpret_cast(m+messageInfo[msgid].fields[fieldid].wire_offset); - *u = field->data(1, Qt::DisplayRole).toDouble(); - } - break; - } - } - - // Send message - protocol->sendMessage(msg); - } - else - { - result = false; - } - - return result; -} - -QGCMAVLinkMessageSender::~QGCMAVLinkMessageSender() -{ - delete ui; -} - -void QGCMAVLinkMessageSender::createTreeView() -{ - for (int i = 0; i < 256; ++i)//mavlink_message_t msg, receivedMessages) - { - // Update the tree view - QString messageName("%1 (%2 Hz, #%3)"); - float msgHz = messagesHz.value(i, 0); - - // Ignore non-existent messages - if (QString(messageInfo[i].name) == "EMPTY") continue; - - messageName = messageName.arg(messageInfo[i].name).arg(msgHz, 3, 'f', 1).arg(i); - if (!treeWidgetItems.contains(i)) - { - QStringList fields; - fields << messageName; - QTreeWidgetItem* widget = new QTreeWidgetItem(fields); - widget->setFirstColumnSpanned(true); - - for (unsigned int j = 0; j < messageInfo[i].num_fields; ++j) - { - QTreeWidgetItem* field = new QTreeWidgetItem(); - widget->addChild(field); - } - - treeWidgetItems.insert(i, widget); - ui->treeWidget->addTopLevelItem(widget); - - - QTreeWidgetItem* message = widget;//treeWidgetItems.value(msg->msgid); - message->setFirstColumnSpanned(true); - message->setData(0, Qt::DisplayRole, QVariant(messageName)); - for (unsigned int j = 0; j < messageInfo[i].num_fields; ++j) - { - createField(i, j, message->child(j)); - } - // Add management fields, such as update rate and send button - // QTreeWidgetItem* management = new QTreeWidgetItem(); - // widget->addChild(management); - // management->setData(0, Qt::DisplayRole, "Rate:"); - // management->setData(1, Qt::DisplayRole, 0); - // management->setData(2, Qt::DisplayRole, "Hz"); - // managementItems.insert(i, management); - } - } -} - -void QGCMAVLinkMessageSender::createField(int msgid, int fieldid, QTreeWidgetItem* item) -{ - // Add field tree widget item - item->setData(0, Qt::DisplayRole, QVariant(messageInfo[msgid].fields[fieldid].name)); - //uint8_t* m = ((uint8_t*)(receivedMessages+msgid))+8; - switch (messageInfo[msgid].fields[fieldid].type) - { - case MAVLINK_TYPE_CHAR: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - item->setData(2, Qt::DisplayRole, "char"); - item->setData(1, Qt::DisplayRole, ""); - } - else - { - // Single char - item->setData(2, Qt::DisplayRole, QString("char[%1]").arg(messageInfo[msgid].fields[fieldid].array_length)); - item->setData(1, Qt::DisplayRole, ""); - } - break; - case MAVLINK_TYPE_UINT8_T: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - // Enforce null termination - QString tmp("%1, "); - QString string; - for (unsigned int j = 0; j < messageInfo[msgid].fields[fieldid].array_length; ++j) - { - string += tmp.arg(0); - } - item->setData(2, Qt::DisplayRole, QString("uint8_t[%1]").arg(messageInfo[msgid].fields[fieldid].array_length)); - item->setData(1, Qt::DisplayRole, string); - } - else - { - // Single value - item->setData(2, Qt::DisplayRole, "uint8_t"); - item->setData(1, Qt::DisplayRole, 0); - } - break; - case MAVLINK_TYPE_INT8_T: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - // Enforce null termination - QString tmp("%1, "); - QString string; - for (unsigned int j = 0; j < messageInfo[msgid].fields[j].array_length; ++j) - { - string += tmp.arg(0); - } - item->setData(2, Qt::DisplayRole, QString("int8_t[%1]").arg(messageInfo[msgid].fields[fieldid].array_length)); - item->setData(1, Qt::DisplayRole, string); - } - else - { - // Single value - item->setData(2, Qt::DisplayRole, "int8_t"); - item->setData(1, Qt::DisplayRole, 0); - } - break; - case MAVLINK_TYPE_UINT16_T: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - // Enforce null termination - QString tmp("%1, "); - QString string; - for (unsigned int j = 0; j < messageInfo[msgid].fields[j].array_length; ++j) - { - string += tmp.arg(0); - } - item->setData(2, Qt::DisplayRole, QString("uint16_t[%1]").arg(messageInfo[msgid].fields[fieldid].array_length)); - item->setData(1, Qt::DisplayRole, string); - } - else - { - // Single value - item->setData(2, Qt::DisplayRole, "uint16_t"); - item->setData(1, Qt::DisplayRole, 0); - } - break; - case MAVLINK_TYPE_INT16_T: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - // Enforce null termination - QString tmp("%1, "); - QString string; - for (unsigned int j = 0; j < messageInfo[msgid].fields[j].array_length; ++j) - { - string += tmp.arg(0); - } - item->setData(2, Qt::DisplayRole, QString("int16_t[%1]").arg(messageInfo[msgid].fields[fieldid].array_length)); - item->setData(1, Qt::DisplayRole, string); - } - else - { - // Single value - item->setData(2, Qt::DisplayRole, "int16_t"); - item->setData(1, Qt::DisplayRole, 0); - } - break; - case MAVLINK_TYPE_UINT32_T: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - // Enforce null termination - QString tmp("%1, "); - QString string; - for (unsigned int j = 0; j < messageInfo[msgid].fields[j].array_length; ++j) - { - string += tmp.arg(0); - } - item->setData(2, Qt::DisplayRole, QString("uint32_t[%1]").arg(messageInfo[msgid].fields[fieldid].array_length)); - item->setData(1, Qt::DisplayRole, string); - } - else - { - // Single value - item->setData(2, Qt::DisplayRole, "uint32_t"); - item->setData(1, Qt::DisplayRole, 0); - } - break; - case MAVLINK_TYPE_INT32_T: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - // Enforce null termination - QString tmp("%1, "); - QString string; - for (unsigned int j = 0; j < messageInfo[msgid].fields[j].array_length; ++j) - { - string += tmp.arg(0); - } - item->setData(2, Qt::DisplayRole, QString("int32_t[%1]").arg(messageInfo[msgid].fields[fieldid].array_length)); - item->setData(1, Qt::DisplayRole, string); - } - else - { - // Single value - item->setData(2, Qt::DisplayRole, "int32_t"); - item->setData(1, Qt::DisplayRole, 0); - } - break; - case MAVLINK_TYPE_FLOAT: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - // Enforce null termination - QString tmp("%1, "); - QString string; - for (unsigned int j = 0; j < messageInfo[msgid].fields[j].array_length; ++j) - { - string += tmp.arg(0.0f); - } - item->setData(2, Qt::DisplayRole, QString("float[%1]").arg(messageInfo[msgid].fields[fieldid].array_length)); - item->setData(1, Qt::DisplayRole, string); - } - else - { - // Single value - item->setData(2, Qt::DisplayRole, "float"); - item->setData(1, Qt::DisplayRole, 0.0f); - } - break; - case MAVLINK_TYPE_DOUBLE: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - // Enforce null termination - QString tmp("%1, "); - QString string; - for (unsigned int j = 0; j < messageInfo[msgid].fields[j].array_length; ++j) - { - string += tmp.arg(0); - } - item->setData(2, Qt::DisplayRole, QString("double[%1]").arg(messageInfo[msgid].fields[fieldid].array_length)); - item->setData(1, Qt::DisplayRole, string); - } - else - { - // Single value - item->setData(2, Qt::DisplayRole, "double"); - item->setData(1, Qt::DisplayRole, 0.0); - } - break; - case MAVLINK_TYPE_UINT64_T: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - // Enforce null termination - QString tmp("%1, "); - QString string; - for (unsigned int j = 0; j < messageInfo[msgid].fields[j].array_length; ++j) - { - string += tmp.arg(0); - } - item->setData(2, Qt::DisplayRole, QString("uint64_t[%1]").arg(messageInfo[msgid].fields[fieldid].array_length)); - item->setData(1, Qt::DisplayRole, string); - } - else - { - // Single value - item->setData(2, Qt::DisplayRole, "uint64_t"); - item->setData(1, Qt::DisplayRole, (quint64) 0); - } - break; - case MAVLINK_TYPE_INT64_T: - if (messageInfo[msgid].fields[fieldid].array_length > 0) - { - // Enforce null termination - QString tmp("%1, "); - QString string; - for (unsigned int j = 0; j < messageInfo[msgid].fields[j].array_length; ++j) - { - string += tmp.arg(0); - } - item->setData(2, Qt::DisplayRole, QString("int64_t[%1]").arg(messageInfo[msgid].fields[fieldid].array_length)); - item->setData(1, Qt::DisplayRole, string); - } - else - { - // Single value - item->setData(2, Qt::DisplayRole, "int64_t"); - item->setData(1, Qt::DisplayRole, (qint64) 0); - } - break; - } -} diff --git a/src/ui/mavlink/QGCMAVLinkMessageSender.h b/src/ui/mavlink/QGCMAVLinkMessageSender.h deleted file mode 100644 index 267c9c2d1c0b18f90d9b696bdfcbdb31342385ff..0000000000000000000000000000000000000000 --- a/src/ui/mavlink/QGCMAVLinkMessageSender.h +++ /dev/null @@ -1,52 +0,0 @@ -#ifndef QGCMAVLINKMESSAGESENDER_H -#define QGCMAVLINKMESSAGESENDER_H - -#include -#include -#include -#include -#include "MAVLinkProtocol.h" - -namespace Ui { -class QGCMAVLinkMessageSender; -} - -class QGCMAVLinkMessageSender : public QWidget -{ - Q_OBJECT - - friend class QTimer; - -public: - explicit QGCMAVLinkMessageSender(MAVLinkProtocol* mavlink, QWidget *parent = 0); - ~QGCMAVLinkMessageSender(); - -public slots: - /** @brief Send message currently selected in ui, taking values from tree view */ - bool sendMessage(); - -protected: - mavlink_message_info_t messageInfo[256]; ///< Meta information about all messages - MAVLinkProtocol* protocol; ///< MAVLink protocol - QMap messagesHz; ///< Used to store update rate in Hz - QTimer refreshTimer; - QMap sendTimers; - QMap managementItems; - QMap treeWidgetItems; ///< Messages - - /** @brief Create the tree view of all messages */ - void createTreeView(); - /** @brief Create one field of one message in the tree view of all messages */ - void createField(int msgid, int fieldid, QTreeWidgetItem* item); - /** @brief Send message with values taken from tree view */ - bool sendMessage(unsigned int id); - -protected slots: - /** @brief Read / display values in UI */ - void refresh(); - -private: - Ui::QGCMAVLinkMessageSender *ui; -}; - -#endif // QGCMAVLINKMESSAGESENDER_H diff --git a/src/ui/mavlink/QGCMAVLinkMessageSender.ui b/src/ui/mavlink/QGCMAVLinkMessageSender.ui deleted file mode 100644 index 5b4ea00e9ed0bd1fd0e9e1b554580b8e777c5107..0000000000000000000000000000000000000000 --- a/src/ui/mavlink/QGCMAVLinkMessageSender.ui +++ /dev/null @@ -1,43 +0,0 @@ - - - QGCMAVLinkMessageSender - - - - 0 - 0 - 400 - 300 - - - - Form - - - - 6 - - - - - - 1 - - - - - - - - - - - Send Message - - - - - - - - diff --git a/src/ui/toolbar/MainToolBar.cc b/src/ui/toolbar/MainToolBar.cc index 6d8dea3d65790b88ee298d0dae194c749f3090d0..f837b64c351b5c5b0466e59d4578cef552a50aed 100644 --- a/src/ui/toolbar/MainToolBar.cc +++ b/src/ui/toolbar/MainToolBar.cc @@ -38,6 +38,7 @@ This file is part of the QGROUNDCONTROL project #include "FlightDisplayView.h" #include "QGCApplication.h" #include "MultiVehicleManager.h" +#include "UAS.h" MainToolBar::MainToolBar(QWidget* parent) : QGCQmlWidgetHolder(parent)