GIS and Media fusion

"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

User Tools

Site Tools


geoinf18:wktplugin

WKTEditor plugin pour QGIS

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.

Pré-requis

  • le tutoriel précédent de prise en main de la console Python dans QGIS
  • l'installation des plugins Plugin Builder et Plugin Reloader - voir Chapitre 2.2 Installation des outils du tutoriel INSIT - voir aussi l'introduction de ce tutoriel INSIT

Créer un plugin

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.

D'après la marche à suivre, avant de pouvoir tester le plugin de base, il faut transformer le fichier resources.qrc avec la commande pyrcc5 (pour l'intégration de ressources telles que des icônes et des fichiers de traduction dans une application) :

pyrcc5 -o resources.py resources.qrc

En cas de problème, le fichier resources.py résultat pour PyQt5 disponible ci-dessous pourrait aussi convenir :
https://drive.switch.ch/index.php/s/jHcUvhFSRwEneES

Modifier l'UI du plugin

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.

  • installez ces outils et customisez l'interface à votre goût
  • ou ajoutez simplement la widget suivante dans votre fichier .ui
  <widget class="QPlainTextEdit" name="plainTextEdit">
   <property name="geometry">
    <rect>
     <x>30</x>
     <y>50</y>
     <width>341</width>
     <height>181</height>
    </rect>
   </property>
  </widget>
  • son identifiant d'objet est plainTextEdit, il est possible de le manipuler avec les instructions ci-dessous dans la logique du plugin (script python NomDeMonPlugin.py).
  • voir aussi la documentation Qt : http://doc.qt.io/

Notez bien : pour voir le résultat des modifications sans relancer QGIS, le plugin Reloader est bien utile !

Logique du plugin

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) :

  • on ajoute une instruction print dans la condition qui contrôle le comportement du bouton OK
print('Button OK of the plugin is successfully pushed!')
  • on reload, on lance le plugin, on clique OK et le message apparait dans le console Python

La méthode Qt5 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

NB: sans oublier d'ajouter en entête les imports qui vont bien :

# Import QGIS stuff
from qgis.core import *
from qgis.utils import *

Tester

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)

geoinf18/wktplugin.txt · Last modified: 2018/11/13 10:14 by oertz