2017-03-21 09:27:44 +01:00
|
|
|
#ifndef OFFLINEMAP_H
|
|
|
|
#define OFFLINEMAP_H
|
2017-03-18 01:30:31 +01:00
|
|
|
|
|
|
|
#include <QTransform>
|
|
|
|
#include "map.h"
|
2017-03-21 01:15:29 +01:00
|
|
|
#include "tar.h"
|
2017-04-14 22:39:33 +02:00
|
|
|
#include "ozf.h"
|
2017-03-18 01:30:31 +01:00
|
|
|
#include "coordinates.h"
|
2017-04-04 22:03:42 +02:00
|
|
|
#include "projection.h"
|
|
|
|
|
2017-03-18 01:30:31 +01:00
|
|
|
|
|
|
|
class QIODevice;
|
2017-03-21 19:02:29 +01:00
|
|
|
class QImage;
|
2017-03-18 01:30:31 +01:00
|
|
|
|
2017-03-21 09:27:44 +01:00
|
|
|
class OfflineMap : public Map
|
2017-03-18 01:30:31 +01:00
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
2017-04-21 21:15:58 +02:00
|
|
|
OfflineMap(const QString &fileName, QObject *parent = 0);
|
|
|
|
OfflineMap(const QString &fileName, Tar &tar, QObject *parent = 0);
|
2017-03-29 00:17:47 +02:00
|
|
|
~OfflineMap();
|
2017-03-18 01:30:31 +01:00
|
|
|
|
|
|
|
const QString &name() const {return _name;}
|
|
|
|
|
2017-04-09 10:26:09 +02:00
|
|
|
QRectF bounds() const {return QRectF(QPointF(0, 0), _size);}
|
|
|
|
qreal resolution(const QPointF &) const {return _resolution;}
|
2017-03-18 01:30:31 +01:00
|
|
|
|
2017-06-25 16:25:29 +02:00
|
|
|
qreal zoom() const {return 0;}
|
2017-06-29 22:29:27 +02:00
|
|
|
qreal zoomFit(const QSize &, const RectC &) {return 0;}
|
2017-06-26 00:20:42 +02:00
|
|
|
qreal zoomFit(qreal, const Coordinates &) {return 0;}
|
2017-06-25 16:25:29 +02:00
|
|
|
qreal zoomIn() {return 0;}
|
|
|
|
qreal zoomOut() {return 0;}
|
2017-03-18 01:30:31 +01:00
|
|
|
|
2017-04-30 00:19:53 +02:00
|
|
|
QPointF ll2xy(const Coordinates &c)
|
2017-04-04 22:03:42 +02:00
|
|
|
{return _transform.map(_projection->ll2xy(c));}
|
2017-04-30 00:19:53 +02:00
|
|
|
Coordinates xy2ll(const QPointF &p)
|
2017-04-04 22:03:42 +02:00
|
|
|
{return _projection->xy2ll(_inverted.map(p));}
|
2017-03-18 01:30:31 +01:00
|
|
|
|
|
|
|
void draw(QPainter *painter, const QRectF &rect);
|
|
|
|
|
|
|
|
void load();
|
|
|
|
void unload();
|
|
|
|
|
2017-04-21 21:15:58 +02:00
|
|
|
bool isValid() const {return _valid;}
|
|
|
|
const QString &errorString() const {return _errorString;}
|
2017-04-01 05:59:55 +02:00
|
|
|
|
2017-04-04 22:03:42 +02:00
|
|
|
QPointF ll2pp(const Coordinates &c) const
|
|
|
|
{return _projection->ll2xy(c);}
|
|
|
|
QPointF xy2pp(const QPointF &p) const
|
|
|
|
{return _inverted.map(p);}
|
|
|
|
QPointF pp2xy(const QPointF &p) const
|
|
|
|
{return _transform.map(p);}
|
2017-03-18 01:30:31 +01:00
|
|
|
|
|
|
|
private:
|
2017-08-10 08:58:21 +02:00
|
|
|
struct ReferencePoint {
|
2017-04-01 15:58:32 +02:00
|
|
|
QPoint xy;
|
|
|
|
Coordinates ll;
|
|
|
|
QPointF pp;
|
2017-08-10 08:58:21 +02:00
|
|
|
};
|
2017-04-01 15:58:32 +02:00
|
|
|
|
2017-08-10 08:58:21 +02:00
|
|
|
struct ProjectionSetup {
|
2017-04-09 10:26:09 +02:00
|
|
|
double latitudeOrigin;
|
|
|
|
double longitudeOrigin;
|
2017-04-01 15:58:32 +02:00
|
|
|
double scale;
|
|
|
|
double falseEasting;
|
|
|
|
double falseNorthing;
|
2017-04-02 22:17:16 +02:00
|
|
|
double standardParallel1;
|
|
|
|
double standardParallel2;
|
2017-04-01 15:58:32 +02:00
|
|
|
int zone;
|
2017-08-10 08:58:21 +02:00
|
|
|
};
|
2017-03-18 01:30:31 +01:00
|
|
|
|
2017-04-21 21:15:58 +02:00
|
|
|
int parse(QIODevice &device, QList<ReferencePoint> &points,
|
|
|
|
QString &projection, ProjectionSetup &setup, QString &datum);
|
|
|
|
bool parseMapFile(QIODevice &device, QList<ReferencePoint> &points,
|
2017-04-03 20:29:35 +02:00
|
|
|
QString &projection, ProjectionSetup &setup, QString &datum);
|
2017-03-27 10:31:41 +02:00
|
|
|
bool totalSizeSet();
|
2017-04-03 20:29:35 +02:00
|
|
|
bool createProjection(const QString &datum, const QString &projection,
|
2017-04-01 15:58:32 +02:00
|
|
|
const ProjectionSetup &setup, QList<ReferencePoint> &points);
|
2017-03-18 01:30:31 +01:00
|
|
|
bool computeTransformation(const QList<ReferencePoint> &points);
|
|
|
|
bool computeResolution(QList<ReferencePoint> &points);
|
2017-03-21 19:02:29 +01:00
|
|
|
bool getTileInfo(const QStringList &tiles, const QString &path = QString());
|
|
|
|
bool getImageInfo(const QString &path);
|
2017-03-18 01:30:31 +01:00
|
|
|
|
2017-04-15 08:59:31 +02:00
|
|
|
void drawTiled(QPainter *painter, const QRectF &rect);
|
|
|
|
void drawOZF(QPainter *painter, const QRectF &rect);
|
|
|
|
void drawImage(QPainter *painter, const QRectF &rect);
|
|
|
|
|
2017-03-18 01:30:31 +01:00
|
|
|
QString _name;
|
2017-04-21 21:15:58 +02:00
|
|
|
bool _valid;
|
|
|
|
QString _errorString;
|
|
|
|
|
2017-03-18 01:30:31 +01:00
|
|
|
QSize _size;
|
2017-03-29 00:17:47 +02:00
|
|
|
Projection *_projection;
|
2017-04-04 22:03:42 +02:00
|
|
|
QTransform _transform, _inverted;
|
2017-03-18 01:30:31 +01:00
|
|
|
qreal _resolution;
|
|
|
|
|
2017-04-14 22:39:33 +02:00
|
|
|
OZF _ozf;
|
2017-03-21 01:15:29 +01:00
|
|
|
Tar _tar;
|
2017-03-27 02:41:30 +02:00
|
|
|
QString _tarPath;
|
2017-03-18 01:30:31 +01:00
|
|
|
QImage *_img;
|
2017-03-21 09:27:44 +01:00
|
|
|
QString _imgPath;
|
2017-03-20 10:05:07 +01:00
|
|
|
QSize _tileSize;
|
|
|
|
QString _tileName;
|
2017-03-18 01:30:31 +01:00
|
|
|
};
|
|
|
|
|
2017-03-21 09:27:44 +01:00
|
|
|
#endif // OFFLINEMAP_H
|