/*===================================================================== QGroundControl Open Source Ground Control Station (c) 2009, 2010 QGROUNDCONTROL/PIXHAWK 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 Declaration of class QGCParamWidget * @author Lorenz Meier */ #ifndef QGCPARAMWIDGET_H #define QGCPARAMWIDGET_H #include #include #include #include #include "UASInterface.h" /** * @brief Widget to read/set onboard parameters */ class QGCParamWidget : public QWidget { Q_OBJECT public: explicit QGCParamWidget(UASInterface* uas, QWidget *parent = 0); /** @brief Get the UAS of this widget */ UASInterface* getUAS(); signals: /** @brief A parameter was changed in the widget, NOT onboard */ void parameterChanged(int component, QString parametername, float value); public slots: /** @brief Add a component to the list */ void addComponent(int uas, int component, QString componentName); /** @brief Add a parameter to the list */ void addParameter(int uas, int component, QString parameterName, float value); /** @brief Request list of parameters from MAV */ void requestParameterList(); /** @brief Set one parameter, changes value in RAM of MAV */ void setParameter(int component, QString parameterName, float value); /** @brief Set all parameters, changes the value in RAM of MAV */ void setParameters(); /** @brief Write the current parameters to permanent storage (EEPROM/HDD) */ void writeParameters(); /** @brief Clear the parameter list */ void clear(); /** @brief Update when user changes parameters */ void parameterItemChanged(QTreeWidgetItem* prev, int column); protected: UASInterface* mav; ///< The MAV this widget is controlling QTreeWidget* tree; ///< The parameter tree QMap* components; ///< The list of components QMap* > paramGroups; ///< Parameter groups QMap* > changedValues; ///< Changed values }; #endif // QGCPARAMWIDGET_H