2018-02-20 23:37:19 +01:00
|
|
|
#ifndef WMTSMAP_H
|
|
|
|
#define WMTSMAP_H
|
|
|
|
|
|
|
|
#include <QTransform>
|
|
|
|
#include "projection.h"
|
|
|
|
#include "map.h"
|
|
|
|
#include "wmts.h"
|
|
|
|
#include "tileloader.h"
|
|
|
|
|
|
|
|
|
|
|
|
class WMTSMap : public Map
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
|
|
|
WMTSMap(const QString &name, const QString &url, const QString &format,
|
2018-02-24 01:59:03 +01:00
|
|
|
const QString &layer, const QString &style, const QString &set,
|
|
|
|
bool invertAxis, QObject *parent = 0);
|
2018-02-20 23:37:19 +01:00
|
|
|
|
|
|
|
const QString &name() const {return _name;}
|
|
|
|
|
|
|
|
QRectF bounds() const;
|
|
|
|
qreal resolution(const QPointF &p) const;
|
|
|
|
|
|
|
|
qreal zoom() const {return _zoom;}
|
|
|
|
qreal zoomFit(const QSize &size, const RectC &br);
|
|
|
|
qreal zoomFit(qreal resolution, const Coordinates &c);
|
|
|
|
qreal zoomIn();
|
|
|
|
qreal zoomOut();
|
|
|
|
|
|
|
|
QPointF ll2xy(const Coordinates &c)
|
|
|
|
{return static_cast<const WMTSMap &>(*this).ll2xy(c);}
|
|
|
|
Coordinates xy2ll(const QPointF &p)
|
|
|
|
{return static_cast<const WMTSMap &>(*this).xy2ll(p);}
|
|
|
|
|
|
|
|
void draw(QPainter *painter, const QRectF &rect);
|
|
|
|
|
|
|
|
void setBlockingMode(bool block) {_block = block;}
|
|
|
|
void clearCache();
|
|
|
|
|
|
|
|
void load();
|
|
|
|
void unload();
|
|
|
|
|
|
|
|
bool isValid() const {return _valid;}
|
|
|
|
QString errorString() const {return _errorString;}
|
|
|
|
|
|
|
|
private slots:
|
|
|
|
void emitLoaded();
|
|
|
|
|
|
|
|
private:
|
|
|
|
qreal sd2res(qreal scaleDenominator) const;
|
|
|
|
void updateTransform();
|
|
|
|
|
|
|
|
QPointF ll2xy(const Coordinates &c) const;
|
|
|
|
Coordinates xy2ll(const QPointF &p) const;
|
|
|
|
|
2018-02-24 01:59:03 +01:00
|
|
|
QString _name, _url, _layer, _set;
|
2018-02-20 23:37:19 +01:00
|
|
|
TileLoader _tileLoader;
|
|
|
|
QList<WMTS::Zoom> _zooms;
|
2018-02-24 01:59:03 +01:00
|
|
|
bool _invertAxis;
|
2018-02-20 23:37:19 +01:00
|
|
|
Projection _projection;
|
|
|
|
QTransform _transform, _inverted;
|
|
|
|
int _zoom;
|
|
|
|
bool _block;
|
|
|
|
|
|
|
|
bool _valid;
|
|
|
|
QString _errorString;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // WMTSMAP_H
|