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

53 lines
1.3 KiB
C
Raw Normal View History

2018-01-08 23:47:45 +01:00
#ifndef MAPFILE_H
#define MAPFILE_H
#include <QTransform>
#include "transform.h"
#include "projection.h"
2018-03-10 09:25:52 +01:00
class QIODevice;
2018-03-21 19:23:17 +01:00
class GCS;
2018-03-10 09:25:52 +01:00
2018-01-08 23:47:45 +01:00
class MapFile
{
public:
2018-03-21 19:09:37 +01:00
MapFile(QIODevice &file);
bool isValid() const {return !_image.isNull() && _projection.isValid();}
const QString &errorString() const {return _errorString;}
2018-01-08 23:47:45 +01:00
const Projection &projection() const {return _projection;}
2018-01-08 23:47:45 +01:00
const QTransform &transform() const {return _transform;}
const QString &name() const {return _name;}
const QString &image() const {return _image;}
const QSize &size() const {return _size;}
private:
struct CalibrationPoint {
ReferencePoint rp;
Coordinates ll;
int zone;
};
int parse(QIODevice &device, QList<CalibrationPoint> &points,
QString &projection, Projection::Setup &setup, QString &datum);
bool parseMapFile(QIODevice &device, QList<CalibrationPoint> &points,
QString &projection, Projection::Setup &setup, QString &datum);
const GCS *createGCS(const QString &datum);
bool createProjection(const GCS *gcs, const QString &projection,
2018-01-08 23:47:45 +01:00
const Projection::Setup &setup, QList<CalibrationPoint> &points);
bool computeTransformation(QList<CalibrationPoint> &points);
QString _name;
QString _image;
QSize _size;
Projection _projection;
QTransform _transform;
2018-01-08 23:47:45 +01:00
QString _errorString;
};
#endif // MAPFILE_H