-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathkmlreader.cpp
79 lines (73 loc) · 2.09 KB
/
kmlreader.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
#include "kmlreader.h"
#include <QDebug>
#include "cpoint.h"
KMLReader::KMLReader()
{
is_point=false;
is_LineString=false;
has_ele=false;
}
bool KMLReader::readFile(const QString &fileName)
{
QFile file(fileName);
QXmlInputSource inputSource(&file);
QXmlSimpleReader reader;
reader.setContentHandler(this);
reader.setErrorHandler(this);
return reader.parse(inputSource);
}
bool KMLReader::startElement(const QString &namespaceURI, const QString &localName, const QString &qName, const QXmlAttributes &atts)
{
if (qName=="LineString") is_LineString=true;
else
if
(qName=="coordinates") is_point=true;
return true;
}
bool KMLReader::endElement(const QString &namespaceURI, const QString &localName, const QString &qName)
{
if (qName=="LineString") is_LineString=false;
else
if
(qName=="coordinates") is_point=false;
return true;
}
bool KMLReader::characters(const QString &ch)
{
if (is_point&&is_LineString)
{
QStringList list1, list2;
list1 = ch.split(QRegExp("[ ]"), QString::SkipEmptyParts);
QStringListIterator iterator1(list1);
while (iterator1.hasNext())
{
CPoint f;
list2 = iterator1.next().split(QRegExp("[,]"), QString::SkipEmptyParts);
QStringListIterator iterator2(list2);
bool ok;
double y = iterator2.next().toDouble(&ok);
if (!ok||y<-180||y>180) return true;
double x = iterator2.next().toDouble(&ok);
if (!ok||x<-90||x>90) return true;
if (iterator2.hasNext())
{
double z = iterator2.next().toDouble(&ok);
if (!ok) return true;
f.setData(x,y,z);
has_ele=true;
}
else
{
f.setData(x,y);
if (has_ele==true) has_ele=false;
}
points.insert(points.size(),f);
}
}
return true;
}
bool KMLReader::fatalError(const QXmlParseException &exception)
{
qDebug()<<"error";
return false;
}