2016-11-16 23:54:15 +01:00
|
|
|
#ifndef NMEAPARSER_H
|
|
|
|
#define NMEAPARSER_H
|
|
|
|
|
|
|
|
#include <QDate>
|
|
|
|
#include "parser.h"
|
|
|
|
|
|
|
|
|
|
|
|
class NMEAParser : public Parser
|
|
|
|
{
|
|
|
|
public:
|
2017-07-27 19:47:46 +02:00
|
|
|
NMEAParser() : _errorLine(0), _GGA(false) {}
|
2016-11-16 23:54:15 +01:00
|
|
|
|
2019-01-31 01:46:53 +01:00
|
|
|
bool parse(QFile *file, QList<TrackData> &tracks, QList<RouteData> &routes,
|
|
|
|
QList<Area> &polygons, QVector<Waypoint> &waypoints);
|
2016-11-16 23:54:15 +01:00
|
|
|
QString errorString() const {return _errorString;}
|
|
|
|
int errorLine() const {return _errorLine;}
|
|
|
|
|
|
|
|
private:
|
2016-11-22 00:13:41 +01:00
|
|
|
bool readEW(const char *data, int len, qreal &lon);
|
|
|
|
bool readLon(const char *data, int len, qreal &lon);
|
|
|
|
bool readNS(const char *data, int len, qreal &lat);
|
|
|
|
bool readLat(const char *data, int len, qreal &lat);
|
|
|
|
bool readDate(const char *data, int len, QDate &date);
|
|
|
|
bool readTime(const char *data, int len, QTime &time);
|
|
|
|
bool readAltitude(const char *data, int len, qreal &ele);
|
|
|
|
bool readGeoidHeight(const char *data, int len, qreal &gh);
|
|
|
|
|
2017-07-27 19:47:46 +02:00
|
|
|
bool readRMC(TrackData &track, const char *line, int len);
|
|
|
|
bool readGGA(TrackData &track, const char *line, int len);
|
2019-01-18 00:17:28 +01:00
|
|
|
bool readWPL(QVector<Waypoint> &waypoints, const char *line, int len);
|
2016-11-16 23:54:15 +01:00
|
|
|
bool readZDA(const char *line, int len);
|
|
|
|
|
|
|
|
int _errorLine;
|
|
|
|
QString _errorString;
|
|
|
|
|
|
|
|
QDate _date;
|
2016-11-22 00:13:41 +01:00
|
|
|
QTime _time;
|
2016-11-16 23:54:15 +01:00
|
|
|
bool _GGA;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // NMEAPARSER_H
|