Python konsolundan çokgenler nasıl çizilir?


Yanıtlar:


27

gerçekten karmaşık değil , vektörde Bellek sağlayıcısına bakın ::

  • Bir nokta ile oluşturulur QgsPoint(x,y)veQgsGeometry.fromPoint(QgsPoint(x,y))
  • iki noktalı bir çizgi oluşturulur: QgsGeometry.fromPolyline([QgsPoint(x1,y1),QgsPoint(x2,y2)]))
  • bir nokta listesi içeren bir çokgen oluşturulur: QgsGeometry.fromPolygon([[QgsPoint(x1,y1),QgsPoint(x2,y2), QgsPoint(x3,y3)]])

1) iki nokta:

# create a memory layer with two points
layer =  QgsVectorLayer('Point', 'points' , "memory")
pr = layer.dataProvider() 
# add the first point
pt = QgsFeature()
point1 = QgsPoint(50,50)
pt.setGeometry(QgsGeometry.fromPoint(point1))
pr.addFeatures([pt])
# update extent of the layer
layer.updateExtents()
# add the second point
pt = QgsFeature()
point2 = QgsPoint(100,150)
pt.setGeometry(QgsGeometry.fromPoint(point2))
pr.addFeatures([pt])
# update extent
layer.updateExtents()
# add the layer to the canvas
QgsMapLayerRegistry.instance().addMapLayers([layer])

resim açıklamasını buraya girin

2) iki noktayı birleştiren çizgi

layer =  QgsVectorLayer('LineString', 'line' , "memory")
pr = layer.dataProvider() 
line = QgsFeature()
line.setGeometry(QgsGeometry.fromPolyline([point1,point2]))
pr.addFeatures([line])
layer.updateExtents()
QgsMapLayerRegistry.instance().addMapLayers([layer])

resim açıklamasını buraya girin

3) noktaları kapsayan bir çokgen

layer =  QgsVectorLayer('Polygon', 'poly' , "memory")
pr = layer.dataProvider() 
poly = QgsFeature()
points = [point1,QgsPoint(50,150),point2,QgsPoint(100,50)]
# or points = [QgsPoint(50,50),QgsPoint(50,150),QgsPoint(100,150),QgsPoint(100,50)] 
poly.setGeometry(QgsGeometry.fromPolygon([points]))
pr.addFeatures([poly])
layer.updateExtents()
QgsMapLayerRegistry.instance().addMapLayers([layer])

resim açıklamasını buraya girin

-

QGIS 3.0 ve sonrasındaki değişiklikler:

QGIS 3.0 ve sonrası için yukarıdaki iş akışı hala doğrudur, ancak bazı işlevler değişmiştir. Bkz. Https://qgis.org/api/api_break.html

Yukarıdaki kodu güncellemek için aşağıdaki işlevleri değiştirin:

QgsPoint -> QgsPointXY
QgsfromPoint -> QgsfromPointXY
QgsfromPolyline -> QgsfromPolylineXY
QgsfromPolygon -> QgsfromPolylineXY
QgsfromPolyline -> QgsfromPolylineXY
QgsMapLayerRegistry -> QgsProject

Kod için çok teşekkür ederim. Ben kodu çalıştırdıktan sonra CRS seçim iletişim kutusundan nasıl kurtulabilirsiniz merak ediyordum?
wannik

nasıl stil ekleyebilirim?
cjahangir

Bu güncelleştirme benim için son derece yararlıydı - dokümantasyonda bulamıyordum - bu cevabı şu anda araçlarım için birkaç kez kullandım. Çok teşekkürler!
GIS_py

3

Katman tanımında CRS'yi seçmeniz yeterlidir: QgsVectorLayer('Polygon?crs=epsg:2154', 'poly' , "memory")örneğin (burada EPSG 2154, Metropolitan Fransa'da standart olan Lambert 93 projeksiyonu içindir, ancak istediğinizi koyabilirsiniz)


nasıl stil ekleyebilirim?
cjahangir
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.