2009-11-07 19:22:27 +00:00
|
|
|
/** \ingroup analysis
|
|
|
|
* The QGis class provides vector geometry analysis functions
|
|
|
|
*/
|
|
|
|
|
|
|
|
class QgsGeometryAnalyzer
|
|
|
|
{
|
|
|
|
%TypeHeaderCode
|
|
|
|
#include <qgsgeometryanalyzer.h>
|
|
|
|
%End
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Simplify vector layer using (a modified) Douglas-Peucker algorithm
|
|
|
|
* and write it to a new shape file
|
|
|
|
*/
|
|
|
|
bool simplify( QgsVectorLayer* layer, const QString& shapefileName, double tolerance,
|
|
|
|
bool onlySelectedFeatures = false );
|
|
|
|
|
|
|
|
/**Calculate the true centroids, or 'center of mass' for a vector layer and
|
|
|
|
write it to a new shape file
|
|
|
|
*/
|
|
|
|
bool centroids( QgsVectorLayer* layer, const QString& shapefileName,
|
|
|
|
bool onlySelectedFeatures = false );
|
|
|
|
|
|
|
|
/**Create a polygon based on the extent of all (selected) features and write it to a new shape file
|
|
|
|
*/
|
|
|
|
bool extent( QgsVectorLayer* layer, const QString& shapefileName,
|
|
|
|
bool onlySelectedFeatures = false );
|
|
|
|
|
|
|
|
/**Create buffers for a vector layer and write it to a new shape file
|
|
|
|
*/
|
|
|
|
bool buffer( QgsVectorLayer* layer, const QString& shapefileName, double bufferDistance,
|
|
|
|
bool onlySelectedFeatures = false, bool dissolve = false,
|
|
|
|
int bufferDistanceField = -1 );
|
|
|
|
|
|
|
|
/**Create convex hull(s) of a vector layer and write it to a new shape file
|
|
|
|
*/
|
|
|
|
bool convexHull( QgsVectorLayer* layer, const QString& shapefileName,
|
|
|
|
bool onlySelectedFeatures = false,
|
|
|
|
int uniqueIdField = -1 );
|
|
|
|
|
|
|
|
/**Dissolve a vector layer and write it to a new shape file
|
|
|
|
*/
|
|
|
|
bool dissolve( QgsVectorLayer* layer, const QString& shapefileName,
|
|
|
|
bool onlySelectedFeatures = false,
|
|
|
|
int uniqueIdField = -1 );
|
|
|
|
|
2012-04-01 13:23:26 +02:00
|
|
|
/**Creates an event layer (multipoint or multiline) by locating features from a (non-spatial) event table along the features of a line layer.
|
|
|
|
Note that currently (until QgsGeometry supports m-values) the z-coordinate of the line layer is used for linear referencing
|
2012-01-25 15:03:18 +01:00
|
|
|
@param lineLayer layer with the line geometry
|
|
|
|
@param eventLayer layer with features and location field
|
|
|
|
@param lineField join index in line layer
|
|
|
|
@param eventField join index in event layer
|
2012-02-03 14:52:53 +01:00
|
|
|
@param outputLayer name of output file (can be empty if a memory layer is used)
|
|
|
|
@param outputFormat name of output format (can be empty if a memory provider is used to store the results)
|
|
|
|
@param unlocatedFeatureIds out: ids of event features where linear referencing was not successful
|
2012-01-25 15:03:18 +01:00
|
|
|
@param locationField1 attribute index of location field in event layer
|
|
|
|
@param locationField2 attribute index of location end field (or -1 for point layer)
|
2012-04-01 13:23:26 +02:00
|
|
|
@param offsetField attribute index for offset field. Negative offset value = offset to left side, positive value = offset to right side
|
|
|
|
@param offsetScale factor to scale offset
|
|
|
|
@param forceSingleGeometry force layer to single point/line type. Feature attributes are copied in case of multiple matches
|
2012-02-03 14:52:53 +01:00
|
|
|
@param memoryProvider memory provider to write output to (can be 0 if output is written to a file)
|
|
|
|
@param p progress dialog or 0 if no progress dialog should be shown
|
2012-01-25 15:03:18 +01:00
|
|
|
*/
|
2012-02-03 14:33:50 +01:00
|
|
|
bool eventLayer( QgsVectorLayer* lineLayer, QgsVectorLayer* eventLayer, int lineField, int eventField, QList<int>& unlocatedFeatureIds /Out/,
|
2012-03-23 11:30:57 +01:00
|
|
|
const QString& outputLayer, const QString& outputFormat, int locationField1, int locationField2 = -1, int offsetField = -1, double offsetScale = 1.0,
|
|
|
|
bool forceSingleGeometry = false, QgsVectorDataProvider* memoryProvider = 0, QProgressDialog* p = 0 );
|
2012-01-25 15:03:18 +01:00
|
|
|
|
2012-01-30 14:30:13 +01:00
|
|
|
/**Returns multilinestring*/
|
|
|
|
QgsGeometry* locateBetweenMeasures( double fromMeasure, double toMeasure, QgsGeometry* lineGeom );
|
|
|
|
/**Returns multipoint*/
|
|
|
|
QgsGeometry* locateAlongMeasure( double measure, QgsGeometry* lineGeom );
|
2012-01-30 13:52:58 +01:00
|
|
|
|
2009-11-07 19:22:27 +00:00
|
|
|
private:
|
|
|
|
|
|
|
|
QList<double> simpleMeasure( QgsGeometry* geometry );
|
|
|
|
double perimeterMeasure( QgsGeometry* geometry, QgsDistanceArea& measure );
|
|
|
|
/**Helper function to simplify an individual feature*/
|
|
|
|
void simplifyFeature( QgsFeature& f, QgsVectorFileWriter* vfw, double tolerance );
|
|
|
|
/**Helper function to get the cetroid of an individual feature*/
|
|
|
|
void centroidFeature( QgsFeature& f, QgsVectorFileWriter* vfw );
|
|
|
|
/**Helper function to buffer an individual feature*/
|
|
|
|
void bufferFeature( QgsFeature& f, int nProcessedFeatures, QgsVectorFileWriter* vfw,
|
|
|
|
bool dissolve, QgsGeometry** dissolveGeometry,
|
|
|
|
double bufferDistance, int bufferDistanceField );
|
|
|
|
/**Helper function to get the convex hull of feature(s)*/
|
|
|
|
void convexFeature( QgsFeature& f, int nProcessedFeatures,
|
|
|
|
QgsGeometry** dissolveGeometry );
|
|
|
|
/**Helper function to dissolve feature(s)*/
|
|
|
|
void dissolveFeature( QgsFeature& f, int nProcessedFeatures,
|
|
|
|
QgsGeometry** dissolveGeometry );
|
|
|
|
};
|