Skip to content
MainWindow.h 11.9 KiB
Newer Older
pixhawk's avatar
pixhawk committed
/*=====================================================================

QGroundControl Open Source Ground Control Station
pixhawk's avatar
pixhawk committed

(c) 2009, 2010 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
pixhawk's avatar
pixhawk committed

This file is part of the QGROUNDCONTROL project
pixhawk's avatar
pixhawk committed

    QGROUNDCONTROL is free software: you can redistribute it and/or modify
pixhawk's avatar
pixhawk committed
    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,
pixhawk's avatar
pixhawk committed
    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 <http://www.gnu.org/licenses/>.
pixhawk's avatar
pixhawk committed

======================================================================*/

/**
 * @file
 *   @brief Definition of class MainWindow
pixhawk's avatar
pixhawk committed
 *   @author Lorenz Meier <mavteam@student.ethz.ch>
 *
 */

#ifndef _MAINWINDOW_H_
#define _MAINWINDOW_H_

#include <QtGui/QMainWindow>
#include <QStatusBar>
#include <QStackedWidget>
pixhawk's avatar
pixhawk committed

#include "ui_MainWindow.h"
#include "LinkManager.h"
#include "LinkInterface.h"
#include "UASInterface.h"
#include "UASManager.h"
#include "UASControlWidget.h"
pixhawk's avatar
pixhawk committed
#include "UASInfoWidget.h"
#include "WaypointList.h"
#include "CameraView.h"
#include "UASListWidget.h"
#include "MAVLinkProtocol.h"
#include "MAVLinkSimulationLink.h"
pixhawk's avatar
pixhawk committed
#include "ObjectDetectionView.h"
#include "HUD.h"
#include "JoystickWidget.h"
#include "input/JoystickInput.h"
#include "DebugConsole.h"
lm's avatar
lm committed
//#include "MapWidget.h"
pixhawk's avatar
pixhawk committed
#include "ParameterInterface.h"
#include "XMLCommProtocolWidget.h"
#include "HDDisplay.h"
#include "WatchdogControl.h"
#include "QGCDataPlot2D.h"
lm's avatar
lm committed
#include "QGCRemoteControlView.h"
lm's avatar
lm committed
#include "opmapcontrol.h"
#if (defined Q_OS_MAC) | (defined _MSC_VER)
pixhawk's avatar
pixhawk committed
#include "QGCGoogleEarthView.h"
#include "QGCToolBar.h"
pixhawk's avatar
pixhawk committed
#include "LogCompressor.h"
#include "SlugsHilSim.h"
pixhawk's avatar
pixhawk committed

#include "SlugsPadCameraControl.h"
#include "UASControlParameters.h"
lm's avatar
lm committed
#include "QGCFlightGearLink.h"
pixhawk's avatar
pixhawk committed

class QGCMapTool;

pixhawk's avatar
pixhawk committed
/**
 * @brief Main Application Window
 *
 **/
class MainWindow : public QMainWindow
{
pixhawk's avatar
pixhawk committed
    Q_OBJECT

public:
    static MainWindow* instance();
pixhawk's avatar
pixhawk committed
    ~MainWindow();
pixhawk's avatar
pixhawk committed

    enum QGC_MAINWINDOW_STYLE {
        QGC_MAINWINDOW_STYLE_NATIVE,
        QGC_MAINWINDOW_STYLE_INDOOR,
        QGC_MAINWINDOW_STYLE_OUTDOOR
    };

    /** @brief Get current visual style */
    int getStyle() {
        return currentStyle;
    }
    /** @brief Get auto link reconnect setting */
    bool autoReconnectEnabled() {
        return autoReconnect;
    }
    /** @brief Get low power mode setting */
    bool lowPowerModeEnabled() {
        return lowPowerMode;
    }

pixhawk's avatar
pixhawk committed
public slots:
lm's avatar
lm committed
//    /** @brief Store the mainwindow settings */
//    void storeSettings();
    /** @brief Shows a status message on the bottom status bar */
pixhawk's avatar
pixhawk committed
    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);
lm's avatar
lm committed
    /** @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 */
pixhawk's avatar
pixhawk committed
    void addLink();
pixhawk's avatar
pixhawk committed
    void addLink(LinkInterface* link);
pixhawk's avatar
pixhawk committed
    void configure();
    /** @brief Set the currently controlled UAS */
    void setActiveUAS(UASInterface* uas);
Alejandro's avatar
Alejandro committed

pixhawk's avatar
pixhawk committed
    void UASCreated(UASInterface* uas);
    /** @brief Update system specs of a UAS */
    void UASSpecsChanged(int uas);
pixhawk's avatar
pixhawk committed
    void startVideoCapture();
    void stopVideoCapture();
    void saveScreen();
pixhawk's avatar
pixhawk committed

    /** @brief Load default view when no MAV is connected */
    void loadUnconnectedView();
pixhawk's avatar
pixhawk committed
    /** @brief Load view for pilot */
    void loadPilotView();
    /** @brief Load view for engineer */
    void loadEngineerView();
    /** @brief Load view for operator */
    void loadOperatorView();
    /** @brief Load MAVLink XML generator view */
    void loadMAVLinkView();
    /** @brief Show the online help for users */
    void showHelp();
    /** @brief Show the authors / credits */
    void showCredits();
    /** @brief Show the project roadmap */
    void showRoadMap();
pixhawk's avatar
pixhawk committed

    /** @brief Reload the CSS style sheet */
pixhawk's avatar
pixhawk committed
    void reloadStylesheet();
    /** @brief Let the user select the CSS style sheet */
    void selectStylesheet();
    /** @brief Automatically reconnect last link */
    void enableAutoReconnect(bool enabled);
    /** @brief Save power by reducing update rates */
    void enableLowPowerMode(bool enabled) { lowPowerMode = enabled; }
    /** @brief Switch to native application style */
    void loadNativeStyle();
    /** @brief Switch to indoor mission style */
    void loadIndoorStyle();
    /** @brief Switch to outdoor mission style */
    void loadOutdoorStyle();
    /** @brief Load a specific style */
    void loadStyle(QGC_MAINWINDOW_STYLE style);
    /** @brief Add a custom tool widget */
    void createCustomWidget();

    /** @brief Load a custom tool widget from a file */
    void loadCustomWidget();

    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
     *
     */

    /**
     * @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
     *
     */
pixhawk's avatar
pixhawk committed
protected:
    /** @brief Set default window settings for the current autopilot type */
    void setDefaultSettingsForAp();

    typedef enum _VIEW_SECTIONS {
        VIEW_ENGINEER,
        VIEW_OPERATOR,
        VIEW_PILOT,
        VIEW_MAVLINK,
        VIEW_UNCONNECTED,    ///< View in unconnected mode, when no UAS is available
        VIEW_FULL            ///< All widgets shown at once

    QHash<int, QAction*> toolsMenuActions; // Holds ptr to the Menu Actions
    QHash<int, QWidget*> dockWidgets;  // Holds ptr to the Actual Dock widget
//    QHash<int, Qt::DockWidgetArea> dockWidgetLocations; // Holds the location
    /**
     * @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(QDockWidget* widget, const QString& title, Qt::DockWidgetArea location=Qt::RightDockWidgetArea);

//    /**
//     * @brief Determines if a QDockWidget needs to be show and if so, shows it
//     *
//     *  Based on the the autopilot and the current view it queries the settings and shows the
//     *  widget if necessary
//     *
//     * @param widget    The QDockWidget requested to be shown
//     * @param view      The view for which the QDockWidget is requested
//     */
//    void showTheWidget (TOOLS_WIDGET_NAMES widget, VIEW_SECTIONS view = VIEW_MAVLINK);

    /**
     * @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);
lm's avatar
lm committed
    /** @brief Catch window resize events */
    void resizeEvent(QResizeEvent * event);
    bool aboutToCloseFlag;
    void storeViewState();
    void loadViewState();
lm's avatar
lm committed
    void buildCustomWidget();
//    void buildPxWidgets();
//    void buildSlugsWidgets();
//    void connectPxWidgets();
//    void connectSlugsWidgets();
//    void arrangePxCenterStack();
//    void arrangeSlugsCenterStack();
//    void connectPxActions();
//    void connectSlugsActions();
    void loadSettings();
    void storeSettings();
pixhawk's avatar
pixhawk committed

    // TODO Should be moved elsewhere, as the protocol does not belong to the UI
    MAVLinkProtocol* mavlink;

    MAVLinkSimulationLink* simulationLink;
pixhawk's avatar
pixhawk committed
    LinkInterface* udpLink;

    QActionGroup centerStackActionGroup;
    // Center widgets
    QPointer<Linecharts> linechartWidget;
    QPointer<HUD> hudWidget;
    QPointer<QGCMapTool> mapWidget;
    QPointer<XMLCommProtocolWidget> protocolWidget;
    QPointer<QGCDataPlot2D> dataplotWidget;
#ifdef QGC_OSG_ENABLED
    QPointer<QWidget> _3DWidget;
#endif
#ifdef QGC_OSGEARTH_ENABLED
    QPointer<QWidget> _3DMapWidget;
#if (defined _MSC_VER) || (defined Q_OS_MAC)
pixhawk's avatar
pixhawk committed
    QPointer<QGCGoogleEarthView> gEarthWidget;
    // Dock widgets
    QPointer<QDockWidget> controlDockWidget;
    QPointer<QDockWidget> controlParameterWidget;
    QPointer<QDockWidget> infoDockWidget;
    QPointer<QDockWidget> cameraDockWidget;
    QPointer<QDockWidget> listDockWidget;
    QPointer<QDockWidget> waypointsDockWidget;
    QPointer<QDockWidget> detectionDockWidget;
    QPointer<QDockWidget> debugConsoleDockWidget;
    QPointer<QDockWidget> parametersDockWidget;
    QPointer<QDockWidget> headDown1DockWidget;
    QPointer<QDockWidget> headDown2DockWidget;
    QPointer<QDockWidget> watchdogControlDockWidget;
pixhawk's avatar
pixhawk committed
    QPointer<QDockWidget> video1DockWidget;
    QPointer<QDockWidget> video2DockWidget;
    QPointer<QDockWidget> logPlayerDockWidget;
    QPointer<QDockWidget> hsiDockWidget;
    QPointer<QDockWidget> rcViewDockWidget;
    QPointer<QDockWidget> hudDockWidget;
    QPointer<QDockWidget> slugsHilSimWidget;
    QPointer<QDockWidget> slugsCamControlWidget;
pixhawk's avatar
pixhawk committed

    QPointer<QGCToolBar> toolBar;

pixhawk's avatar
pixhawk committed

    // Popup widgets
    JoystickWidget* joystickWidget;

    JoystickInput* joystick;

    /** User interface actions **/
    QAction* connectUASAct;
    QAction* disconnectUASAct;
    QAction* startUASAct;
    QAction* returnUASAct;
    QAction* stopUASAct;
    QAction* killUASAct;
    QAction* simulateUASAct;
pixhawk's avatar
pixhawk committed
    LogCompressor* comp;
pixhawk's avatar
pixhawk committed
    QString screenFileName;
    QTimer* videoTimer;
    bool autoReconnect;
    QGC_MAINWINDOW_STYLE currentStyle;
    bool lowPowerMode; ///< If enabled, QGC reduces the update rates of all widgets
lm's avatar
lm committed
    QGCFlightGearLink* fgLink;
pixhawk's avatar
pixhawk committed

private:
pixhawk's avatar
pixhawk committed
    Ui::MainWindow ui;
//    QString buildMenuKey (SETTINGS_SECTIONS section , TOOLS_WIDGET_NAMES tool, VIEW_SECTIONS view);
    QString getWindowStateKey();
    QString getWindowGeometryKey();
pixhawk's avatar
pixhawk committed
};

#endif /* _MAINWINDOW_H_ */