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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/****************************************************************************
*
* (c) 2009-2016 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
*
* QGroundControl is licensed according to the terms in the file
* COPYING.md in the root of the source code directory.
*
****************************************************************************/
#include "ShapeFileHelper.h"
#include "AppSettings.h"
#include "KMLFileHelper.h"
#include "SHPFileHelper.h"
#include <QFile>
#include <QVariant>
const char* ShapeFileHelper::_errorPrefix = QT_TR_NOOP("Shape file load failed. %1");
QVariantList ShapeFileHelper::determineShapeType(const QString& file)
{
QString errorString;
ShapeType shapeType = determineShapeType(file, errorString);
QVariantList varList;
varList.append(QVariant::fromValue(shapeType));
varList.append(QVariant::fromValue(errorString));
return varList;
}
bool ShapeFileHelper::_fileIsKML(const QString& file, QString& errorString)
{
errorString.clear();
if (file.endsWith(AppSettings::kmlFileExtension)) {
return true;
} else if (file.endsWith(AppSettings::shpFileExtension)) {
return false;
} else {
errorString = QString(_errorPrefix).arg(tr("Unsupported file type. Only .%1 and .%2 are supported.").arg(AppSettings::kmlFileExtension).arg(AppSettings::shpFileExtension));
}
return true;
}
ShapeFileHelper::ShapeType ShapeFileHelper::determineShapeType(const QString& file, QString& errorString)
{
ShapeType shapeType = Error;
errorString.clear();
bool fileIsKML = _fileIsKML(file, errorString);
if (errorString.isEmpty()) {
if (fileIsKML) {
shapeType = KMLFileHelper::determineShapeType(file, errorString);
} else {
shapeType = SHPFileHelper::determineShapeType(file, errorString);
}
}
return shapeType;
}
bool ShapeFileHelper::loadPolygonFromFile(const QString& file, QList<QGeoCoordinate>& vertices, QString& errorString)
{
bool success = false;
errorString.clear();
vertices.clear();
bool fileIsKML = _fileIsKML(file, errorString);
if (errorString.isEmpty()) {
if (fileIsKML) {
success = KMLFileHelper::loadPolygonFromFile(file, vertices, errorString);
} else {
success = SHPFileHelper::loadPolygonFromFile(file, vertices, errorString);
}
}
return success;
}
bool ShapeFileHelper::loadPolylineFromFile(const QString& file, QList<QGeoCoordinate>& coords, QString& errorString)
{
errorString.clear();
coords.clear();
bool fileIsKML = _fileIsKML(file, errorString);
if (errorString.isEmpty()) {
if (fileIsKML) {
KMLFileHelper::loadPolylineFromFile(file, coords, errorString);
} else {
errorString = QString(_errorPrefix).arg(tr("Polyline not support from SHP files."));
}
}
return errorString.isEmpty();
}
QStringList ShapeFileHelper::fileDialogKMLFilters(void) const
{
return QStringList(tr("KML Files (*.%1)").arg(AppSettings::kmlFileExtension));
}
QStringList ShapeFileHelper::fileDialogKMLOrSHPFilters(void) const
{
return QStringList(tr("KML/SHP Files (*.%1 *.%2)").arg(AppSettings::kmlFileExtension).arg(AppSettings::shpFileExtension));
}