mirror of
https://github.com/tumic0/GPXSee.git
synced 2025-02-23 10:40:49 +01:00
Added support for geo URIs (RFC 5870)
This commit is contained in:
parent
9cd82319e9
commit
0ed630dd20
@ -1069,6 +1069,16 @@ void GUI::openDir()
|
|||||||
|
|
||||||
bool GUI::openFile(const QString &fileName, bool tryUnknown, int &showError)
|
bool GUI::openFile(const QString &fileName, bool tryUnknown, int &showError)
|
||||||
{
|
{
|
||||||
|
QUrl url(fileName);
|
||||||
|
if (url.scheme() == "geo") {
|
||||||
|
if (loadURL(url, showError)) {
|
||||||
|
_fileActionGroup->setEnabled(true);
|
||||||
|
_reloadFileAction->setEnabled(false);
|
||||||
|
return true;
|
||||||
|
} else if (showError)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
QFileInfo fi(fileName);
|
QFileInfo fi(fileName);
|
||||||
QString canonicalFileName(fi.canonicalFilePath());
|
QString canonicalFileName(fi.canonicalFilePath());
|
||||||
|
|
||||||
@ -1099,6 +1109,36 @@ bool GUI::openFile(const QString &fileName, bool tryUnknown, int &showError)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool GUI::loadURL(const QUrl &url, int &showError)
|
||||||
|
{
|
||||||
|
Data data(url);
|
||||||
|
|
||||||
|
if (data.isValid()) {
|
||||||
|
loadData(data);
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
if (showError) {
|
||||||
|
QString error = tr("Error loading geo URI:") + "\n" + url.toString()
|
||||||
|
+ ": " + data.errorString();
|
||||||
|
|
||||||
|
if (showError > 1) {
|
||||||
|
QMessageBox message(QMessageBox::Critical, APP_NAME, error,
|
||||||
|
QMessageBox::Ok, this);
|
||||||
|
QCheckBox checkBox(tr("Don't show again"));
|
||||||
|
message.setCheckBox(&checkBox);
|
||||||
|
message.exec();
|
||||||
|
if (checkBox.isChecked())
|
||||||
|
showError = 0;
|
||||||
|
} else
|
||||||
|
QMessageBox::critical(this, APP_NAME, error);
|
||||||
|
} else
|
||||||
|
qWarning("%s: %s", qUtf8Printable(url.toString()),
|
||||||
|
qUtf8Printable(data.errorString()));
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bool GUI::loadFile(const QString &fileName, bool tryUnknown, int &showError)
|
bool GUI::loadFile(const QString &fileName, bool tryUnknown, int &showError)
|
||||||
{
|
{
|
||||||
Data data(fileName, tryUnknown);
|
Data data(fileName, tryUnknown);
|
||||||
|
@ -158,6 +158,7 @@ private:
|
|||||||
#endif // Q_OS_ANDROID
|
#endif // Q_OS_ANDROID
|
||||||
bool openPOIFile(const QString &fileName);
|
bool openPOIFile(const QString &fileName);
|
||||||
bool loadFile(const QString &fileName, bool tryUnknown, int &showError);
|
bool loadFile(const QString &fileName, bool tryUnknown, int &showError);
|
||||||
|
bool loadURL(const QUrl &url, int &showError);
|
||||||
void loadData(const Data &data);
|
void loadData(const Data &data);
|
||||||
bool loadMapNode(const TreeNode<Map*> &node, MapAction *&action,
|
bool loadMapNode(const TreeNode<Map*> &node, MapAction *&action,
|
||||||
const QList<QAction*> &existingActions, int &showError);
|
const QList<QAction*> &existingActions, int &showError);
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
#include <QFile>
|
#include <QFile>
|
||||||
#include <QFileInfo>
|
#include <QFileInfo>
|
||||||
#include "common/util.h"
|
#include "common/util.h"
|
||||||
|
#include "map/crs.h"
|
||||||
#include "gpxparser.h"
|
#include "gpxparser.h"
|
||||||
#include "tcxparser.h"
|
#include "tcxparser.h"
|
||||||
#include "csvparser.h"
|
#include "csvparser.h"
|
||||||
@ -154,6 +155,69 @@ Data::Data(const QString &fileName, bool tryUnknown)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Data::Data(const QUrl &url)
|
||||||
|
{
|
||||||
|
bool caOk, cbOk, ccOk;
|
||||||
|
Coordinates c;
|
||||||
|
Projection proj;
|
||||||
|
|
||||||
|
_valid = false;
|
||||||
|
|
||||||
|
QStringList parts(url.path().split(';'));
|
||||||
|
if (parts.size() < 1) {
|
||||||
|
_errorString = "Syntax error";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
QStringList coords(parts.at(0).split(','));
|
||||||
|
if (coords.size() < 2 || coords.size() > 3) {
|
||||||
|
_errorString = "Syntax error";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
double ca = coords.at(0).toDouble(&caOk);
|
||||||
|
double cb = coords.at(1).toDouble(&cbOk);
|
||||||
|
double cc = NAN;
|
||||||
|
if (!(caOk && cbOk)) {
|
||||||
|
_errorString = "Invalid coordinates";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (coords.size() > 2) {
|
||||||
|
cc = coords.at(2).toDouble(&ccOk);
|
||||||
|
if (!ccOk) {
|
||||||
|
_errorString = "Invalid elevation";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (parts.size() > 1) {
|
||||||
|
QStringList crsp(parts.at(1).split('='));
|
||||||
|
if (crsp.size() != 2) {
|
||||||
|
_errorString = "Syntax error";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (!crsp.at(0).compare("crs", Qt::CaseInsensitive)) {
|
||||||
|
if (crsp.at(1).compare("wgs84", Qt::CaseInsensitive)) {
|
||||||
|
proj = CRS::projection(crsp.at(1));
|
||||||
|
if (!proj.isValid()) {
|
||||||
|
_errorString = "Unknown CRS";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
c = proj.isValid() ? proj.xy2ll(PointD(ca, cb)) : Coordinates(cb, ca);
|
||||||
|
if (!c.isValid()) {
|
||||||
|
_errorString = "Invalid coordinates";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Waypoint w(c);
|
||||||
|
w.setElevation(cc);
|
||||||
|
_waypoints.append(w);
|
||||||
|
|
||||||
|
_valid = true;
|
||||||
|
}
|
||||||
|
|
||||||
QString Data::formats()
|
QString Data::formats()
|
||||||
{
|
{
|
||||||
return
|
return
|
||||||
|
@ -14,6 +14,7 @@ class Data
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
Data(const QString &fileName, bool tryUnknown = true);
|
Data(const QString &fileName, bool tryUnknown = true);
|
||||||
|
Data(const QUrl &url);
|
||||||
|
|
||||||
bool isValid() const {return _valid;}
|
bool isValid() const {return _valid;}
|
||||||
const QString &errorString() const {return _errorString;}
|
const QString &errorString() const {return _errorString;}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user