本文整理匯總了Python中qgis.core.QgsGeometryValidator.start方法的典型用法代碼示例。如果您正苦於以下問題:Python QgsGeometryValidator.start方法的具體用法?Python QgsGeometryValidator.start怎麽用?Python QgsGeometryValidator.start使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類qgis.core.QgsGeometryValidator
的用法示例。
在下文中一共展示了QgsGeometryValidator.start方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: MapToolCapture
# 需要導入模塊: from qgis.core import QgsGeometryValidator [as 別名]
# 或者: from qgis.core.QgsGeometryValidator import start [as 別名]
#.........這裏部分代碼省略.........
def _undo(self):
if (self._rubberBand is not None):
rubberBandSize = self._rubberBand.numberOfVertices()
moveRubberBandSize = self._moveRubberBand.numberOfVertices()
if (rubberBandSize < 1 or len(self._mapPointList) < 1):
return
self._rubberBand.removePoint(-1)
if (rubberBandSize > 1):
if (moveRubberBandSize > 1):
point = self._rubberBand.getPoint(0, rubberBandSize - 2)
self._moveRubberBand.movePoint(moveRubberBandSize - 2, point)
else:
self._moveRubberBand.reset(self.geometryType())
self._mapPointList.pop()
self._validateGeometry()
def resetCapturing(self):
if (self._rubberBand is not None):
self._rubberBand.reset(self.geometryType())
if (self._moveRubberBand is not None):
self._moveRubberBand.reset(self.geometryType())
self._deleteGeometryValidation()
del self._mapPointList[:]
self.canvas().refresh()
def _deleteGeometryValidation(self):
if (self._validator is not None):
self._validator.errorFound.disconnect(self._addGeometryError)
self._validator.finished.disconnect(self.validationFinished)
self._validator.deleteLater()
self._validator = None
for errorMarker in self._geometryErrorMarkers:
self.canvas().scene().removeItem(errorMarker)
del self._geometryErrorMarkers[:]
self._geometryErrors[:]
self._tip = ''
def _validateGeometry(self):
geometryType = self.geometryType()
if (geometryType == QGis.Point
or geometryType == QGis.UnknownGeometry
or geometryType == QGis.NoGeometry
or len(self._mapPointList) < 2):
return
settings = QSettings()
if (settings.value('/qgis/digitizing/validate_geometries', 1) == 0):
return
self._deleteGeometryValidation()
geometry = None # QgsGeometry()
if (geometryType == QGis.Line):
geometry = QgsGeometry.fromPolyline(self._mapPointList)
elif (geometryType == QGis.Polygon):
if (len(self._mapPointList) < 3):
return
closed = list(self._mapPointList)
closed.append(self._mapPointList[0])
geometry = QgsGeometry.fromPolygon([closed])
if (geometry is None):
return
self._validator = QgsGeometryValidator(geometry)
self._validator.errorFound.connect(self._addGeometryError)
self._validator.finished.connect(self.validationFinished)
self._validator.start()
self._iface.mainWindow().statusBar().showMessage(self.tr('Geometry validation started.'))
def _addGeometryError(self, error):
self._geometryErrors.append(error)
if (self._tip != ''):
self._tip += '\n'
self._tip += error.what()
if (error.hasWhere()):
marker = QgsVertexMarker(self.canvas())
marker.setCenter(error.where())
marker.setIconType(QgsVertexMarker.ICON_X)
marker.setPenWidth(2)
marker.setToolTip(error.what())
marker.setColor(Qt.green)
marker.setZValue(marker.zValue() + 1)
self._geometryErrorMarkers.append(marker)
self._iface.mainWindow().statusBar().showMessage(error.what())
if (self._tip != ''):
self._iface.mainWindow().statusBar().setToolTip(self._tip)
def validationFinished(self):
self._iface.mainWindow().statusBar().showMessage(self.tr('Geometry validation finished.'))