/*===================================================================== 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 configuration window for serial links * * @author Lorenz Meier * */ #ifndef _SERIALCONFIGURATIONWINDOW_H_ #define _SERIALCONFIGURATIONWINDOW_H_ #include #include #include #include #include #include #include #include #include "ui_SerialSettings.h" class SerialConfigurationWindow : public QWidget { Q_OBJECT public: SerialConfigurationWindow(LinkInterface* link, QWidget *parent = 0, Qt::WindowFlags flags = Qt::Sheet); ~SerialConfigurationWindow(); QAction* getAction(); public slots: void configureCommunication(); void enableFlowControl(bool flow); void setParityNone(); void setParityOdd(); void setParityEven(); void setPortName(QString port); void setLinkName(QString name); /** * @brief Remove this link * * Disconnects the associated link, removes it from all menus and closes the window. */ void remove(); void setupPortList(); protected slots: void showEvent(QShowEvent* event); void hideEvent(QHideEvent* event); protected: bool userConfigured; ///< Switch to detect if current values are user-selected and shouldn't be overriden private: Ui::serialSettings ui; SerialLinkInterface* link; QAction* action; QTimer* portCheckTimer; }; #endif // _SERIALCONFIGURATIONWINDOW_H_