/*===================================================================== QGroundControl Open Source Ground Control Station (c) 2009, 2010 QGROUNDCONTROL PROJECT This file is part of the QGROUNDCONTROL project QGROUNDCONTROL is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. QGROUNDCONTROL is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with QGROUNDCONTROL. If not, see . ======================================================================*/ /** * @file * @brief Definition of class MainWindow * @author Lorenz Meier * */ #ifndef _MAINWINDOW_H_ #define _MAINWINDOW_H_ #include #include #include #include #include #include "ui_MainWindow.h" #include "LinkManager.h" #include "LinkInterface.h" #include "UASInterface.h" #include "UASManager.h" #include "UASControlWidget.h" #include "UASInfoWidget.h" #include "WaypointList.h" #include "CameraView.h" #include "UASListWidget.h" #include "MAVLinkProtocol.h" #include "MAVLinkSimulationLink.h" #include "ObjectDetectionView.h" #include "submainwindow.h" #include "input/JoystickInput.h" #if (defined MOUSE_ENABLED_WIN) | (defined MOUSE_ENABLED_LINUX) #include "Mouse6dofInput.h" #endif // MOUSE_ENABLED_WIN #include "DebugConsole.h" #include "ParameterInterface.h" #include "XMLCommProtocolWidget.h" #include "HDDisplay.h" #include "WatchdogControl.h" #include "HSIDisplay.h" #include "QGCRemoteControlView.h" #include "opmapcontrol.h" #if (defined Q_OS_MAC) | (defined _MSC_VER) #include "QGCGoogleEarthView.h" #endif #include "QGCToolBar.h" #include "SlugsDataSensorView.h" #include "LogCompressor.h" #include "SlugsHilSim.h" #include "SlugsPadCameraControl.h" #include "UASControlParameters.h" #include "QGCMAVLinkInspector.h" #include "QGCMAVLinkLogPlayer.h" #include "QGCVehicleConfig.h" #include "MAVLinkDecoder.h" class QGCMapTool; class QGCMAVLinkMessageSender; class QGCFirmwareUpdate; class QSplashScreen; class QGCStatusBar; class Linecharts; class QGCDataPlot2D; class JoystickWidget; /** * @brief Main Application Window * **/ class MainWindow : public QMainWindow { Q_OBJECT public: /** * A static function for obtaining the sole instance of the MainWindow. The screen * argument is only important on the FIRST call to this function. The provided splash * screen is updated with some status messages that are emitted during init(). This * function cannot be used within the MainWindow constructor! */ static MainWindow* instance(QSplashScreen* screen = 0); /** * Initializes the MainWindow. Some variables are initialized and the widget is hidden. * Initialization of the MainWindow class really occurs in init(), which loads the UI * and does everything important. The constructor is split in two like this so that * the instance() is available for all classes. */ MainWindow(QWidget *parent = NULL); ~MainWindow(); /** * This function actually performs the non-trivial initialization of the MainWindow * class. This is separate from the constructor because instance() won't work within * code executed in the MainWindow constructor. */ void init(); enum QGC_MAINWINDOW_STYLE { QGC_MAINWINDOW_STYLE_DARK, QGC_MAINWINDOW_STYLE_LIGHT }; // Declare default dark and light stylesheets. These should be file-resource // paths. static const QString defaultDarkStyle; static const QString defaultLightStyle; /** @brief Get current visual style */ QGC_MAINWINDOW_STYLE getStyle() { return currentStyle; } /** @brief Get current light visual stylesheet */ QString getLightStyleSheet() { return lightStyleFileName; } /** @brief Get current dark visual stylesheet */ QString getDarkStyleSheet() { return darkStyleFileName; } /** @brief Get auto link reconnect setting */ bool autoReconnectEnabled() { return autoReconnect; } /** @brief Get custom toolbar setting */ bool isApmToolBarEnabled() { return apmToolBarEnabled; } /** @brief Get title bar mode setting */ bool dockWidgetTitleBarsEnabled() { return dockWidgetTitleBarEnabled; } /** @brief Get low power mode setting */ bool lowPowerModeEnabled() { return lowPowerMode; } QList listLinkMenuActions(void); public slots: /** @brief Shows a status message on the bottom status bar */ void showStatusMessage(const QString& status, int timeout); /** @brief Shows a status message on the bottom status bar */ void showStatusMessage(const QString& status); /** @brief Shows a critical message as popup or as widget */ void showCriticalMessage(const QString& title, const QString& message); /** @brief Shows an info message as popup or as widget */ void showInfoMessage(const QString& title, const QString& message); /** @brief Show the application settings */ void showSettings(); /** @brief Add a communication link */ void addLink(); void addLink(LinkInterface* link); bool configLink(LinkInterface *link); void configure(); /** @brief Set the currently controlled UAS */ void setActiveUAS(UASInterface* uas); /** @brief Add a new UAS */ void UASCreated(UASInterface* uas); /** Delete an UAS */ void UASDeleted(UASInterface* uas); /** @brief Update system specs of a UAS */ void UASSpecsChanged(int uas); void startVideoCapture(); void stopVideoCapture(); void saveScreen(); /** @brief Sets advanced mode, allowing for editing of tool widget locations */ void setAdvancedMode(); /** @brief Load configuration views */ void loadHardwareConfigView(); void loadSoftwareConfigView(); /** @brief Load default view when no MAV is connected */ void loadUnconnectedView(); /** @brief Load view for pilot */ void loadPilotView(); /** @brief Load view for simulation */ void loadSimulationView(); /** @brief Load view for engineer */ void loadEngineerView(); /** @brief Load view for operator */ void loadOperatorView(); /** @brief Load MAVLink XML generator view */ void loadMAVLinkView(); /** @brief Load firmware update view */ void loadFirmwareUpdateView(); /** @brief Show the online help for users */ void showHelp(); /** @brief Show the authors / credits */ void showCredits(); /** @brief Show the project roadmap */ void showRoadMap(); /** @breif Enable title bars on dock widgets when no in advanced mode */ void enableDockWidgetTitleBars(bool enabled); /** @brief Automatically reconnect last link */ void enableAutoReconnect(bool enabled); /** @brief Enable APM specific toolbar */ void enableApmToolbar(bool enabled) { apmToolBarEnabled = enabled; } /** @brief Save power by reducing update rates */ void enableLowPowerMode(bool enabled) { lowPowerMode = enabled; } /** @brief Load a specific style. * If it's a custom style, load the file indicated by the cssFile path. */ bool loadStyle(QGC_MAINWINDOW_STYLE style, QString cssFile); /** @brief Add a custom tool widget */ void createCustomWidget(); /** @brief Load a custom tool widget from a file chosen by user (QFileDialog) */ void loadCustomWidget(); /** @brief Load a custom tool widget from a file */ void loadCustomWidget(const QString& fileName, bool singleinstance=false); void loadCustomWidget(const QString& fileName, int view); /** @brief Load custom widgets from default file */ void loadCustomWidgetsFromDefaults(const QString& systemType, const QString& autopilotType); /** @brief Loads and shows the HIL Configuration Widget for the given UAS*/ void showHILConfigurationWidget(UASInterface *uas); void closeEvent(QCloseEvent* event); /** @brief Load data view, allowing to plot flight data */ // void loadDataView(QString fileName); /** * @brief Shows a Docked Widget based on the action sender * * This slot is written to be used in conjunction with the addTool() function * It shows the QDockedWidget based on the action sender * */ void showTool(bool visible); /** * @brief Shows a Widget from the center stack based on the action sender * * This slot is written to be used in conjunction with the addCentralWidget() function * It shows the Widget based on the action sender * */ void showCentralWidget(); /** @brief Update the window name */ void configureWindowName(); void commsWidgetDestroyed(QObject *obj); signals: void styleChanged(MainWindow::QGC_MAINWINDOW_STYLE newTheme); void initStatusChanged(const QString& message, int alignment, const QColor &color); #ifdef MOUSE_ENABLED_LINUX /** @brief Forward X11Event to catch 3DMouse inputs */ void x11EventOccured(XEvent *event); #endif //MOUSE_ENABLED_LINUX public: QGCMAVLinkLogPlayer* getLogPlayer() { return logPlayer; } MAVLinkProtocol* getMAVLink() { return mavlink; } protected: typedef enum _VIEW_SECTIONS { VIEW_ENGINEER, VIEW_MISSION, VIEW_FLIGHT, VIEW_SIMULATION, VIEW_MAVLINK, VIEW_FIRMWAREUPDATE, VIEW_HARDWARE_CONFIG, VIEW_SOFTWARE_CONFIG, VIEW_UNCONNECTED, ///< View in unconnected mode, when no UAS is available VIEW_FULL ///< All widgets shown at once } VIEW_SECTIONS; /** * @brief Adds an already instantiated QDockedWidget to the Tools Menu * * This function does all the hosekeeping to have a QDockedWidget added to the * tools menu and connects the QMenuAction to a slot that shows the widget and * checks/unchecks the tools menu item * * @param widget The QDockWidget being added * @param title The entry that will appear in the Menu and in the QDockedWidget title bar * @param location The default location for the QDockedWidget in case there is no previous key in the settings */ void addTool(SubMainWindow *parent,VIEW_SECTIONS view,QDockWidget* widget, const QString& title, Qt::DockWidgetArea area); void loadDockWidget(QString name); QDockWidget* createDockWidget(QWidget *parent,QWidget *child,QString title,QString objectname,VIEW_SECTIONS view,Qt::DockWidgetArea area,int minwidth=0,int minheight=0); /** * @brief Adds an already instantiated QWidget to the center stack * * This function does all the hosekeeping to have a QWidget added to the tools menu * tools menu and connects the QMenuAction to a slot that shows the widget and * checks/unchecks the tools menu item. This is used for all the central widgets (those in * the center stack. * * @param widget The QWidget being added * @param title The entry that will appear in the Menu */ void addCentralWidget(QWidget* widget, const QString& title); /** @brief Catch window resize events */ void resizeEvent(QResizeEvent * event); /** @brief Keeps track of the current view */ VIEW_SECTIONS currentView; QGC_MAINWINDOW_STYLE currentStyle; bool aboutToCloseFlag; bool changingViewsFlag; void storeViewState(); void loadViewState(); void buildCustomWidget(); void buildCommonWidgets(); void connectCommonWidgets(); void connectCommonActions(); void connectSenseSoarActions(); void loadSettings(); void storeSettings(); // TODO Should be moved elsewhere, as the protocol does not belong to the UI MAVLinkProtocol* mavlink; MAVLinkSimulationLink* simulationLink; LinkInterface* udpLink; QSettings settings; QStackedWidget *centerStack; QActionGroup* centerStackActionGroup; // Center widgets QPointer plannerView; QPointer pilotView; QPointer configView; QPointer softwareConfigView; QPointer mavlinkView; QPointer engineeringView; QPointer simView; // Center widgets QPointer linechartWidget; //QPointer hudWidget; //QPointer configWidget; //QPointer mapWidget; //QPointer protocolWidget; //QPointer dataplotWidget; #ifdef QGC_OSG_ENABLED QPointer _3DWidget; #endif #if (defined _MSC_VER) || (defined Q_OS_MAC) QPointer gEarthWidget; #endif QPointer firmwareUpdateWidget; // Dock widgets QPointer controlDockWidget; QPointer controlParameterWidget; QPointer infoDockWidget; QPointer cameraDockWidget; QPointer listDockWidget; QPointer waypointsDockWidget; QPointer detectionDockWidget; QPointer debugConsoleDockWidget; QPointer parametersDockWidget; QPointer headDown1DockWidget; QPointer headDown2DockWidget; QPointer watchdogControlDockWidget; QPointer headUpDockWidget; QPointer video1DockWidget; QPointer video2DockWidget; QPointer rgbd1DockWidget; QPointer rgbd2DockWidget; QPointer logPlayerDockWidget; QPointer hsiDockWidget; QPointer rcViewDockWidget; QPointer hudDockWidget; QPointer slugsDataWidget; QPointer slugsHilSimWidget; QPointer slugsCamControlWidget; QPointer toolBar; QPointer customStatusBar; QPointer debugConsole; QPointer mavlinkInspectorWidget; QPointer mavlinkDecoder; QPointer mavlinkSenderWidget; QGCMAVLinkLogPlayer* logPlayer; QMap hilDocks; // Popup widgets JoystickWidget* joystickWidget; JoystickInput* joystick; #ifdef MOUSE_ENABLED_WIN /** @brief 3d Mouse support (WIN only) */ Mouse3DInput* mouseInput; ///< 3dConnexion 3dMouse SDK Mouse6dofInput* mouse; ///< Implementation for 3dMouse input #endif // MOUSE_ENABLED_WIN #ifdef MOUSE_ENABLED_LINUX /** @brief Reimplementation of X11Event to handle 3dMouse Events (magellan) */ bool x11Event(XEvent *event); Mouse6dofInput* mouse; ///< Implementation for 3dMouse input #endif // MOUSE_ENABLED_LINUX /** User interface actions **/ QAction* connectUASAct; QAction* disconnectUASAct; QAction* startUASAct; QAction* returnUASAct; QAction* stopUASAct; QAction* killUASAct; QAction* simulateUASAct; LogCompressor* comp; QString screenFileName; QTimer* videoTimer; QString darkStyleFileName; QString lightStyleFileName; bool autoReconnect; bool apmToolBarEnabled; Qt::WindowStates windowStateVal; bool lowPowerMode; ///< If enabled, QGC reduces the update rates of all widgets QGCFlightGearLink* fgLink; QTimer windowNameUpdateTimer; private: QList commsWidgetList; QMap customWidgetNameToFilenameMap; QMap menuToDockNameMap; QList dockWidgets; QMap > centralWidgetToDockWidgetsMap; bool isAdvancedMode; ///< If enabled dock widgets can be moved and floated. bool dockWidgetTitleBarEnabled; ///< If enabled, dock widget titlebars are displayed when NOT in advanced mode. Ui::MainWindow ui; /** @brief Set the appropriate titlebar for a given dock widget. * Relies on the isAdvancedMode and dockWidgetTitleBarEnabled member variables. */ void setDockWidgetTitleBar(QDockWidget* widget); QString getWindowStateKey(); QString getWindowGeometryKey(); }; #endif /* _MAINWINDOW_H_ */