Commit 2bb7d251 authored by Pierre TILAK's avatar Pierre TILAK

Re-add Missing map providers

parent 863c0ffc
...@@ -97,7 +97,6 @@ Map { ...@@ -97,7 +97,6 @@ Map {
var settings = QGroundControl.settingsManager.flightMapSettings var settings = QGroundControl.settingsManager.flightMapSettings
var fullMapName = settings.mapProvider.value + " " + settings.mapType.value var fullMapName = settings.mapProvider.value + " " + settings.mapType.value
console.log("updateActiveMapType",fullMapName)
for (var i = 0; i < _map.supportedMapTypes.length; i++) { for (var i = 0; i < _map.supportedMapTypes.length; i++) {
if (fullMapName === _map.supportedMapTypes[i].name) { if (fullMapName === _map.supportedMapTypes[i].name) {
_map.activeMapType = _map.supportedMapTypes[i] _map.activeMapType = _map.supportedMapTypes[i]
......
...@@ -20,3 +20,84 @@ QString EniroMapProvider::_getURL(int x, int y, int zoom, ...@@ -20,3 +20,84 @@ QString EniroMapProvider::_getURL(int x, int y, int zoom,
.arg(x) .arg(x)
.arg((1 << zoom) - 1 - y); .arg((1 << zoom) - 1 - y);
} }
QString MapQuestMapMapProvider::_getURL(int x, int y, int zoom,
QNetworkAccessManager* networkManager) {
Q_UNUSED(networkManager);
char letter = "1234"[_getServerNum(x, y, 4)];
return QString("http://otile%1.mqcdn.com/tiles/1.0.0/map/%2/%3/%4.jpg")
.arg(letter)
.arg(zoom)
.arg(x)
.arg(y);
}
QString MapQuestSatMapProvider::_getURL(int x, int y, int zoom,
QNetworkAccessManager* networkManager) {
Q_UNUSED(networkManager);
char letter = "1234"[_getServerNum(x, y, 4)];
return QString("http://otile%1.mqcdn.com/tiles/1.0.0/sat/%2/%3/%4.jpg")
.arg(letter)
.arg(zoom)
.arg(x)
.arg(y);
}
QString
VWorldStreetMapProvider::_getURL(int x, int y, int zoom,
QNetworkAccessManager* networkManager) {
Q_UNUSED(networkManager);
int gap = zoom - 6;
int x_min = 53 * pow(2, gap);
int x_max = 55 * pow(2, gap) + (2 * gap - 1);
int y_min = 22 * pow(2, gap);
int y_max = 26 * pow(2, gap) + (2 * gap - 1);
if (zoom > 19) {
return {};
} else if (zoom > 5 && x >= x_min && x <= x_max && y >= y_min &&
y <= y_max) {
return QString(
"http://xdworld.vworld.kr:8080/2d/Base/service/%1/%2/%3.png")
.arg(zoom)
.arg(x)
.arg(y);
} else {
QString key = _tileXYToQuadKey(x, y, zoom);
return QString("http://ecn.t%1.tiles.virtualearth.net/tiles/"
"r%2.png?g=%3&mkt=%4")
.arg(_getServerNum(x, y, 4))
.arg(key)
.arg(_versionBingMaps)
.arg(_language);
}
}
QString VWorldSatMapProvider::_getURL(int x, int y, int zoom,
QNetworkAccessManager* networkManager) {
Q_UNUSED(networkManager);
int gap = zoom - 6;
int x_min = 53 * pow(2, gap);
int x_max = 55 * pow(2, gap) + (2 * gap - 1);
int y_min = 22 * pow(2, gap);
int y_max = 26 * pow(2, gap) + (2 * gap - 1);
if (zoom > 19) {
return {};
} else if (zoom > 5 && x >= x_min && x <= x_max && y >= y_min &&
y <= y_max) {
return QString("http://xdworld.vworld.kr:8080/2d/Satellite/service/%1/"
"%2/%3.jpeg")
.arg(zoom)
.arg(x)
.arg(y);
} else {
QString key = _tileXYToQuadKey(x, y, zoom);
return QString("http://ecn.t%1.tiles.virtualearth.net/tiles/"
"a%2.jpeg?g=%3&mkt=%4")
.arg(_getServerNum(x, y, 4))
.arg(key)
.arg(_versionBingMaps)
.arg(_language);
}
}
...@@ -30,3 +30,55 @@ class EniroMapProvider : public MapProvider { ...@@ -30,3 +30,55 @@ class EniroMapProvider : public MapProvider {
QString _getURL(int x, int y, int zoom, QString _getURL(int x, int y, int zoom,
QNetworkAccessManager* networkManager); QNetworkAccessManager* networkManager);
}; };
class MapQuestMapMapProvider : public MapProvider {
Q_OBJECT
public:
MapQuestMapMapProvider(QObject* parent)
: MapProvider(QString("https://mapquest.com"), QString("jpg"),
AVERAGE_TILE_SIZE, QGeoMapType::StreetMap, parent) {}
QString _getURL(int x, int y, int zoom,
QNetworkAccessManager* networkManager);
};
class MapQuestSatMapProvider : public MapProvider {
Q_OBJECT
public:
MapQuestSatMapProvider(QObject* parent)
: MapProvider(QString("https://mapquest.com"), QString("jpg"),
AVERAGE_TILE_SIZE, QGeoMapType::SatelliteMapDay, parent) {
}
QString _getURL(int x, int y, int zoom,
QNetworkAccessManager* networkManager);
};
class VWorldStreetMapProvider : public MapProvider {
Q_OBJECT
public:
VWorldStreetMapProvider(QObject* parent)
: MapProvider(QString("www.vworld.kr"), QString("png"),
AVERAGE_TILE_SIZE, QGeoMapType::StreetMap, parent) {}
QString _getURL(int x, int y, int zoom,
QNetworkAccessManager* networkManager);
private:
const QString _versionBingMaps = "563";
};
class VWorldSatMapProvider : public MapProvider {
Q_OBJECT
public:
VWorldSatMapProvider(QObject* parent)
: MapProvider(QString("www.vworld.kr"), QString("jpg"),
AVERAGE_TILE_SIZE, QGeoMapType::SatelliteMapDay, parent) {
}
QString _getURL(int x, int y, int zoom,
QNetworkAccessManager* networkManager);
private:
const QString _versionBingMaps = "563";
};
...@@ -69,6 +69,12 @@ UrlFactory::UrlFactory() : _timeout(5 * 1000) { ...@@ -69,6 +69,12 @@ UrlFactory::UrlFactory() : _timeout(5 * 1000) {
_providersTable["Mapbox Outdoors"] = new MapboxOutdoorsMapProvider(this); _providersTable["Mapbox Outdoors"] = new MapboxOutdoorsMapProvider(this);
_providersTable["Mapbox RunBikeHike"] = new MapboxRunBikeHikeMapProvider(this); _providersTable["Mapbox RunBikeHike"] = new MapboxRunBikeHikeMapProvider(this);
_providersTable["Mapbox HighContrast"] = new MapboxHighContrastMapProvider(this); _providersTable["Mapbox HighContrast"] = new MapboxHighContrastMapProvider(this);
//_providersTable["MapQuest Map"] = new MapQuestMapMapProvider(this);
//_providersTable["MapQuest Sat"] = new MapQuestSatMapProvider(this);
_providersTable["VWorld Street Map"] = new VWorldStreetMapProvider(this);
_providersTable["VWorld Satellite Map"] = new VWorldSatMapProvider(this);
} }
void UrlFactory::registerProvider(QString name, MapProvider* provider) { void UrlFactory::registerProvider(QString name, MapProvider* provider) {
...@@ -432,7 +438,7 @@ quint32 UrlFactory::averageSizeForType(QString type) { ...@@ -432,7 +438,7 @@ quint32 UrlFactory::averageSizeForType(QString type) {
return _providersTable[type]->getAverageSize(); return _providersTable[type]->getAverageSize();
} }
qCDebug(QGCMapUrlEngineLog) << "UrlFactory::averageSizeForType " << type qCDebug(QGCMapUrlEngineLog) << "UrlFactory::averageSizeForType " << type
<< " Not registeret"; << " Not registered";
// case AirmapElevation: // case AirmapElevation:
// return AVERAGE_AIRMAP_ELEV_SIZE; // return AVERAGE_AIRMAP_ELEV_SIZE;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment