UASInterface.h 5.41 KB
Newer Older
1 2
/****************************************************************************
 *
Gus Grubba's avatar
Gus Grubba committed
3
 * (c) 2009-2020 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
4 5 6 7 8
 *
 * QGroundControl is licensed according to the terms in the file
 * COPYING.md in the root of the source code directory.
 *
 ****************************************************************************/
pixhawk's avatar
pixhawk committed
9

Donald Gagne's avatar
Donald Gagne committed
10 11 12
// NO NEW CODE HERE
// UASInterface, UAS.h/cc are deprecated. All new functionality should go into Vehicle.h/cc
//
pixhawk's avatar
pixhawk committed
13

14
#pragma once
pixhawk's avatar
pixhawk committed
15 16 17 18 19

#include <QObject>
#include <QList>
#include <QAction>
#include <QColor>
20
#include <QPointer>
pixhawk's avatar
pixhawk committed
21 22 23

#include "LinkInterface.h"

24
#ifndef __mobile__
25
class FileManager;
26
#endif
27

pixhawk's avatar
pixhawk committed
28 29 30 31 32 33
/**
 * @brief Interface for all robots.
 *
 * This interface is abstract and thus cannot be instantiated. It serves only as type definition.
 * It represents an unmanned aerial vehicle, e.g. a micro air vehicle.
 **/
lm's avatar
lm committed
34 35
class UASInterface : public QObject
{
pixhawk's avatar
pixhawk committed
36 37 38 39 40 41
    Q_OBJECT
public:
    virtual ~UASInterface() {}

    /* MANAGEMENT */

42
    virtual int getUASID() const = 0; ///< Get the ID of the connected UAS
pixhawk's avatar
pixhawk committed
43
    /** @brief The time interval the robot is switched on **/
44
    virtual quint64 getUptime() const = 0;
pixhawk's avatar
pixhawk committed
45

46
#ifndef __mobile__
47
    virtual FileManager* getFileManager() = 0;
48
#endif
49

50 51 52 53 54
    enum StartCalibrationType {
        StartCalibrationRadio,
        StartCalibrationGyro,
        StartCalibrationMag,
        StartCalibrationAirspeed,
55
        StartCalibrationAccel,
56
        StartCalibrationLevel,
57
        StartCalibrationPressure,
Don Gagne's avatar
Don Gagne committed
58
        StartCalibrationEsc,
59
        StartCalibrationCopyTrims,
60 61
        StartCalibrationUavcanEsc,
        StartCalibrationCompassMot,
62 63 64
    };

    enum StartBusConfigType {
65 66
        StartBusConfigActuators,
        EndBusConfigActuators,
67
    };
dogmaphobic's avatar
dogmaphobic committed
68

69 70
    /// Starts the specified calibration
    virtual void startCalibration(StartCalibrationType calType) = 0;
dogmaphobic's avatar
dogmaphobic committed
71

72 73
    /// Ends any current calibration
    virtual void stopCalibration(void) = 0;
74

75 76 77 78 79 80
    /// Starts the specified bus configuration
    virtual void startBusConfig(StartBusConfigType calType) = 0;

    /// Ends any current bus configuration
    virtual void stopBusConfig(void) = 0;

pixhawk's avatar
pixhawk committed
81
public slots:
82 83
    /** @brief Order the robot to pair its receiver **/
    virtual void pairRX(int rxType, int rxSubType) = 0;
pixhawk's avatar
pixhawk committed
84 85 86 87 88 89

signals:
    /** @brief The robot is connected **/
    void connected();
    /** @brief The robot is disconnected **/
    void disconnected();
90

pixhawk's avatar
pixhawk committed
91 92 93
    /** @brief A value of the robot has changed.
      *
      * Typically this is used to send lowlevel information like the battery voltage to the plotting facilities of
94
      * the groundstation. The data here should be converted to human-readable values before being passed, so ideally
dogmaphobic's avatar
dogmaphobic committed
95
      * SI units.
pixhawk's avatar
pixhawk committed
96 97 98
      *
      * @param uasId ID of this system
      * @param name name of the value, e.g. "battery voltage"
dogmaphobic's avatar
dogmaphobic committed
99
      * @param unit The units this variable is in as an abbreviation. For system-dependent (such as raw ADC values) use "raw", for bitfields use "bits", for true/false or on/off use "bool", for unitless values use "-".
pixhawk's avatar
pixhawk committed
100 101 102
      * @param value the value that changed
      * @param msec the timestamp of the message, in milliseconds
      */
103
    void valueChanged(const int uasid, const QString& name, const QString& unit, const QVariant &value,const quint64 msecs);
lm's avatar
lm committed
104

105
    void parameterUpdate(int uas, int component, QString parameterName, int parameterCount, int parameterId, int type, QVariant value);
Don Gagne's avatar
Don Gagne committed
106

pixhawk's avatar
pixhawk committed
107 108 109 110 111 112 113 114
    /**
     * @brief The battery status has been updated
     *
     * @param uas sending system
     * @param voltage battery voltage
     * @param percent remaining capacity in percent
     * @param seconds estimated remaining flight time in seconds
     */
dongfang's avatar
dongfang committed
115
    void batteryChanged(UASInterface* uas, double voltage, double current, double percent, int seconds);
pixhawk's avatar
pixhawk committed
116
    void statusChanged(UASInterface* uas, QString status);
117

pixhawk's avatar
pixhawk committed
118 119
    void imageStarted(int imgid, int width, int height, int depth, int channels);
    void imageDataReceived(int imgid, const unsigned char* imageData, int length, int startIndex);
120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137

    /** @brief Optical flow status changed */
    void opticalFlowStatusChanged(bool supported, bool enabled, bool ok);
    /** @brief Vision based localization status changed */
    void visionLocalizationStatusChanged(bool supported, bool enabled, bool ok);
    /** @brief Infrared / Ultrasound status changed */
    void distanceSensorStatusChanged(bool supported, bool enabled, bool ok);
    /** @brief Gyroscope status changed */
    void gyroStatusChanged(bool supported, bool enabled, bool ok);
    /** @brief Accelerometer status changed */
    void accelStatusChanged(bool supported, bool enabled, bool ok);
    /** @brief Magnetometer status changed */
    void magSensorStatusChanged(bool supported, bool enabled, bool ok);
    /** @brief Barometer status changed */
    void baroStatusChanged(bool supported, bool enabled, bool ok);
    /** @brief Differential pressure / airspeed status changed */
    void airspeedStatusChanged(bool supported, bool enabled, bool ok);

138 139 140
    // ERROR AND STATUS SIGNALS
    /** @brief Name of system changed */
    void nameChanged(QString newName);
141 142
    /** @brief Core specifications have changed */
    void systemSpecsChanged(int uasId);
143

dogmaphobic's avatar
dogmaphobic committed
144 145 146
    // Log Download Signals
    void logEntry   (UASInterface* uas, uint32_t time_utc, uint32_t size, uint16_t id, uint16_t num_logs, uint16_t last_log_num);
    void logData    (UASInterface* uas, uint32_t ofs, uint16_t id, uint8_t count, const uint8_t* data);
147

pixhawk's avatar
pixhawk committed
148 149
};

lm's avatar
lm committed
150
Q_DECLARE_INTERFACE(UASInterface, "org.qgroundcontrol/1.0")
151