Skip to content
Terrain.h 2.03 KiB
Newer Older
/****************************************************************************
 *
 *   (c) 2017 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.
 *
 ****************************************************************************/

#pragma once

Andreas Bircher's avatar
Andreas Bircher committed
#include "TerrainTile.h"
#include "QGCLoggingCategory.h"

#include <QObject>
#include <QGeoCoordinate>
#include <QNetworkAccessManager>
Andreas Bircher's avatar
Andreas Bircher committed
#include <QHash>
#include <QMutex>
Andreas Bircher's avatar
Andreas Bircher committed

/* usage example:
    ElevationProvider *p = new ElevationProvider();
    QList<QGeoCoordinate> coordinates;
    QGeoCoordinate c(47.379243, 8.548265);
    coordinates.push_back(c);
    c.setLatitude(c.latitude()+0.01);
    coordinates.push_back(c);
    p->queryTerrainData(coordinates);
 */

Andreas Bircher's avatar
Andreas Bircher committed
Q_DECLARE_LOGGING_CATEGORY(TerrainLog)

class ElevationProvider : public QObject
{
    Q_OBJECT
public:
    ElevationProvider(QObject* parent = NULL);

    /**
     * Async elevation query for a list of lon,lat coordinates. When the query is done, the terrainData() signal
     * is emitted.
     * @param coordinates
     * @return true on success
     */
    bool queryTerrainData(const QList<QGeoCoordinate>& coordinates);

Andreas Bircher's avatar
Andreas Bircher committed
    /**
Andreas Bircher's avatar
Andreas Bircher committed
     * Cache all data in rectangular region given by south west and north east corner.
Andreas Bircher's avatar
Andreas Bircher committed
     *
Andreas Bircher's avatar
Andreas Bircher committed
     * @param southWest
     * @param northEast
Andreas Bircher's avatar
Andreas Bircher committed
     */
Andreas Bircher's avatar
Andreas Bircher committed
    bool cacheTerrainTiles(const QList<QGeoCoordinate>& coordinates);
Andreas Bircher's avatar
Andreas Bircher committed

signals:
    void terrainData(bool success, QList<float> altitudes);

private slots:
    void _requestFinished();
Andreas Bircher's avatar
Andreas Bircher committed
    void _requestFinishedTile();

Andreas Bircher's avatar
Andreas Bircher committed
    QString _uniqueTileId(const QGeoCoordinate& coordinate);
    void    _downloadTiles(void);

    enum class State {
        Idle,
        Downloading,
    };

Andreas Bircher's avatar
Andreas Bircher committed
    State                       _state = State::Idle;
    QNetworkAccessManager       _networkManager;

    static QMutex                       _tilesMutex;
    static QHash<QString, TerrainTile>  _tiles;
Andreas Bircher's avatar
Andreas Bircher committed
    static QStringList                  _downloadQueue;