QGIS:通过输入坐标添加多边形

时间:2017-04-28 07:38:33

标签: qgis

简单的问题,我想编辑一个图层来添加一个正方形:

x,y
10,10
10,20
20,20
20,10

但是我不想把它放到csv / txt文件中,我只是想一次输入一个坐标并构造多边形,任何想法?

4 个答案:

答案 0 :(得分:1)

不完全确定您的意思,但您可以使用coords创建一个众所周知的文本文件:

"id","st_astext" 3,"POLYGON((380021.900198576 277004.918072763,380001.683890889 276942.789907678,380057.895087871

然后导入csv?

答案 1 :(得分:1)

感谢您的回答,但很明显QGIS没有添加单个坐标的插件(就像ArcGIS使用F6快捷键一样)。

答案 2 :(得分:0)

这是一个简单的例子,但我相信要理解这个问题。

我有一个简单的插件,这会加载多边形图层(注意:只有一个)并且这是空的,并使用此模式" x0,y0; x1,y1来插入新的多边形。 ..; X0,Y0"

并输入以下值:

<强> -4.6142578125,39.40224434029275; -2.6806640625,39.40224434029275; -2.6806640625,40.97989806962013; -4.6142578125,40.97989806962013; -4.6142578125,39.40224434029275

点击&#34; Aceptar&#34;按钮添加新的多边形。

这是 run()方法:

def run(self):
    self.dlg.cmb_TOC.clear()
    self.dlg.input_ln.clear()
    layers = self.iface.legendInterface().layers()
    layer_list = []
    for layer in layers:
        layerType = layer.type()
        if layerType == QgsMapLayer.VectorLayer and layer.wkbType()==QGis.WKBPolygon:

            layer_list.append(layer.name())
            self.dlg.cmb_TOC.addItems(layer_list)

    """Run method that performs all the real work"""
    # show the dialog
    self.dlg.show()
    # Run the dialog event loop
    result = self.dlg.exec_()
    # See if OK was pressed
    if result == 1:   
        if unicode(self.dlg.cmb_TOC.currentText())=="" or self.dlg.input_ln.text()=="":
            self.iface.messageBar().pushMessage("Info", "Empty parameters", level=QgsMessageBar.WARNING, duration=3)
            return 1

        t_e="-4.6142578125,39.40224434029275;-2.6806640625,39.40224434029275;-2.6806640625,40.97989806962013;-4.6142578125,40.97989806962013;-4.6142578125,39.40224434029275"   
        t_e=self.dlg.input_ln.text()

        v=t_e.rstrip('\n').split(';')

        #Create New Polygon
        points =[]

        for p in v:             
            point=QgsPoint( float(p.split(',')[0]), float(p.split(',')[1]))
            points.append(point)

        polygon = QgsGeometry.fromPolygon([points]) 

        selectedLayerIndex = self.dlg.cmb_TOC.currentIndex()
        selectedLayer = layers[selectedLayerIndex]

        pr = selectedLayer.dataProvider() 
        poly = QgsFeature()
        poly.setGeometry(polygon)
        pr.addFeatures([poly])
        selectedLayer.updateExtents()
        selectedLayer.triggerRepaint()

我希望它有所帮助

注意:我重复使用了另一个例子

答案 3 :(得分:-1)

如果使用python

,则通过python创建一个多边形
  • 制作一个json dict