ComplexMissionItem.h 1.8 KB
Newer Older
1 2 3 4 5 6 7 8
/****************************************************************************
 *
 *   (c) 2009-2016 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
 *
 * QGroundControl is licensed according to the terms in the file
 * COPYING.md in the root of the source code directory.
 *
 ****************************************************************************/
9

10 11 12
#ifndef ComplexMissionItem_H
#define ComplexMissionItem_H

13
#include "VisualMissionItem.h"
14

15
class ComplexMissionItem : public VisualMissionItem
16 17
{
    Q_OBJECT
18

19 20 21
public:
    ComplexMissionItem(Vehicle* vehicle, QObject* parent = NULL);

22 23
    const ComplexMissionItem& operator=(const ComplexMissionItem& other);

24
    Q_PROPERTY(double   complexDistance     READ complexDistance    NOTIFY complexDistanceChanged)
25

26 27
    /// @return The distance covered the complex mission item in meters.
    virtual double complexDistance(void) const = 0;
28

29 30
    /// Load the complex mission item from Json
    ///     @param complexObject Complex mission item json object
Don Gagne's avatar
Don Gagne committed
31
    ///     @param sequenceNumber Sequence number for first MISSION_ITEM in survey
32 33
    ///     @param[out] errorString Error if load fails
    /// @return true: load success, false: load failed, errorString set
Don Gagne's avatar
Don Gagne committed
34
    virtual bool load(const QJsonObject& complexObject, int sequenceNumber, QString& errorString) = 0;
35

36 37 38
    /// Get the point of complex mission item furthest away from a coordinate
    ///     @param other QGeoCoordinate to which distance is calculated
    /// @return the greatest distance from any point of the complex item to some coordinate
39
    virtual double greatestDistanceTo(const QGeoCoordinate &other) const = 0;
40

Don Gagne's avatar
Don Gagne committed
41 42 43
    /// This mission item attribute specifies the type of the complex item.
    static const char* jsonComplexItemTypeKey;

44
signals:
45
    void complexDistanceChanged(double complexDistance);
46 47 48
};

#endif