WimaPlaner.h 5.83 KB
Newer Older
1
#pragma once
2

3
#include "QmlObjectListModel.h"
4
#include <QObject>
5
#include <QSharedPointer>
6

7 8 9 10
#include "Geometry/WimaCorridor.h"
#include "Geometry/WimaCorridorData.h"
#include "Geometry/WimaJoinedArea.h"
#include "Geometry/WimaJoinedAreaData.h"
11 12 13 14
#include "Geometry/WimaMeasurementArea.h"
#include "Geometry/WimaMeasurementAreaData.h"
#include "Geometry/WimaServiceArea.h"
#include "Geometry/WimaServiceAreaData.h"
15
#include "WimaPlanData.h"
16

17 18
#include "Snake/NemoInterface.h"

19
#include "JsonHelper.h"
20

21 22 23
class MissionController;
class PlanMasterController;
class WimaBridge;
24

25 26
class WimaPlaner : public QObject {
  Q_OBJECT
27

28
  enum FileType { WimaFile, PlanFile };
29

30
public:
31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
  WimaPlaner(QObject *parent = nullptr);
  template <class T> WimaPlaner(T t, QObject *parent = nullptr) = delete;
  template <class T> WimaPlaner(T t) = delete;

  Q_PROPERTY(PlanMasterController *masterController READ masterController WRITE
                 setMasterController NOTIFY masterControllerChanged)
  Q_PROPERTY(MissionController *missionController READ missionController WRITE
                 setMissionController NOTIFY missionControllerChanged)
  Q_PROPERTY(QmlObjectListModel *visualItems READ visualItems NOTIFY
                 visualItemsChanged)
  Q_PROPERTY(int currentPolygonIndex READ currentPolygonIndex WRITE
                 setCurrentPolygonIndex NOTIFY currentPolygonIndexChanged)
  Q_PROPERTY(QString currentFile READ currentFile NOTIFY currentFileChanged)
  Q_PROPERTY(QStringList loadNameFilters READ loadNameFilters CONSTANT)
  Q_PROPERTY(QStringList saveNameFilters READ saveNameFilters CONSTANT)
  Q_PROPERTY(QString fileExtension READ fileExtension CONSTANT)
  Q_PROPERTY(QGeoCoordinate joinedAreaCenter READ joinedAreaCenter CONSTANT)
  Q_PROPERTY(WimaBridge *wimaBridge READ wimaBridge WRITE setWimaBridge NOTIFY
                 wimaBridgeChanged)
50
  Q_PROPERTY(NemoInterface *nemoInterface READ nemoInterface CONSTANT)
51 52
  Q_PROPERTY(bool synchronized READ synchronized NOTIFY synchronizedChanged)
  Q_PROPERTY(bool needsUpdate READ needsUpdate NOTIFY needsUpdateChanged)
53 54

  // Property accessors
55 56
  PlanMasterController *masterController(void);
  MissionController *missionController(void);
57
  QmlObjectListModel *visualItems(void);
58 59
  int currentPolygonIndex(void) const;
  QString currentFile(void) const;
60 61
  QStringList loadNameFilters(void) const;
  QStringList saveNameFilters(void) const;
62
  QString fileExtension(void) const;
63
  QGeoCoordinate joinedAreaCenter(void) const;
64
  WimaBridge *wimaBridge(void);
65
  NemoInterface *nemoInterface(void);
66 67
  bool synchronized();
  bool needsUpdate();
68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87

  // Property setters
  void setMasterController(PlanMasterController *masterController);
  void setMissionController(MissionController *missionController);
  /// Sets the integer index pointing to the current polygon. Current polygon is
  /// set interactive.
  void setCurrentPolygonIndex(int index);
  void setWimaBridge(WimaBridge *bridge);

  Q_INVOKABLE WimaPlaner *thisPointer();
  Q_INVOKABLE bool addMeasurementArea();
  /// Removes an area from _visualItems
  /// @param index Index of the area to be removed
  Q_INVOKABLE void removeArea(int index);
  Q_INVOKABLE bool addServiceArea();
  Q_INVOKABLE bool addCorridor();
  /// Remove all areas from WimaPlaner and all mission items from
  /// MissionController
  Q_INVOKABLE void removeAll();
  /// Recalculates vehicle corridor, flight path, etc.
88
  Q_INVOKABLE bool update();
89
  /// Pushes the generated mission data to the wimaController.
90
  Q_INVOKABLE void synchronize();
91
  Q_INVOKABLE bool readyForSynchronization();
92 93 94 95 96 97 98 99 100 101 102 103
  Q_INVOKABLE void saveToCurrent();
  Q_INVOKABLE void saveToFile(const QString &filename);
  Q_INVOKABLE bool loadFromCurrent();
  Q_INVOKABLE bool loadFromFile(const QString &filename);
  Q_INVOKABLE void resetAllInteractive(void);
  Q_INVOKABLE void setInteractive(void);

  QJsonDocument saveToJson(FileType fileType);
  // static Members
  static const char *wimaFileExtension;
  static const char *areaItemsName;
  static const char *missionItemsName;
104 105

signals:
106 107 108 109 110 111
  void masterControllerChanged(void);
  void missionControllerChanged(void);
  void visualItemsChanged(void);
  void currentPolygonIndexChanged(int index);
  void currentFileChanged();
  void wimaBridgeChanged();
112 113
  void synchronizedChanged(void);
  void needsUpdateChanged(void);
114 115

private slots:
116
  void updatePolygonInteractivity(int index);
Valentin Platzgummer's avatar
Valentin Platzgummer committed
117
#ifndef NDEBUG
118
  void autoLoadMission(void);
Valentin Platzgummer's avatar
Valentin Platzgummer committed
119
#endif
120

121 122
private:
signals:
123 124
  void joinedAreaValidChanged();

125
private:
126
  // Member Functions
127
  QSharedPointer<WimaPlanData> toPlanData();
128 129 130 131
  bool shortestPath(const QGeoCoordinate &start,
                    const QGeoCoordinate &destination,
                    QVector<QGeoCoordinate> &path);
  void setNeedsUpdate(bool needsUpdate);
132 133 134 135 136

  // Member Variables
  PlanMasterController *_masterController;
  MissionController *_missionController;
  int _currentAreaIndex;
137 138 139 140
  QString _currentFile;
  // container for data exchange with WimaController
  WimaBridge *_wimaBridge;

141
  bool _joinedAreaValid;
142
  WimaMeasurementArea _measurementArea;
143
  bool _mAreaChanged;
144
  WimaServiceArea _serviceArea;
145
  bool _sAreaChanged;
146
  WimaCorridor _corridor;
147
  bool _corridorChanged;
148 149 150 151 152 153 154 155
  // contains all visible areas
  QmlObjectListModel _visualItems;
  // joined area fromed by _measurementArea, _serviceArea, _corridor
  WimaJoinedArea _joinedArea;
  // path from takeoff to first measurement point
  unsigned long _arrivalPathLength;
  // path from last measurement point to land
  unsigned long _returnPathLength;
156

157 158
  CircularSurvey *_TSComplexItem;
  bool _surveyChanged;
159
  // sync stuff
160 161 162
  bool _synchronized; // true if planData is synchronized with
                      // wimaController
  bool _needsUpdate;  // gets set by updateMission and calcArrivalAndReturnPath
163

Valentin Platzgummer's avatar
Valentin Platzgummer committed
164
#ifndef NDEBUG
165 166
  QTimer _autoLoadTimer; // timer to auto load mission after some time, prevents
                         // seg. faults
Valentin Platzgummer's avatar
Valentin Platzgummer committed
167
#endif
168 169

  NemoInterface _nemoInterface;
170
};