mirror of
https://github.com/tumic0/GPXSee.git
synced 2025-01-18 19:52:09 +01:00
Some more offline map code cleanup
This commit is contained in:
parent
16476dbf74
commit
de05f5e64b
@ -15,7 +15,7 @@
|
||||
#include "offlinemap.h"
|
||||
|
||||
|
||||
bool OfflineMap::getImageInfo(const QString &path)
|
||||
bool OfflineMap::setImageInfo(const QString &path)
|
||||
{
|
||||
QFileInfo ii(_map.path);
|
||||
|
||||
@ -58,8 +58,13 @@ bool OfflineMap::getImageInfo(const QString &path)
|
||||
return true;
|
||||
}
|
||||
|
||||
bool OfflineMap::getTileInfo(const QStringList &tiles, const QString &path)
|
||||
bool OfflineMap::setTileInfo(const QStringList &tiles, const QString &path)
|
||||
{
|
||||
if (!_map.size.isValid()) {
|
||||
_errorString = "Missing total image size (IWH)";
|
||||
return false;
|
||||
}
|
||||
|
||||
QRegExp rx("_[0-9]+_[0-9]+\\.");
|
||||
for (int i = 0; i < tiles.size(); i++) {
|
||||
if (tiles.at(i).contains(rx)) {
|
||||
@ -79,6 +84,7 @@ bool OfflineMap::getTileInfo(const QStringList &tiles, const QString &path)
|
||||
return false;
|
||||
}
|
||||
|
||||
_map.path = QString();
|
||||
return true;
|
||||
}
|
||||
}
|
||||
@ -87,15 +93,6 @@ bool OfflineMap::getTileInfo(const QStringList &tiles, const QString &path)
|
||||
return false;
|
||||
}
|
||||
|
||||
bool OfflineMap::totalSizeSet()
|
||||
{
|
||||
if (!_map.size.isValid()) {
|
||||
_errorString = "Missing total image size (IWH)";
|
||||
return false;
|
||||
} else
|
||||
return true;
|
||||
}
|
||||
|
||||
OfflineMap::OfflineMap(const QString &fileName, QObject *parent)
|
||||
: Map(parent), _img(0), _tar(0), _ozf(0), _zoom(0), _valid(false)
|
||||
{
|
||||
@ -158,21 +155,15 @@ OfflineMap::OfflineMap(const QString &fileName, QObject *parent)
|
||||
}
|
||||
|
||||
if (_tar) {
|
||||
if (!totalSizeSet())
|
||||
if (!setTileInfo(_tar->files()))
|
||||
return;
|
||||
if (!getTileInfo(_tar->files()))
|
||||
return;
|
||||
_map.path = QString();
|
||||
} else {
|
||||
QDir set(fi.absolutePath() + "/" + "set");
|
||||
if (set.exists()) {
|
||||
if (!totalSizeSet())
|
||||
if (!setTileInfo(set.entryList(), set.absolutePath()))
|
||||
return;
|
||||
if (!getTileInfo(set.entryList(), set.absolutePath()))
|
||||
return;
|
||||
_map.path = QString();
|
||||
} else {
|
||||
if (!getImageInfo(fi.absolutePath()))
|
||||
if (!setImageInfo(fi.absolutePath()))
|
||||
return;
|
||||
}
|
||||
}
|
||||
@ -230,7 +221,7 @@ void OfflineMap::load()
|
||||
qPrintable(_tar->fileName()));
|
||||
return;
|
||||
}
|
||||
if (!getTileInfo(_tar->files()))
|
||||
if (!setTileInfo(_tar->files()))
|
||||
qWarning("%s: %s", qPrintable(_tar->fileName()),
|
||||
qPrintable(_errorString));
|
||||
return;
|
||||
@ -249,7 +240,7 @@ void OfflineMap::unload()
|
||||
_img = 0;
|
||||
}
|
||||
|
||||
void OfflineMap::drawTiled(QPainter *painter, const QRectF &rect)
|
||||
void OfflineMap::drawTiled(QPainter *painter, const QRectF &rect) const
|
||||
{
|
||||
QPoint tl = QPoint((int)floor(rect.left() / (qreal)_tile.size.width())
|
||||
* _tile.size.width(), (int)floor(rect.top() / _tile.size.height())
|
||||
@ -287,7 +278,7 @@ void OfflineMap::drawTiled(QPainter *painter, const QRectF &rect)
|
||||
}
|
||||
}
|
||||
|
||||
void OfflineMap::drawOZF(QPainter *painter, const QRectF &rect)
|
||||
void OfflineMap::drawOZF(QPainter *painter, const QRectF &rect) const
|
||||
{
|
||||
QPoint tl = QPoint((int)floor(rect.left() / _ozf->tileSize().width())
|
||||
* _ozf->tileSize().width(), (int)floor(rect.top()
|
||||
@ -318,7 +309,7 @@ void OfflineMap::drawOZF(QPainter *painter, const QRectF &rect)
|
||||
}
|
||||
}
|
||||
|
||||
void OfflineMap::drawImage(QPainter *painter, const QRectF &rect)
|
||||
void OfflineMap::drawImage(QPainter *painter, const QRectF &rect) const
|
||||
{
|
||||
QRect r(rect.toRect());
|
||||
painter->drawImage(r.left(), r.top(), *_img, r.left(), r.top(),
|
||||
|
@ -59,13 +59,12 @@ private:
|
||||
QPointF ll2xy(const Coordinates &c) const;
|
||||
Coordinates xy2ll(const QPointF &p) const;
|
||||
|
||||
bool getTileInfo(const QStringList &tiles, const QString &path = QString());
|
||||
bool getImageInfo(const QString &path);
|
||||
bool totalSizeSet();
|
||||
bool setTileInfo(const QStringList &tiles, const QString &path = QString());
|
||||
bool setImageInfo(const QString &path);
|
||||
|
||||
void drawTiled(QPainter *painter, const QRectF &rect);
|
||||
void drawOZF(QPainter *painter, const QRectF &rect);
|
||||
void drawImage(QPainter *painter, const QRectF &rect);
|
||||
void drawTiled(QPainter *painter, const QRectF &rect) const;
|
||||
void drawOZF(QPainter *painter, const QRectF &rect) const;
|
||||
void drawImage(QPainter *painter, const QRectF &rect) const;
|
||||
|
||||
void rescale(int zoom);
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user