"The explosive growth of the GeoWeb and geographic information has made GIS powerful media for the general public to communicate, but perhaps more importantly, GIS have also become media for constructive dialogs and interactions about social issues." - Sui & Goodchild
This is an old revision of the document!
Objectif : créer un plugin permettant d'ajouter des entités géographiques formalisées avec le format WKT dans la couche sélectionnée dans la table des couches.
Initialiser un dossier de configuration d'un nouveau plugin avec le Plugin Builder préalablement installé et selon le Chapitre 2.3.3 Marche à suivre – structure du plugin du tutoriel INSIT.
Dans le Chapitre 2.3.4 Marche à suivre – interface graphique du plugin du tutoriel INSIT est indiqué que l'UI a été initialisée par le builder dans le fichier avec l'extension .ui. Aussi que ce fichier peut être modifié avec les outils Qt (QtDesigner ou QtCreator) pour ajouter des éléments d'interface.
<widget class="QPlainTextEdit" name="plainTextEdit"> <property name="geometry"> <rect> <x>30</x> <y>50</y> <width>341</width> <height>181</height> </rect> </property> </widget>
D'après le chapitre 2.3.5 Marche à suivre – code Python du plugin du tutoriel INSIT, tout se passe dans la fonction run (tout en bas du script) :
print('Button OK of the plugin is successfully pushed!')
La méthode toPlainText renvoie le contenu du champ texte de la boîte de dialogue
mywkt = self.dlg.plainTextEdit.toPlainText() print('Content: ' + mywkt)
Supposant que ce contenu est une représentation WKT d'une géométrie, il est possible d'ajouter à la couche sélectionnée une entité géographique portant cette géométrie comme suit :
layer = iface.activeLayer() # load the current selected layer mywkt = self.dlg.plainTextEdit.toPlainText() # get the WKT content in the textfield layer.startEditing() # set the layer in edit mode geom = QgsGeometry() # create an empty geometry geom = QgsGeometry.fromWkt(mywkt) # parse the WKT content to initialize the geometry feat = QgsFeature() # create an empty feature feat.setGeometry(geom) # attach the geometry to the feature layer.dataProvider().addFeatures([feat]) # add the new feature to the layer layer.commitChanges() # save changes
Pour tester le plugin, il faut sélectionner une couche dans la table des couches (soit en créant une couche vide ou en ajoutant une source de données existantes, ex. shapefile). Le type de géométrie de la couche que l'on souhaite alimenter est important, il doit y avoir adéquation entre le type de géométrie décrit par la représentation WKT et le type de la couche sélectionnée (POINT, LINE, POLYGON).
Quelques WKT pour tester :
POINT(6.644375 46.78025) POINT(6.64711 46.784599) POLYGON((6.646721 46.781629,6.647439 46.781350,6.647354 46.781159,6.647836 46.781012,6.648148 46.781291,6.648309 46.781240,6.647579 46.780343,6.646131053352633 46.780916,6.646721 46.781629)) POLYGON((6.659504 46.780179,6.657723 46.778783,6.659976 46.778298,6.660749 46.778761,6.661017 46.780407,6.659912 46.779885,6.659504 46.780179)) LINESTRING(6.647343 46.781315,6.649264 46.781624,6.655175 46.779420,6.655765 46.778472,6.659059 46.778964) LINESTRING(6.647370 46.781338,6.646330 46.781316,6.644742 46.781838,6.643176 46.780236,6.641062 46.780993,6.641448 46.781397)
Notez bien : les coordonnées sont en longitude/latitude WGS84 (EPSG:4326)