1
0
mirror of https://github.com/tumic0/GPXSee.git synced 2025-03-18 04:27:45 +01:00
GPXSee/src/map/dem.h
2024-10-22 07:43:42 +02:00

79 lines
1.5 KiB
C++

#ifndef DEM_H
#define DEM_H
#include <QString>
#include <QCache>
#include <QByteArray>
#include <QMutex>
#include "common/hash.h"
#include "data/area.h"
#include "matrix.h"
class DEM
{
public:
class Tile {
public:
Tile(int lon, int lat) : _lon(lon), _lat(lat) {}
int lon() const {return _lon;}
int lat() const {return _lat;}
QString lonStr() const;
QString latStr() const;
QString fileName() const;
bool operator==(const Tile &other) const
{
return (_lon == other._lon && _lat == other._lat);
}
private:
int _lon, _lat;
};
static void setCacheSize(int size);
static void setDir(const QString &path);
static void clearCache();
static double elevation(const Coordinates &c);
static MatrixD elevation(const MatrixC &m);
static QList<Area> tiles();
private:
class Entry {
public:
Entry() : _samples(0) {}
Entry(const QByteArray &data);
const QByteArray &data() const {return _data;}
int samples() const {return _samples;}
private:
unsigned int _samples;
QByteArray _data;
};
typedef QCache<DEM::Tile, Entry> TileCache;
static double height(const Coordinates &c, const Entry *e);
static Entry *loadTile(const Tile &tile);
static double elevationLockFree(const Coordinates &c);
static QString _dir;
static TileCache _data;
static QMutex _lock;
};
inline HASH_T qHash(const DEM::Tile &tile)
{
return (qHash(tile.lon()) ^ qHash(tile.lat()));
}
#ifndef QT_NO_DEBUG
QDebug operator<<(QDebug dbg, const DEM::Tile &tile);
#endif // QT_NO_DEBUG
#endif // DEM_H