Skip to content
Snippets Groups Projects
maptools.py 7.16 KiB
Newer Older
  • Learn to ignore specific revisions
  • unknown's avatar
    unknown committed
    from qgis.core import *
    from qgis.gui import *
    import qgis
    from PyQt4.QtCore import *
    from PyQt4.QtGui import *
    
    from PyQt4.QtXml import *
    from PyQt4.QtXmlPatterns import *
    
    import six
    
    from timeseriesviewer import SETTINGS
    
    Benjamin Jakimow's avatar
    Benjamin Jakimow committed
    from timeseriesviewer.main import SpatialExtent
    
    
    
    class CursorLocationValueMapTool(QgsMapTool):
        sigLocationIdentified = pyqtSignal(list)
        sigLocationRequest = pyqtSignal(QgsPoint, QgsCoordinateReferenceSystem)
        def __init__(self, canvas):
            self.canvas = canvas
            self.layerType = QgsMapToolIdentify.AllLayers
            self.identifyMode = QgsMapToolIdentify.LayerSelection
            QgsMapToolIdentify.__init__(self, canvas)
    
    
        def canvasReleaseEvent(self, mouseEvent):
            x = mouseEvent.x()
            y = mouseEvent.y()
            point = self.canvas.getCoordinateTransform().toMapCoordinates(x,y)
            crs = self.canvas.mapRenderer().destinationCrs()
            self.sigLocationRequest.emit(point, crs)
    
    
    
    unknown's avatar
    unknown committed
    class PointMapTool(QgsMapToolEmitPoint):
    
    
    Benjamin Jakimow's avatar
    Benjamin Jakimow committed
        sigCoordinateSelected = pyqtSignal(QgsPoint, QgsCoordinateReferenceSystem)
    
    unknown's avatar
    unknown committed
    
        def __init__(self, canvas):
    
    unknown's avatar
    unknown committed
            self.canvas = canvas
            QgsMapToolEmitPoint.__init__(self, self.canvas)
            self.marker = QgsVertexMarker(self.canvas)
    
    unknown's avatar
    unknown committed
    
    
        def setStyle(self):
            color = QColor(SETTINGS.value('map_tool_color', Qt.red))
            penWidth = 3
            iconSize = 5
            iconType = QgsVertexMarker.ICON_CROSS
    
    Benjamin Jakimow's avatar
    Benjamin Jakimow committed
            self.marker.setColor(color)
            self.marker.setPenWidth(penWidth)
            self.marker.setIconSize(iconSize)
            self.marker.setIconType(iconType)  # or ICON_CROSS, ICON_X
    
    unknown's avatar
    unknown committed
    
        def canvasPressEvent(self, e):
    
            geoPoint = self.toMapCoordinates(e.pos())
            self.marker.setCenter(geoPoint)
    
    unknown's avatar
    unknown committed
            self.marker.show()
    
        def canvasReleaseEvent(self, e):
    
    
    
            pixelPoint = e.pixelPoint()
            _crs = self.canvas.mapRenderer().destinationCrs()
    
    Benjamin Jakimow's avatar
    Benjamin Jakimow committed
            crs = self.canvas.mapSettings().destinationCrs()
    
    Benjamin Jakimow's avatar
    Benjamin Jakimow committed
            if crs:
    
    
                geoPoint = self.toMapCoordinates(pixelPoint)
                self.marker.setCenter(geoPoint)
                self.sigCoordinateSelected.emit(geoPoint, crs)
    
    Benjamin Jakimow's avatar
    Benjamin Jakimow committed
    
    
    
    class PointLayersMapTool(PointMapTool):
    
        def __init__(self, canvas):
            super(PointLayersMapTool, self).__init__(self, canvas)
            self.layerType = QgsMapToolIdentify.AllLayers
            self.identifyMode = QgsMapToolIdentify.LayerSelection
            QgsMapToolIdentify.__init__(self, canvas)
    
    
    Benjamin Jakimow's avatar
    Benjamin Jakimow committed
    class SpatialExtentMapTool(QgsMapToolEmitPoint):
        from timeseriesviewer.main import SpatialExtent
        sigSpatialExtentSelected = pyqtSignal(SpatialExtent)
    
    
        def __init__(self, canvas):
            self.canvas = canvas
            QgsMapToolEmitPoint.__init__(self, self.canvas)
            self.rubberBand = QgsRubberBand(self.canvas, QGis.Polygon)
            self.setStyle(Qt.red, 1)
            self.reset()
    
        def setStyle(self, color, width):
            self.rubberBand.setColor(color)
            self.rubberBand.setWidth(width)
    
        def reset(self):
            self.startPoint = self.endPoint = None
            self.isEmittingPoint = False
            self.rubberBand.reset(QGis.Polygon)
    
        def canvasPressEvent(self, e):
            self.startPoint = self.toMapCoordinates(e.pos())
            self.endPoint = self.startPoint
            self.isEmittingPoint = True
            self.showRect(self.startPoint, self.endPoint)
    
        def canvasReleaseEvent(self, e):
            self.isEmittingPoint = False
    
            crs = self.canvas.mapSettings().destinationCrs()
            rect = self.rectangle()
    
            self.reset()
    
            if crs is not None and rect is not None:
                extent = SpatialExtent(crs, rect)
                self.rectangleDrawed.emit(extent)
    
    
        def canvasMoveEvent(self, e):
    
            if not self.isEmittingPoint:
                return
    
            self.endPoint = self.toMapCoordinates(e.pos())
            self.showRect(self.startPoint, self.endPoint)
    
        def showRect(self, startPoint, endPoint):
            self.rubberBand.reset(QGis.Polygon)
            if startPoint.x() == endPoint.x() or startPoint.y() == endPoint.y():
                return
    
            point1 = QgsPoint(startPoint.x(), startPoint.y())
            point2 = QgsPoint(startPoint.x(), endPoint.y())
            point3 = QgsPoint(endPoint.x(), endPoint.y())
            point4 = QgsPoint(endPoint.x(), startPoint.y())
    
            self.rubberBand.addPoint(point1, False)
            self.rubberBand.addPoint(point2, False)
            self.rubberBand.addPoint(point3, False)
            self.rubberBand.addPoint(point4, True)    # true to update canvas
            self.rubberBand.show()
    
        def rectangle(self):
            if self.startPoint is None or self.endPoint is None:
                return None
            elif self.startPoint.x() == self.endPoint.x() or self.startPoint.y() == self.endPoint.y():
    
                return None
    
    unknown's avatar
    unknown committed
    
    
    Benjamin Jakimow's avatar
    Benjamin Jakimow committed
            return QgsRectangle(self.startPoint, self.endPoint)
    
    unknown's avatar
    unknown committed
    
    
    Benjamin Jakimow's avatar
    Benjamin Jakimow committed
        #def deactivate(self):
        #   super(RectangleMapTool, self).deactivate()
        #self.deactivated.emit()
    
    unknown's avatar
    unknown committed
    
    
    class RectangleMapTool(QgsMapToolEmitPoint):
    
        rectangleDrawed = pyqtSignal(QgsRectangle, object)
    
    
        def __init__(self, canvas):
            self.canvas = canvas
            QgsMapToolEmitPoint.__init__(self, self.canvas)
            self.rubberBand = QgsRubberBand(self.canvas, QGis.Polygon)
            self.rubberBand.setColor(Qt.red)
            self.rubberBand.setWidth(1)
            self.reset()
    
        def reset(self):
            self.startPoint = self.endPoint = None
            self.isEmittingPoint = False
            self.rubberBand.reset(QGis.Polygon)
    
        def canvasPressEvent(self, e):
            self.startPoint = self.toMapCoordinates(e.pos())
            self.endPoint = self.startPoint
            self.isEmittingPoint = True
            self.showRect(self.startPoint, self.endPoint)
    
        def canvasReleaseEvent(self, e):
            self.isEmittingPoint = False
    
    
    
            wkt = self.canvas.mapSettings().destinationCrs().toWkt()
    
    unknown's avatar
    unknown committed
            r = self.rectangle()
            self.reset()
    
    Benjamin Jakimow's avatar
    Benjamin Jakimow committed
            if wkt is not None and r is not None:
    
                self.rectangleDrawed.emit(r, wkt)
    
    unknown's avatar
    unknown committed
    
    
        def canvasMoveEvent(self, e):
    
            if not self.isEmittingPoint:
                return
    
            self.endPoint = self.toMapCoordinates(e.pos())
            self.showRect(self.startPoint, self.endPoint)
    
        def showRect(self, startPoint, endPoint):
            self.rubberBand.reset(QGis.Polygon)
            if startPoint.x() == endPoint.x() or startPoint.y() == endPoint.y():
                return
    
            point1 = QgsPoint(startPoint.x(), startPoint.y())
            point2 = QgsPoint(startPoint.x(), endPoint.y())
            point3 = QgsPoint(endPoint.x(), endPoint.y())
            point4 = QgsPoint(endPoint.x(), startPoint.y())
    
            self.rubberBand.addPoint(point1, False)
            self.rubberBand.addPoint(point2, False)
            self.rubberBand.addPoint(point3, False)
            self.rubberBand.addPoint(point4, True)    # true to update canvas
            self.rubberBand.show()
    
        def rectangle(self):
            if self.startPoint is None or self.endPoint is None:
                return None
            elif self.startPoint.x() == self.endPoint.x() or self.startPoint.y() == self.endPoint.y():
    
                return None
    
            return QgsRectangle(self.startPoint, self.endPoint)
    
        #def deactivate(self):
        #   super(RectangleMapTool, self).deactivate()
        #self.deactivated.emit()