17 #ifndef QGS_GEOMETRY_SNAPPER_H    18 #define QGS_GEOMETRY_SNAPPER_H    22 #include <QStringList>    27 #include "qgis_analysis.h"    81     static QgsGeometry snapGeometry( 
const QgsGeometry &geometry, 
double snapTolerance, 
const QList<QgsGeometry> &referenceGeometries, 
SnapMode mode = PreferNodes );
    86     void featureSnapped();
    89     struct ProcessFeatureWrapper
    95         : instance( _instance )
    96         , snapTolerance( snapTolerance )
    99       void operator()( 
QgsFeature &feature ) { instance->processFeature( feature, snapTolerance, mode ); }
   102     enum PointFlag { SnappedToRefNode, SnappedToRefSegment, Unsnapped };
   108     mutable QMutex mIndexMutex;
   109     mutable QMutex mReferenceLayerMutex;
   157     bool mFirstFeature = 
true;
   158     double mSnapTolerance = 0;
   183     enum SnapType { SnapPoint, SnapEndPoint, SnapSegment };
   188         virtual ~SnapItem() = 
default;
   193         explicit SnapItem( SnapType _type ) : type( _type ) {}
   196     class PointSnapItem : 
public QgsSnapIndex::SnapItem
   199         explicit PointSnapItem( 
const CoordIdx *_idx, 
bool isEndPoint );
   201         const CoordIdx *idx = 
nullptr;
   204     class SegmentSnapItem : 
public QgsSnapIndex::SnapItem
   207         SegmentSnapItem( 
const CoordIdx *_idxFrom, 
const CoordIdx *_idxTo );
   211         const CoordIdx *idxFrom = 
nullptr;
   212         const CoordIdx *idxTo = 
nullptr;
   215     QgsSnapIndex( 
const QgsPoint &origin, 
double cellSize );
   218     QgsSnapIndex( 
const QgsSnapIndex &rh ) = 
delete;
   219     QgsSnapIndex &operator=( 
const QgsSnapIndex &rh ) = 
delete;
   223     SnapItem *getSnapItem( 
const QgsPoint &pos, 
double tol, PointSnapItem **pSnapPoint = 
nullptr, SegmentSnapItem **pSnapSegment = 
nullptr, 
bool endPointOnly = 
false ) 
const;
   226     typedef QList<SnapItem *> Cell;
   227     typedef QPair<QgsPoint, QgsPoint> Segment;
   234         const Cell *getCell( 
int col ) 
const;
   235         Cell &getCreateCell( 
int col );
   236         QList<SnapItem *> getSnapItems( 
int colStart, 
int colEnd ) 
const;
   239         QList<QgsSnapIndex::Cell> mCells;
   240         int mColStartIdx = 0;
   246     QList<CoordIdx *> mCoordIdxs;
   247     QList<GridRow> mGridRows;
   250     void addPoint( 
const CoordIdx *idx, 
bool isEndPoint );
   251     void addSegment( 
const CoordIdx *idxFrom, 
const CoordIdx *idxTo );
   252     const Cell *getCell( 
int col, 
int row ) 
const;
   253     Cell &getCreateCell( 
int col, 
int row );
   261 #endif // QGS_GEOMETRY_SNAPPER_H QMap< QgsFeatureId, QgsGeometry > QgsGeometryMap
QList< QgsFeature > QgsFeatureList
Only snap the start/end points of lines to other start/end points of lines. 
A geometry is the spatial representation of a feature. 
The feature class encapsulates a single feature including its id, geometry and a list of field/values...
QgsPoint vertexAt(QgsVertexId) const override
Returns the point corresponding to a specified vertex id. 
Utility class for identifying a unique vertex within a geometry. 
Only snap start/end points of lines (point features will also be snapped, polygon features will not b...
QgsGeometrySnapper allows a geometry to be snapped to the geometries within a different reference lay...
Abstract base class for all geometries. 
Point geometry type, with support for z-dimension and m-values. 
Prefer to snap to nodes, even when a segment may be closer than a node. New nodes will be inserted to...
A spatial index for QgsFeature objects. 
Snap to closest point, regardless of it is a node or a segment. New nodes will be inserted to make ge...
An interface for objects which provide features via a getFeatures method. 
Prefer to snap to nodes, even when a segment may be closer than a node. No new nodes will be inserted...
Only snap start/end points of lines (point features will also be snapped, polygon features will not b...
Represents a vector layer which manages a vector based data sets. 
Snap to closest point, regardless of it is a node or a segment. No new nodes will be inserted...
QgsGeometryMap snappedGeometries() const
Returns a QgsGeometryMap of all feature geometries snapped by this object. 
QgsInternalGeometrySnapper allows a set of geometries to be snapped to each other.