WimaGlobalMeasurementPolygon.h 2.9 KB
Newer Older
1
#pragma once
2 3 4 5

#include <QObject>
#include "WimaPolygon.h"
#include "QGCMapPolyline.h"
6
#include "QGCMapPolygon.h"
7 8
#include "WimaVehicleMeasurementPolygon.h"

9 10
#include "QScopedPointer"

11 12 13 14 15
class WimaGlobalMeasurementPolygon : public WimaPolygon
{
    Q_OBJECT
public:
    WimaGlobalMeasurementPolygon(QObject* parent);
16
    WimaGlobalMeasurementPolygon(QGCMapPolygon* other, QObject* parent);
17 18 19 20

    Q_PROPERTY(double                   bottomLayerAltitude         READ bottomLayerAltitude        WRITE setBottomLayerAltitude        NOTIFY bottomLayerAltitudeChanged)
    Q_PROPERTY(int                      numberOfLayers              READ numberOfLayers             WRITE setNumberOfLayers             NOTIFY numberOfLayersChanged)
    Q_PROPERTY(double                   layerDistance               READ layerDistance              WRITE setLayerDistance              NOTIFY layerDistanceChanged)
21
    Q_PROPERTY(QmlObjectListModel*      vehicleList                 READ vehicleList                                                    NOTIFY vehicleListChanged)
22 23 24 25
    Q_PROPERTY(QGCMapPolyline*          entryPolyline               READ entryPolyline                                                  NOTIFY entryPolylineChanged)

    Q_INVOKABLE void addVehicle(Vehicle *vehicle);
    Q_INVOKABLE void removeVehicle(int vehicleIndex);
26
    Q_INVOKABLE void recalculatesubPolygons();
27 28 29 30
    Q_INVOKABLE void removeAllVehicles();


    // Overrides from WimaPolygon
31
    QString         mapVisualQML    (void) const { return "WimaGlobalMeasurementPolygonMapVisual.qml";}
32 33 34
    QString         editorQML       (void) const { return "WimaGlobalMeasurementPolygonEditor.qml";}

    // Property accessors
35 36 37
    double                                      bottomLayerAltitude     (void) const { return _bottomLayerAltitude;}
    int                                         numberOfLayers          (void) const { return _numberOfLayers;}
    double                                      layerDistance           (void) const { return _layerDistance;}
38
    QmlObjectListModel*                         vehicleList             (void) const { return _vehicleList;}
39
    QGCMapPolyline*                             entryPolyline           (void) const { return _entryPolyline;}
40 41 42

    // Property setters

43 44 45
    void setBottomLayerAltitude     (double altitude);
    void setNumberOfLayers          (int numberOfLayers);
    void setLayerDistance           (double distance);
46 47

signals:
48 49 50 51 52 53
    void bottomLayerAltitudeChanged     (void);
    void numberOfLayersChanged          (void);
    void layerDistanceChanged           (void);
    void vehicleListChanged             (void);
    void entryPolylineChanged           (void);
    void subPolygonsChanged             (void);
54 55 56 57


private:
    double                  _bottomLayerAltitude;
58
    int                     _numberOfLayers;
59
    double                  _layerDistance;
60
    QmlObjectListModel*     _vehicleList;
61 62 63 64
    QGCMapPolyline*         _entryPolyline;

};