Rev 539 |
Go to most recent revision |
Blame |
Compare with Previous |
Last modification |
View Log
| RSS feed
//---------------------------------------------------------------------------
#ifndef GISGRID_H
#define GISGRID_H
#include <QVector3D>
#include <QString>
#include <QPointF>
#include <QRectF>
#include "grid.h"
struct SCoordTrans {
double RotationAngle;
double sinRotate, cosRotate;
double sinRotateReverse, cosRotateReverse;
double offsetX, offsetY, offsetZ;
};
// setup routine -- give a vector with offsets [m] and rotation angle.
void setupGISTransformation(const double offsetx,
const double offsety,
const double offsetz,
const double angle_degree);
// transformation routines.
void worldToModel(const QVector3D &From, QVector3D &To);
void modelToWorld(const QVector3D &From, QVector3D &To);
class GISGrid
{
public:
GISGrid();
~GISGrid();
// maintenance
bool loadFromFile(const QString &fileName); ///< load ESRI style text file
// access
int dataSize() const { return mDataSize; } ///< number of data items (rows*cols)
int rows() const { return mNRows; } ///< number of rows
int cols() const { return mNCols; } ///< number of columns
double cellSize() const { return mCellSize; } ///< size of a cell (meters)
double minValue() const { return min_value; } ///< minimum data value
double maxValue() const { return max_value; } ///< maximum data value
/// get grid value at (X/Y); returs NODATAValue if out of range
double value(const QPointF &p) const {return value(p.x(), p.y());}
double value(const double X, const double Y) const;
double value(const int indexx, const int indexy) const; ///< get value of grid at index positions
/// get coordinates of the center of the cell with 'Index'
QVector3D coord(const int Index) const;
QVector3D coord(const int indexx, const int indexy) const;
QRectF rectangle(const int indexx, const int indexy) const;
void clip(const QRectF & box); ///< clip the grid to 'Box' (set values outside to -1)
// special operations
//QRectF GetBoundingBox(int LookFor, SBoundingBox &Result, double x_m, double y_m);
QList<double> distinctValues(); ///< returns a list of distinct values
//void GetDistinctValues(TStringList *ResultList, double x_m, double y_m);
//void CountOccurence(int intID, int & Count, int & left, int &upper, int &right, int &lower, SBoundingBox *OuterBox);
//S3dVector GetNthOccurence(int ID, int N, int left, int upper, int right, int lower);
//void ExportToTable(AnsiString OutFileName);
/// create (new!!) and return a grid that covers the full iland project area
/// and holds a list of integer keys
Grid<int> *create10mGrid();
private:
int mDataSize; ///< number of data items (rows*cols)
double mCellSize; // size of cells [m]
double max_value;
double min_value;
QPointF mOrigin; // lowerleftcorner
QPointF xAxis; // transformed axis (moved, rotated)
QPointF yAxis;
int mNRows;
int mNCols; // count of rows and cols
double *mData;
int mNODATAValue;
};
// Cached GIS - Dataset
// template class.
/*
template <class T> class TGISData
{
public:
TTypedList<T> *Items;
TGISGrid *Grid;
TGISData() {
Items = new TTypedList<T>(true);
Grid=0;
}
~TGISData() {
delete Items;
//if (Grid)
// delete Grid;
}
int Add(T* Item) {
return Items->Add(Item);
}
void Clear() { Items->Clear(); }
// template <class T> * Select(int ID);
T* Select(int ID) {
for (int i=0;i<Items->Count;i++)
if (Items->Items[i]->ID == ID)
return Items->Items[i];
return 0;
}
T* SelectAt(double X, double Y) {
if (!Grid)
return 0;
int CellValue = Grid->value(X,Y);
return Select(CellValue);
}
//bool Select(int ID);
};
*/
//---------------------------------------------------------------------------
#endif