Skip to content
QGCUASParamManager.h 2.99 KiB
Newer Older
#ifndef QGCUASPARAMMANAGER_H
#define QGCUASPARAMMANAGER_H

#include <QWidget>
#include <QMap>
#include <QTimer>
#include <QVariant>
#include "UASParameterDataModel.h"

tstellanova's avatar
tstellanova committed
//forward declarations
tstellanova's avatar
tstellanova committed
class UASParameterCommsMgr;
class QGCUASParamManager : public QObject
    QGCUASParamManager(QObject* parent = 0);
    QGCUASParamManager* initWithUAS(UASInterface* uas);
tstellanova's avatar
tstellanova committed
    /** @brief Get the known, confirmed value of a parameter */
tstellanova's avatar
tstellanova committed
    virtual bool getParameterValue(int component, const QString& parameter, QVariant& value) const;
    /** @brief Provide tooltips / user-visible descriptions for parameters */
    virtual void setParamDescriptions(const QMap<QString,QString>& paramDescs);

tstellanova's avatar
tstellanova committed
    /** @brief Get the UAS of this widget
     * @return The MAV of this mgr. Unless the MAV object has been destroyed, this is never null.
     */
    UASInterface* getUAS();
tstellanova's avatar
tstellanova committed

    /** @return The data model managed by this class */
    virtual UASParameterDataModel* dataModel();

tstellanova's avatar
tstellanova committed
protected:
tstellanova's avatar
tstellanova committed
    /** @brief Load parameter meta information from appropriate CSV file */
    virtual void loadParamMetaInfoCSV();
tstellanova's avatar
tstellanova committed


    /** @brief We updated the parameter status message */
    void parameterStatusMsgUpdated(QString msg, int level);
    /** @brief We have received a complete list of all parameters onboard the MAV */
    void parameterListUpToDate();
tstellanova's avatar
tstellanova committed
    /** @brief Send one parameter to the MAV: changes value in transient memory of MAV */
    virtual void setParameter(int component, QString parameterName, QVariant value);

tstellanova's avatar
tstellanova committed
    /** @brief Send all pending parameters to the MAV, for storage in transient (RAM) memory */
    virtual void sendPendingParameters();

    /** @brief Request list of parameters from MAV */
tstellanova's avatar
tstellanova committed
    virtual void requestParameterList();
    /** @brief Request a list of params onboard the MAV if the onboard param list we have is empty */
    virtual void requestParameterListIfEmpty();

    virtual void setPendingParam(int componentId,  QString& key,  const QVariant& value);

tstellanova's avatar
tstellanova committed
    /** @brief Request a single parameter by name from the MAV */
    virtual void requestParameterUpdate(int component, const QString& parameter);

    virtual void writeOnboardParamsToStream(QTextStream &stream, const QString& uasName);
    virtual void readPendingParamsFromStream(QTextStream &stream);

    virtual void requestRcCalibrationParamsUpdate();

    /** @brief Copy the current parameters in volatile RAM to persistent storage (EEPROM/HDD) */
    virtual void copyVolatileParamsToPersistent();
    /** @brief Copy the parameters from persistent storage to volatile RAM  */
    virtual void copyPersistentParamsToVolatile();
tstellanova's avatar
tstellanova committed
    // Parameter data model
tstellanova's avatar
tstellanova committed
    UASInterface*           mav;   ///< The MAV this manager is controlling
    UASParameterDataModel  paramDataModel;///< Shared data model of parameters
tstellanova's avatar
tstellanova committed
    UASParameterCommsMgr*   paramCommsMgr; ///< Shared comms mgr for parameters