AirMapAdvisoryManager.cc 4.06 KB
Newer Older
Gus Grubba's avatar
Gus Grubba committed
1 2 3 4 5 6 7 8 9
/****************************************************************************
 *
 *   (c) 2009-2016 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
 *
 * QGroundControl is licensed according to the terms in the file
 * COPYING.md in the root of the source code directory.
 *
 ****************************************************************************/

Gus Grubba's avatar
Gus Grubba committed
10
#include "AirMapAdvisoryManager.h"
Gus Grubba's avatar
Gus Grubba committed
11 12 13 14 15 16
#include "AirMapManager.h"

#define ADVISORY_UPDATE_DISTANCE    500     //-- 500m threshold for updates

using namespace airmap;

Gus Grubba's avatar
Gus Grubba committed
17 18 19 20 21 22 23 24
//-----------------------------------------------------------------------------
AirMapAdvisory::AirMapAdvisory(QObject* parent)
    : AirspaceAdvisory(parent)
    , _radius(0.0)
{
}

//-----------------------------------------------------------------------------
Gus Grubba's avatar
Gus Grubba committed
25
AirMapAdvisoryManager::AirMapAdvisoryManager(AirMapSharedState& shared, QObject *parent)
Gus Grubba's avatar
Gus Grubba committed
26 27 28 29 30 31
    : AirspaceAdvisoryProvider(parent)
    , _valid(false)
    , _shared(shared)
{
}

Gus Grubba's avatar
Gus Grubba committed
32
//-----------------------------------------------------------------------------
Gus Grubba's avatar
Gus Grubba committed
33
void
Gus Grubba's avatar
Gus Grubba committed
34
AirMapAdvisoryManager::setROI(const QGeoCoordinate& center, double radiusMeters)
Gus Grubba's avatar
Gus Grubba committed
35 36 37 38 39 40 41 42
{
    //-- If first time or we've moved more than ADVISORY_UPDATE_DISTANCE, ask for updates.
    if(!_lastRoiCenter.isValid() || _lastRoiCenter.distanceTo(center) > ADVISORY_UPDATE_DISTANCE) {
        _lastRoiCenter = center;
        _requestAdvisories(center, radiusMeters);
    }
}

Gus Grubba's avatar
Gus Grubba committed
43 44 45 46 47 48 49 50 51 52 53
//-----------------------------------------------------------------------------
static bool
adv_sort(QObject* a, QObject* b)
{
    AirMapAdvisory* aa = qobject_cast<AirMapAdvisory*>(a);
    AirMapAdvisory* bb = qobject_cast<AirMapAdvisory*>(b);
    if(!aa || !bb) return false;
    return aa->color() > bb->color();
}

//-----------------------------------------------------------------------------
Gus Grubba's avatar
Gus Grubba committed
54
void
Gus Grubba's avatar
Gus Grubba committed
55
AirMapAdvisoryManager::_requestAdvisories(const QGeoCoordinate& coordinate, double radiusMeters)
Gus Grubba's avatar
Gus Grubba committed
56 57 58 59 60 61 62 63 64
{
    qCDebug(AirMapManagerLog) << "Advisories Request";
    if (!_shared.client()) {
        qCDebug(AirMapManagerLog) << "No AirMap client instance. Not updating Advisories";
        _valid = false;
        emit advisoryChanged();
        return;
    }
    _valid = false;
Gus Grubba's avatar
Gus Grubba committed
65
    _airspaces.clearAndDeleteContents();
Gus Grubba's avatar
Gus Grubba committed
66 67 68 69 70 71 72
    Status::GetStatus::Parameters params;
    params.longitude = coordinate.longitude();
    params.latitude  = coordinate.latitude();
    params.weather   = false;
    params.buffer    = radiusMeters;
    _shared.client()->status().get_status_by_point(params, [this, coordinate](const Status::GetStatus::Result& result) {
        if (result) {
Gus Grubba's avatar
Gus Grubba committed
73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
            qCDebug(AirMapManagerLog) << "Successful advisory search. Items:" << result.value().advisories.size();
            _airspaceColor = (AirspaceAdvisoryProvider::AdvisoryColor)(int)result.value().advisory_color;
            const std::vector<Status::Advisory> advisories = result.value().advisories;
            for (const auto& advisory : advisories) {
                AirMapAdvisory* pAdvisory = new AirMapAdvisory(this);
                pAdvisory->_id          = QString::fromStdString(advisory.airspace.id());
                pAdvisory->_name        = QString::fromStdString(advisory.airspace.name());
                pAdvisory->_type        = (AirspaceAdvisory::AdvisoryType)(int)advisory.airspace.type();
                pAdvisory->_color       = (AirspaceAdvisoryProvider::AdvisoryColor)(int)advisory.color;
                //-- TODO: Add airspace center coordinates and radius (easy to get from Json but
                //   I have no idea how to get it from airmap::Airspace.)
                // pAdvisory->_coordinates = QGeoCoordinate( something );
                // pAdvisory->_radius = something ;
                _airspaces.append(pAdvisory);
                qCDebug(AirMapManagerLog) << "Adding advisory" << pAdvisory->name();
Gus Grubba's avatar
Gus Grubba committed
88
            }
Gus Grubba's avatar
Gus Grubba committed
89 90 91
            //-- Sort in order of color (priority)
            std::sort(_airspaces.objectList()->begin(), _airspaces.objectList()->end(), adv_sort);
            _valid = true;
Gus Grubba's avatar
Gus Grubba committed
92 93 94 95 96 97
        } else {
            qCDebug(AirMapManagerLog) << "Advisories Request Failed";
        }
        emit advisoryChanged();
    });
}