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

3 4
WimaAreaData::WimaAreaData(QObject *parent)
    : QObject(parent)
Valentin Platzgummer's avatar
Valentin Platzgummer committed
5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
{
    _maxAltitude = 0;
}

/*!
 * \fn double WimaAreaData::maxAltitude()
 *
 * Returns the maximum altitude at which vehicles are allowed to fly.
 */
double WimaAreaData::maxAltitude() const
{
    return _maxAltitude;
}

/*!
 * \fn double WimaAreaData::maxAltitude()
 *
 * Returns the path (vertex list defining the \l {Simple Polygon}).
 */
24
QVariantList WimaAreaData::path() const
Valentin Platzgummer's avatar
Valentin Platzgummer committed
25 26 27 28
{
    return _path;
}

29 30 31 32 33
QGeoCoordinate WimaAreaData::center() const
{
    return _center;
}

34 35 36 37 38 39 40 41 42 43
QList<QGeoCoordinate> WimaAreaData::coordinateList() const
{
    QList<QGeoCoordinate> coordinateList;

    for ( auto coorinate : _path)
        coordinateList.append(coorinate.value<QGeoCoordinate>());

    return coordinateList;
}

Valentin Platzgummer's avatar
Valentin Platzgummer committed
44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
/*!
 * \fn void WimaAreaData::setMaxAltitude(double maxAltitude)
 *
 * Sets the maximum altitude member to \a maxAltitude and emits the \c maxAltitudeChanged() signal if
 * \a maxAltitude differs from the members value.
 */
void WimaAreaData::setMaxAltitude(double maxAltitude)
{
    if ( !qFuzzyCompare(_maxAltitude, maxAltitude) ) {
        _maxAltitude = maxAltitude;

        emit maxAltitudeChanged(_maxAltitude);
    }
}

59 60 61 62 63 64
void WimaAreaData::setPath(const QVariantList &coordinateList)
{
    _path.clear();
    _path.append(coordinateList);
}

65 66 67 68 69 70 71 72 73
void WimaAreaData::setCenter(const QGeoCoordinate &center)
{
    if (_center != center) {
        _center = center;

        emit centerChanged();
    }
}

74 75 76 77 78
/*!
 * \fn void WimaAreaData::assign(const WimaAreaData &other)
 *
 * Assigns \a other to the invoking object
 */
79 80
void WimaAreaData::assign(const WimaAreaData &other)
{
81 82
    setMaxAltitude(other.maxAltitude());
    setPath(other.path());
83
    setCenter(other.center());
84
}
85

86 87 88
void WimaAreaData::assign(const WimaArea &other)
{
    setMaxAltitude(other.maxAltitude());
89 90
    setPath(other.path());    
    setCenter(other.center());
91 92
}

93

Valentin Platzgummer's avatar
Valentin Platzgummer committed
94 95 96 97 98 99 100 101 102 103 104 105
/*!
 * \fn void WimaAreaData::setPath(const QList<QGeoCoordinate> &coordinateList)
 *
 * Sets the path member to \a coordinateList by copying all entries of \a coordinateList.
 * Emits the \c pathChanged() signal.
 */
void WimaAreaData::setPath(const QList<QGeoCoordinate> &coordinateList)
{
    _path.clear();

    // copy all coordinates to _path
    for(int i = 0; i < coordinateList.size(); i++) {
106
        _path.append(QVariant::fromValue(coordinateList.value(i)));
Valentin Platzgummer's avatar
Valentin Platzgummer committed
107 108 109 110 111 112 113 114 115
    }

    emit pathChanged(_path);
}

/*!
 * \class WimaArea::WimaAreaData
 * \brief Class to store and exchange data of a \c WimaArea Object.
 * Class to store and exchange data of a \c WimaArea Object. In contrast to \c WimaArea this class
116 117
 * 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
118 119 120
 *
 * \sa WimaArea
 */