UASParameterDataModel.h 5.12 KB
Newer Older
1 2 3 4 5 6 7
#ifndef UASPARAMETERDATAMODEL_H
#define UASPARAMETERDATAMODEL_H

#include <QMap>
#include <QObject>
#include <QVariant>

8 9
class QTextStream;

10 11 12 13 14 15 16
class UASParameterDataModel : public QObject
{
    Q_OBJECT
public:
    explicit UASParameterDataModel(QObject *parent = 0);
    

17 18 19 20 21 22 23 24 25 26 27 28 29 30
    //Parameter meta info
    bool isParamMinKnown(const QString& param) { return paramMin.contains(param); }
    virtual bool isValueLessThanParamMin(const QString& param, double dblVal);

    bool isParamMaxKnown(const QString& param) { return paramMax.contains(param); }
    virtual bool isValueGreaterThanParamMax(const QString& param, double dblVal);

    bool isParamDefaultKnown(const QString& param) { return paramDefault.contains(param); }
    double getParamMin(const QString& param) { return paramMin.value(param, 0.0f); }
    double getParamMax(const QString& param) { return paramMax.value(param, 0.0f); }
    double getParamDefault(const QString& param) { return paramDefault.value(param, 0.0f); }
    virtual QString getParamDescription(const QString& param) { return paramDescriptions.value(param, ""); }
    virtual void setParamDescriptions(const QMap<QString,QString>& paramInfo);

tstellanova's avatar
tstellanova committed
31 32 33 34 35
    //TODO make this method protected?
     /** @brief Ensure that the data model is aware of this component
      * @param compId Id of the component
      */
    virtual void addComponent(int compId);
36

37 38 39 40 41 42
    /**
     * @brief Return a list of all components for this parameter name
     * @param parameter The parameter string to search for
     * @return A list with all components, can be potentially empty
     */
    virtual QList<int> getComponentForOnboardParam(const QString& parameter) const;
43 44

    /** @brief Save the onboard parameter with a the type specified in the QVariant as fixed */
45
    virtual void setOnboardParamWithType(int componentId, const QString &key, const QVariant& value);
46 47

    /** @brief clears every parameter for every loaded component */
48
    virtual void forgetAllOnboardParams();
49 50


51

52
    /** @brief add this parameter to pending list iff it has changed from onboard value
53
     * @return true if the parameter is now pending
54
    */
55 56
    virtual bool updatePendingParamWithValue(int componentId, const QString &key,  const QVariant &value);
    virtual void handleParamUpdate(int componentId, const QString& key, const QVariant& value);
57
    virtual bool getOnboardParamValue(int componentId, const QString& key, QVariant& value) const;
58

59 60
    virtual bool isParamChangePending(int componentId,const QString& key);

61
    QMap<QString , QVariant>* getPendingParamsForComponent(int componentId) {
62 63 64
        return pendingParameters.value(componentId);
    }

65
    QMap<QString , QVariant>* getOnboardParamsForComponent(int componentId) {
66 67
        return onboardParameters.value(componentId);
    }
68

69
    QMap<int, QMap<QString, QVariant>* >*  getAllPendingParams() {
70
       return &pendingParameters;
71 72
   }

73
    QMap<int, QMap<QString, QVariant>* >* getAllOnboardParams() {
74
       return &onboardParameters;
75 76
   }

77
    /** @brief return a count of all pending parameters */
78
    virtual int countPendingParams();
79

80 81
    /** @brief return a count of all onboard parameters we've received */
    virtual int countOnboardParams();
82

83 84
    virtual void writeOnboardParamsToStream(QTextStream &stream, const QString& uasName);
    virtual void readUpdateParamsFromStream(QTextStream &stream);
85 86

    virtual void loadParamMetaInfoFromStream(QTextStream& stream);
87

88 89
    void setUASID(int anId) {  this->uasId = anId; }

90
protected:
91
    /** @brief set the confirmed value of a parameter in the onboard params list */
92
    virtual void setOnboardParam(int componentId, const QString& key, const QVariant& value);
93

94
    /** @brief Write a new pending parameter value that may be eventually sent to the UAS */
95
    virtual void setPendingParam(int componentId,  const QString &key,  const QVariant& value);
96
    /** @brief remove a parameter from the pending list */
97
    virtual void removePendingParam(int compId, const QString &key);
98

99

100 101
signals:
    
tstellanova's avatar
tstellanova committed
102 103
    /** @brief We've received an update of a parameter's value */
    void parameterUpdated(int compId, QString paramName, QVariant value);
tstellanova's avatar
tstellanova committed
104

105 106 107
    /** @brief Notifies listeners that a param was added to or removed from the pending list */
    void pendingParamUpdate(int compId, const QString& paramName, QVariant value, bool isPending);

108 109
    void allPendingParamsCommitted(); ///< All pending params have been committed to the MAV

110 111
public slots:

112
    virtual void clearAllPendingParams();
113 114 115 116 117 118

protected:
    int     uasId; ///< The UAS / MAV to which this data model pertains
    QMap<int, QMap<QString, QVariant>* > pendingParameters; ///< Changed values that have not yet been transmitted to the UAS, by component ID
    QMap<int, QMap<QString, QVariant>* > onboardParameters; ///< All parameters confirmed to be stored onboard the UAS, by component ID

119 120 121 122 123 124 125 126
    // Tooltip data structures
    QMap<QString, QString> paramDescriptions; ///< Tooltip values

    // Min / Default / Max data structures
    QMap<QString, double> paramMin; ///< Minimum param values
    QMap<QString, double> paramDefault; ///< Default param values
    QMap<QString, double> paramMax; ///< Minimum param values

127 128 129 130
    
};

#endif // UASPARAMETERDATAMODEL_H