CircularSurvey.h 4.34 KB
Newer Older
1 2 3 4 5 6 7 8
#pragma once

#include <QFutureWatcher>
#include <QVector>

#include "SettingsFact.h"
#include "TransectStyleComplexItem.h"

9
class RoutingThread;
10
class RoutingData;
11

12 13 14
class CircularSurvey : public TransectStyleComplexItem {
  Q_OBJECT
public:
15
  using PtrRoutingData = QSharedPointer<RoutingData>;
16 17 18 19 20
  enum class Type {
    Circular = 0,
    Linear = 1,
    Count = 2 // Must me last, onyl for counting
  };
21

22 23 24 25 26 27 28
  /// @param vehicle Vehicle which this is being contructed for
  /// @param flyView true: Created for use in the Fly View, false: Created for
  /// use in the Plan View
  /// @param kmlOrShpFile Polygon comes from this file, empty for default
  /// polygon
  CircularSurvey(Vehicle *vehicle, bool flyView, const QString &kmlOrShpFile,
                 QObject *parent);
29
  ~CircularSurvey();
30 31 32

  Q_PROPERTY(QGeoCoordinate refPoint READ refPoint WRITE setRefPoint NOTIFY
                 refPointChanged)
33 34 35 36 37
  Q_PROPERTY(Fact *transectDistance READ transectDistance CONSTANT)
  Q_PROPERTY(Fact *alpha READ alpha CONSTANT)
  Q_PROPERTY(Fact *minLength READ minLength CONSTANT)
  Q_PROPERTY(Fact *type READ type CONSTANT)
  Q_PROPERTY(int typeCount READ typeCount CONSTANT)
38
  Q_PROPERTY(bool calculating READ calculating NOTIFY calculatingChanged)
39
  Q_PROPERTY(bool hidePolygon READ hidePolygon NOTIFY hidePolygonChanged)
40 41

  Q_INVOKABLE void resetReference(void);
42
  Q_INVOKABLE void reverse(void);
43 44 45

  // Property setters
  void setRefPoint(const QGeoCoordinate &refPt);
46 47 48
  void setHidePolygon(bool hide);
  void setDepot(const QGeoCoordinate &depot);
  void setSafeArea(const QList<QGeoCoordinate> &safeArea);
49 50 51

  // Property getters
  QGeoCoordinate refPoint() const;
52 53 54 55 56
  Fact *transectDistance();
  Fact *alpha();
  Fact *minLength();
  Fact *type();
  int typeCount() const;
57 58 59 60
  bool calculating() const;
  bool hidePolygon() const;
  QGeoCoordinate depot() const;
  QList<QGeoCoordinate> safeArea() const;
61
  const QList<QList<QGeoCoordinate>> &rawTransects() const;
62

63
  // Overrides
64
  bool load(const QJsonObject &complexObject, int sequenceNumber,
65 66 67 68
            QString &errorString) override final;
  QString mapVisualQML(void) const override final;
  void save(QJsonArray &planItems) override final;
  bool specifiesCoordinate(void) const override final;
69
  void appendMissionItems(QList<MissionItem *> &items,
70 71 72 73 74 75 76 77
                          QObject *missionItemParent) override final;
  void applyNewAltitude(double newAltitude) override final;
  double timeBetweenShots(void) override final;
  QString commandDescription(void) const override final;
  QString commandName(void) const override final;
  QString abbreviation(void) const override final;
  bool readyForSave(void) const override final;
  double additionalTimeDelay(void) const override final;
78 79

  static const char *settingsGroup;
80 81 82 83
  static const char *transectDistanceName;
  static const char *alphaName;
  static const char *minLengthName;
  static const char *typeName;
84 85 86 87 88 89 90 91
  static const char *CircularSurveyName;
  static const char *refPointLongitudeName;
  static const char *refPointLatitudeName;
  static const char *refPointAltitudeName;

signals:
  void refPointChanged();
  void calculatingChanged();
92 93 94
  void hidePolygonChanged();
  void depotChanged();
  void safeAreaChanged();
95 96 97 98 99 100

private slots:
  // Overrides from TransectStyleComplexItem
  void _rebuildTransectsPhase1(void) final;
  void _recalcComplexDistance(void) final;
  void _recalcCameraShots(void) final;
101
  void _setTransects(PtrRoutingData pRoute);
102 103 104 105 106 107 108 109 110 111 112

private:
  void _appendLoadedMissionItems(QList<MissionItem *> &items,
                                 QObject *missionItemParent);
  void _buildAndAppendMissionItems(QList<MissionItem *> &items,
                                   QObject *missionItemParent);

  // center of the circular lanes, e.g. base station
  QGeoCoordinate _referencePoint;
  QMap<QString, FactMetaData *> _metaDataMap;
  // distance between two neighbour circles
113
  SettingsFact _transectDistance;
114
  // angle discretisation of the circles
115
  SettingsFact _alpha;
116 117 118
  // minimal transect lenght, transects are rejected if they are shorter than
  // this value
  SettingsFact _minLength;
119
  SettingsFact _type;
120

121
  // Worker
122
  using PtrWorker = std::shared_ptr<RoutingThread>;
123
  PtrWorker _pWorker;
124 125
  PtrRoutingData _workerOutput;
  QList<QList<QGeoCoordinate>> _rawTransects;
126 127
  bool _needsStoring;
  bool _needsReversal;
128 129 130 131
  bool _hidePolygon;

  QGeoCoordinate _depot;
  QList<QGeoCoordinate> _safeArea;
132
};