WimaAreaData.cc 3 KB
Newer Older
1 2
#include "WimaAreaData.h"

3
WimaAreaData::WimaAreaData(QObject *parent) : QObject(parent) {}
Valentin Platzgummer's avatar
Valentin Platzgummer committed
4

5 6
WimaAreaData::~WimaAreaData() {}

7 8 9 10 11 12 13
bool WimaAreaData::operator==(const WimaAreaData &data) const {
  return this->_path == data._path && this->_center == data._center;
}

bool WimaAreaData::operator!=(const WimaAreaData &data) const {
  return !this->operator==(data);
}
Valentin Platzgummer's avatar
Valentin Platzgummer committed
14

15
QVariantList WimaAreaData::path() const { return _path; }
Valentin Platzgummer's avatar
Valentin Platzgummer committed
16

17
QGeoCoordinate WimaAreaData::center() const { return _center; }
18

19 20
const QList<QGeoCoordinate> &WimaAreaData::coordinateList() const {
  return _list;
21 22
}

23 24 25 26 27 28 29 30 31 32 33
bool WimaAreaData::containsCoordinate(const QGeoCoordinate &coordinate) const {
  using namespace PlanimetryCalculus;
  using namespace PolygonCalculus;
  using namespace GeoUtilities;

  if (_path.size() > 2) {
    QPolygonF polygon;
    toCartesianList(this->coordinateList(), coordinate, polygon);
    return PlanimetryCalculus::contains(polygon, QPointF(0, 0));
  } else
    return false;
34 35
}

36
void WimaAreaData::append(const QGeoCoordinate &c) {
37 38
  _list.append(c);
  _path.push_back(QVariant::fromValue(c));
39 40
}

41
void WimaAreaData::push_back(const QGeoCoordinate &c) { append(c); }
42

43
void WimaAreaData::clear() {
44 45
  _list.clear();
  _path.clear();
46 47
}

48 49 50 51 52 53
void WimaAreaData::setPath(const QVariantList &coordinateList) {
  _path = coordinateList;
  _list.clear();
  for (auto variant : coordinateList) {
    _list.push_back(variant.value<QGeoCoordinate>());
  }
54 55
}

56 57 58
void WimaAreaData::setCenter(const QGeoCoordinate &center) {
  if (_center != center) {
    _center = center;
59

60 61
    emit centerChanged();
  }
62 63
}

64 65 66 67 68
/*!
 * \fn void WimaAreaData::assign(const WimaAreaData &other)
 *
 * Assigns \a other to the invoking object
 */
69 70 71
void WimaAreaData::assign(const WimaAreaData &other) {
  setPath(other.path());
  setCenter(other.center());
72
}
73

74 75 76
void WimaAreaData::assign(const WimaArea &other) {
  setPath(other.path());
  setCenter(other.center());
77 78
}

Valentin Platzgummer's avatar
Valentin Platzgummer committed
79 80 81
/*!
 * \fn void WimaAreaData::setPath(const QList<QGeoCoordinate> &coordinateList)
 *
82 83
 * Sets the path member to \a coordinateList by copying all entries of \a
 * coordinateList. Emits the \c pathChanged() signal.
Valentin Platzgummer's avatar
Valentin Platzgummer committed
84
 */
85 86
void WimaAreaData::setPath(const QList<QGeoCoordinate> &coordinateList) {
  _list = coordinateList;
Valentin Platzgummer's avatar
Valentin Platzgummer committed
87

88 89 90 91 92
  _path.clear();
  // copy all coordinates to _path
  for (int i = 0; i < coordinateList.size(); i++) {
    _path.append(QVariant::fromValue(coordinateList.value(i)));
  }
Valentin Platzgummer's avatar
Valentin Platzgummer committed
93

94
  emit pathChanged(_path);
Valentin Platzgummer's avatar
Valentin Platzgummer committed
95 96
}

97 98 99 100 101 102 103
bool operator==(const WimaAreaData &m1, const WimaArea &m2) {
  return m1.path() == m2.path() && m1.center() == m2.center();
}
bool operator!=(const WimaAreaData &m1, const WimaArea &m2) {
  return !operator==(m1, m2);
}

Valentin Platzgummer's avatar
Valentin Platzgummer committed
104 105 106
/*!
 * \class WimaArea::WimaAreaData
 * \brief Class to store and exchange data of a \c WimaArea Object.
107 108 109 110
 * Class to store and exchange data of a \c WimaArea Object. In contrast to \c
 * WimaArea this class does not uses the QGC Fact System. It is designed to
 * exchange data between the \c WimaPlaner and the \c WimaController class. And
 * it is the base class for any derived data objects
Valentin Platzgummer's avatar
Valentin Platzgummer committed
111 112 113
 *
 * \sa WimaArea
 */