2015-10-05 01:43:48 +02:00
|
|
|
#ifndef PARSER_H
|
|
|
|
#define PARSER_H
|
|
|
|
|
|
|
|
#include <QXmlStreamReader>
|
|
|
|
#include <QDateTime>
|
|
|
|
#include <QPointF>
|
|
|
|
|
|
|
|
struct TrackPoint
|
|
|
|
{
|
|
|
|
QPointF coordinates;
|
|
|
|
QDateTime timestamp;
|
|
|
|
qreal elevation;
|
2015-10-19 00:35:08 +02:00
|
|
|
qreal geoidheight;
|
2015-10-15 01:30:21 +02:00
|
|
|
qreal speed;
|
|
|
|
|
2015-10-19 00:35:08 +02:00
|
|
|
TrackPoint() {elevation = 0; geoidheight = 0; speed = -1;}
|
2015-10-05 01:43:48 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
class Parser
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
bool loadFile(QIODevice *device, QVector<TrackPoint> &data);
|
|
|
|
QString errorString() const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
bool parse(QVector<TrackPoint> &data);
|
|
|
|
void gpx(QVector<TrackPoint> &data);
|
|
|
|
void trek(QVector<TrackPoint> &data);
|
|
|
|
void trekPoints(QVector<TrackPoint> &data);
|
2015-10-15 01:30:21 +02:00
|
|
|
void extensions(QVector<TrackPoint> &data);
|
2015-10-05 01:43:48 +02:00
|
|
|
void trekPointData(QVector<TrackPoint> &data);
|
|
|
|
|
|
|
|
void handleTrekPointAttributes(QVector<TrackPoint> &data,
|
|
|
|
const QXmlStreamAttributes &attr);
|
|
|
|
void handleTrekPointData(QVector<TrackPoint> &data, QStringRef element,
|
|
|
|
const QString &value);
|
2015-10-15 01:30:21 +02:00
|
|
|
void handleExtensionData(QVector<TrackPoint> &data, QStringRef element,
|
|
|
|
const QString &value);
|
2015-10-05 01:43:48 +02:00
|
|
|
|
|
|
|
QXmlStreamReader _reader;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // PARSER_H
|