AirMapWeatherInformation.cc 2.77 KB
Newer Older
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 "AirMapWeatherInformation.h"
Gus Grubba's avatar
Gus Grubba committed
11
#include "AirMapManager.h"
12

13 14 15
#define WEATHER_UPDATE_DISTANCE 50000                   //-- 50km threshold for weather updates
#define WEATHER_UPDATE_TIME     30 * 60 * 60 * 1000     //-- 30 minutes threshold for weather updates

Gus Grubba's avatar
Gus Grubba committed
16 17
using namespace airmap;

18
AirMapWeatherInformation::AirMapWeatherInformation(AirMapSharedState& shared, QObject *parent)
Gus Grubba's avatar
Gus Grubba committed
19
    : AirspaceWeatherInfoProvider(parent)
20
    , _valid(false)
Gus Grubba's avatar
Gus Grubba committed
21
    , _shared(shared)
22 23 24 25
{
}

void
Gus Grubba's avatar
Gus Grubba committed
26
AirMapWeatherInformation::setROI(const QGeoCoordinate& center)
27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
{
    //-- If first time or we've moved more than WEATHER_UPDATE_DISTANCE, ask for weather updates.
    if(!_lastRoiCenter.isValid() || _lastRoiCenter.distanceTo(center) > WEATHER_UPDATE_DISTANCE) {
        _lastRoiCenter = center;
        _requestWeatherUpdate(center);
        _weatherTime.start();
    } else {
        //-- Check weather once every WEATHER_UPDATE_TIME
        if(_weatherTime.elapsed() > WEATHER_UPDATE_TIME) {
            _requestWeatherUpdate(center);
            _weatherTime.start();
        }
    }
}

void
AirMapWeatherInformation::_requestWeatherUpdate(const QGeoCoordinate& coordinate)
{
45
    qCDebug(AirMapManagerLog) << "Request Weather";
46 47 48 49 50 51 52
    if (!_shared.client()) {
        qCDebug(AirMapManagerLog) << "No AirMap client instance. Not updating Weather information";
        _valid = false;
        emit weatherChanged();
        return;
    }
    Status::GetStatus::Parameters params;
Gus Grubba's avatar
Gus Grubba committed
53 54 55
    params.longitude= coordinate.longitude();
    params.latitude = coordinate.latitude();
    params.weather  = true;
56 57 58
    _shared.client()->status().get_status_by_point(params, [this, coordinate](const Status::GetStatus::Result& result) {
        if (result) {
            const Status::Weather& weather = result.value().weather;
Gus Grubba's avatar
Gus Grubba committed
59
            _valid  = true;
Gus Grubba's avatar
Gus Grubba committed
60 61 62 63 64
            if(weather.icon.empty()) {
                _icon = QStringLiteral("qrc:/airmapweather/unknown.svg");
            } else {
                _icon = QStringLiteral("qrc:/airmapweather/") + QString::fromStdString(weather.icon) + QStringLiteral(".svg");
            }
65
            qCDebug(AirMapManagerLog) << "Weather Info: " << _valid << "Icon:" << QString::fromStdString(weather.icon) << "Condition:" << QString::fromStdString(weather.condition) << "Temp:" << weather.temperature;
66
        } else {
Gus Grubba's avatar
Gus Grubba committed
67
            _valid  = false;
68
            qCDebug(AirMapManagerLog) << "Request Weather Failed";
69 70 71 72
        }
        emit weatherChanged();
    });
}