ComplexMissionItem.h 2.17 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 25
    Q_PROPERTY(int      lastSequenceNumber  READ lastSequenceNumber NOTIFY lastSequenceNumberChanged)
    Q_PROPERTY(double   complexDistance     READ complexDistance    NOTIFY complexDistanceChanged)
26

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

30
    /// @return The last sequence number used by this item. Takes into account child items of the complex item
31
    virtual int lastSequenceNumber(void) const = 0;
32

33 34
    /// Returns the mission items associated with the complex item. Caller is responsible for freeing. Calling
    /// delete on returned QmlObjectListModel will free all memory including internal items.
35
    virtual QmlObjectListModel* getMissionItems(void) const = 0;
36

37 38 39 40
    /// Load the complex mission item from Json
    ///     @param complexObject Complex mission item json object
    ///     @param[out] errorString Error if load fails
    /// @return true: load success, false: load failed, errorString set
41
    virtual bool load(const QJsonObject& complexObject, QString& errorString) = 0;
42

43 44 45
    /// 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
46
    virtual double greatestDistanceTo(const QGeoCoordinate &other) const = 0;
47 48

signals:
49 50
    void lastSequenceNumberChanged  (int lastSequenceNumber);
    void complexDistanceChanged     (double complexDistance);
51 52 53
};

#endif