16 #ifndef QGSPOINTLOCATOR_H 
   17 #define QGSPOINTLOCATOR_H 
   25 #include "qgis_core.h" 
   85   class IStorageManager;
 
  162       MiddleOfSegment = 1 << 4, 
 
  163       LineEndpoint = 1 << 5, 
 
  164       All = Vertex | Edge | Area | Centroid | MiddleOfSegment 
 
  167     Q_DECLARE_FLAGS( Types, Type )
 
  182     bool init( 
int maxFeaturesToIndex = -1, 
bool relaxed = 
false );
 
  185     bool hasIndex() 
const;
 
  198           , mVertexIndex( vertexIndex )
 
  202             mEdgePoints[0] = edgePoints[0];
 
  203             mEdgePoints[1] = edgePoints[1];
 
  209         bool isValid()
 const { 
return mType != Invalid; }
 
  213         bool hasEdge()
 const { 
return mType == Edge; }
 
  217         bool hasArea()
 const { 
return mType == Area; }
 
  257           pt1 = mEdgePoints[0];
 
  258           pt2 = mEdgePoints[1];
 
  269           const QgsGeometry geom = mLayer->getGeometry( mFid );
 
  281           return mType == other.
mType &&
 
  282                  mDist == other.
mDist &&
 
  285                  mFid == other.
mFid &&
 
  298         int mVertexIndex = 0; 
 
  307     typedef QList<QgsPointLocator::Match> 
MatchList;
 
  428     void waitForIndexingFinished();
 
  440     bool rebuildIndex( 
int maxFeaturesToIndex = -1 );
 
  445     void onInitTaskFinished();
 
  449     void onAttributeValueChanged( 
QgsFeatureId fid, 
int idx, 
const QVariant &value );
 
  457     bool prepare( 
bool relaxed );
 
  460     std::unique_ptr< SpatialIndex::IStorageManager > mStorage;
 
  462     QHash<QgsFeatureId, QgsGeometry *> mGeoms;
 
  463     std::unique_ptr< SpatialIndex::ISpatialIndex > mRTree;
 
  466     bool mIsEmptyLayer = 
false;
 
  472     std::unique_ptr< QgsRectangle > mExtent;
 
  474     std::unique_ptr<QgsRenderContext> mContext;
 
  475     std::unique_ptr<QgsFeatureRenderer> mRenderer;
 
  476     std::unique_ptr<QgsVectorLayerFeatureSource> mSource;
 
  477     int mMaxFeaturesToIndex = -1;
 
  478     bool mIsIndexing = 
false;
 
  479     bool mIsDestroying = 
false;
 
  482     QPointer<QgsPointLocatorInitTask> mInitTask;
 
  491     friend class QgsPointLocatorInitTask;
 
  492     friend class TestQgsPointLocator;
 
This class represents a coordinate reference system (CRS).
Contains information about the context in which a coordinate transform is executed.
static QgsPoint closestPoint(const QgsAbstractGeometry &geometry, const QgsPoint &point)
Returns the nearest point on a segment of a geometry for the specified point.
A geometry is the spatial representation of a feature.
QgsPoint vertexAt(int atVertex) const
Returns coordinates of a vertex.
bool isEmpty() const
Returns true if the geometry is empty (eg a linestring with no vertices, or a collection with no geom...
Line string geometry type, with support for z-dimension and m-values.
Helper class used when traversing the index with areas - builds a list of matches.
Helper class used when traversing the index looking for centroid - builds a list of matches.
Helper class used when traversing the index looking for edges - builds a list of matches.
Helper class used when traversing the index looking for middle segment - builds a list of matches.
Helper class used when traversing the index looking for centroid - builds a list of matches.
Helper class used when traversing the index looking for edges - builds a list of matches.
Helper class used when traversing the index looking for line endpoints (start or end vertex) - builds...
Helper class used when traversing the index looking for middle segment - builds a list of matches.
Helper class used when traversing the index looking for vertices - builds a list of matches.
Helper class used when traversing the index looking for vertices - builds a list of matches.
The class defines interface for querying point location:
const QgsRectangle * extent() const
Gets extent of the area point locator covers - if nullptr then it caches the whole layer.
int cachedGeometryCount() const
Returns how many geometries are cached in the index.
class QList< QgsPointLocator::Match > MatchList
QgsVectorLayer * layer() const
Gets associated layer.
bool isIndexing() const
Returns true if the point locator is currently indexing the data.
void initFinished(bool ok)
Emitted whenever index has been built and initialization is finished.
Type
The type of a snap result or the filter type for a snap request.
A class to represent a 2D point.
Point geometry type, with support for z-dimension and m-values.
A rectangle specified with double values.
Contains information about the context of a rendering operation.
Partial snapshot of vector layer's state (only the members necessary for access to features)
Represents a vector layer which manages a vector based data sets.
QSet< QgsFeatureId > QgsFeatureIds
qint64 QgsFeatureId
64 bit feature ids negative numbers are used for uncommitted/newly added features
Interface that allows rejection of some matches in intersection queries (e.g.
virtual bool acceptMatch(const QgsPointLocator::Match &match)=0
virtual ~MatchFilter()=default
QgsVectorLayer * layer() const
The vector layer where the snap occurred.
QgsFeatureId featureId() const
The id of the feature to which the snapped geometry belongs.
bool hasCentroid() const
Returns true if the Match is a centroid.
double distance() const
for vertex / edge match units depending on what class returns it (geom.cache: layer units,...
QgsPointXY mMiddleOfSegment
QgsPointXY point() const
for vertex / edge match coords depending on what class returns it (geom.cache: layer coords,...
bool hasEdge() const
Returns true if the Match is an edge.
void edgePoints(QgsPointXY &pt1, QgsPointXY &pt2) const
Only for a valid edge match - obtain endpoints of the edge.
bool hasArea() const
Returns true if the Match is an area.
QgsPoint interpolatedPoint() const
Convenient method to return a point on an edge with linear interpolation of the Z value.
Match()=default
construct invalid match
Match(QgsPointLocator::Type t, QgsVectorLayer *vl, QgsFeatureId fid, double dist, const QgsPointXY &pt, int vertexIndex=0, QgsPointXY *edgePoints=nullptr)
QgsPointLocator::Type type() const
QgsPointXY mEdgePoints[2]
bool hasLineEndpoint() const
Returns true if the Match is a line endpoint (start or end vertex).
bool hasMiddleSegment() const
Returns true if the Match is the middle of a segment.
int vertexIndex() const
for vertex / edge match (first vertex of the edge)
bool hasVertex() const
Returns true if the Match is a vertex.
bool operator==(const QgsPointLocator::Match &other) const