1
0
mirror of https://github.com/tumic0/GPXSee.git synced 2024-11-28 13:41:16 +01:00
GPXSee/src/data/kmlparser.h

53 lines
1.8 KiB
C
Raw Normal View History

#ifndef KMLPARSER_H
#define KMLPARSER_H
#include <QXmlStreamReader>
2016-10-25 22:50:11 +02:00
#include <QDateTime>
#include "parser.h"
class KMLParser : public Parser
{
public:
2019-01-31 01:46:53 +01:00
bool parse(QFile *file, QList<TrackData> &tracks, QList<RouteData> &routes,
QList<Area> &areas, QVector<Waypoint> &waypoints);
QString errorString() const {return _reader.errorString();}
int errorLine() const {return _reader.lineNumber();}
private:
2019-01-31 01:46:53 +01:00
void kml(QList<TrackData> &tracks, QList<Area> &areas,
QVector<Waypoint> &waypoints);
void document(QList<TrackData> &tracks, QList<Area> &areas,
QVector<Waypoint> &waypoints);
void folder(QList<TrackData> &tracks, QList<Area> &areas,
QVector<Waypoint> &waypoints);
void placemark(QList<TrackData> &tracks, QList<Area> &areas,
QVector<Waypoint> &waypoints);
void multiGeometry(QList<TrackData> &tracks, QList<Area> &areas,
QVector<Waypoint> &waypoints, const QString &name, const QString &desc,
const QDateTime timestamp);
2019-02-11 23:28:08 +01:00
void track(SegmentData &segment);
void multiTrack(TrackData &t);
2019-02-11 23:28:08 +01:00
void lineString(SegmentData &segment);
2019-01-31 01:46:53 +01:00
void linearRing(QVector<Coordinates> &coordinates);
void boundary(QVector<Coordinates> &coordinates);
void polygon(Area &area);
2016-10-27 22:33:35 +02:00
void point(Waypoint &waypoint);
bool pointCoordinates(Waypoint &waypoint);
2019-02-11 23:28:08 +01:00
bool lineCoordinates(SegmentData &segment);
2019-01-31 01:46:53 +01:00
bool polygonCoordinates(QVector<Coordinates> &points);
2016-10-28 19:12:40 +02:00
bool coord(Trackpoint &trackpoint);
2019-02-11 23:28:08 +01:00
void extendedData(SegmentData &segment, int start);
void schemaData(SegmentData &segment, int start);
void heartRate(SegmentData &segment, int start);
void cadence(SegmentData &segment, int start);
void speed(SegmentData &segment, int start);
void temperature(SegmentData &segment, int start);
QDateTime timeStamp();
2016-10-27 22:33:35 +02:00
qreal number();
QDateTime time();
QXmlStreamReader _reader;
};
#endif // KMLPARSER_H