1
0
mirror of https://github.com/tumic0/GPXSee.git synced 2024-10-06 23:03:22 +02:00
GPXSee/src/map/wmts.h

64 lines
1.6 KiB
C
Raw Normal View History

2018-02-20 23:37:19 +01:00
#ifndef WMTS_H
#define WMTS_H
#include <QSize>
#include <QMap>
2018-02-20 23:37:19 +01:00
#include "projection.h"
class QXmlStreamReader;
class Downloader;
class WMTS
{
public:
struct Zoom {
qreal scaleDenominator;
QPointF topLeft;
QSize tile;
QSize matrix;
QRect limits;
2018-02-20 23:37:19 +01:00
};
bool load(const QString &path, const QString &url, const QString &layer,
const QString &set);
2018-02-20 23:37:19 +01:00
const QString &errorString() const {return _errorString;}
const QList<Zoom> zooms() const {return _zooms.values();}
const Projection &projection() const {return _projection;}
2018-02-20 23:37:19 +01:00
static Downloader *downloader() {return _downloader;}
static void setDownloader(Downloader *downloader)
{_downloader = downloader;}
private:
bool createProjection(const QString &crs);
void tileMatrixLimits(QXmlStreamReader &reader);
2018-02-20 23:37:19 +01:00
void tileMatrix(QXmlStreamReader &reader);
void tileMatrixSetLimits(QXmlStreamReader &reader);
2018-02-20 23:37:19 +01:00
void tileMatrixSet(QXmlStreamReader &reader, const QString &set);
void tileMatrixSetLink(QXmlStreamReader &reader, const QString &set);
void layer(QXmlStreamReader &reader, const QString &layer,
const QString &set);
void contents(QXmlStreamReader &reader, const QString &layer,
const QString &set);
void capabilities(QXmlStreamReader &reader, const QString &layer,
const QString &set);
bool parseCapabilities(const QString &path, const QString &layer,
const QString &set);
2018-02-20 23:37:19 +01:00
bool getCapabilities(const QString &url, const QString &file);
QMap<int, Zoom> _zooms;
2018-02-20 23:37:19 +01:00
Projection _projection;
QString _errorString;
static Downloader *_downloader;
};
#ifndef QT_NO_DEBUG
QDebug operator<<(QDebug dbg, const WMTS::Zoom &zoom);
#endif // QT_NO_DEBUG
2018-02-20 23:37:19 +01:00
#endif // WMTS_H