Skip to main content

Getting Ready for Quantum GIS Plugin Development

Quantum GIS (QGIS) is a desktop GIS application that can be extended with Python plugins. We are going to use Plugin Builder from within QGIS. Plugin Builder is not installed by default. Start QGIS and follow these steps to install Plugin Builder:


Installing Plugin Builder

  1. Select Plugins->Fetch Python Plugins. A QGIS Python Plugin Installer dialog box will open.
  2. Select Repositories tab.
  3. Click on Add 3rd party repositories button. A confirmation dialog box will appear. Click Ok. Another dialog box will appear to fetch the repositories. The dialog box will close itself.
  4. Select Plugins tab.
  5. Select Plugin Builder from the list.
  6. Click on Install Plugin button.

Plugin Builder menu will appear in Plugins menu. Select Plugins->Plugin Builder->Plugin Builder to start the Plugin Builder. A QGIS Plugin Builder dialog box will appear.


Generating QGIS Python plugin file set


We use the Plugin Builder to generate a basic file set for our QGIS Python plugin. Fill in the QGIS Plugin Builder dialog box with our plugin details. Click Ok. Select the directory where we want to keep our plugin. The Plugin Builder will generate the files in the directory we chose and will give us the following instruction (assuming that we name our plugin myplugin):

  1. Copy the entire directory containing your new plugin to the QGIS plugin directory
  2. Compile the ui file using pyuic4 (refer to Compiling our plugin section below) 
  3. Compile the resources file using pyrcc4 (refer to Compiling our plugin section below) 
  4. Test the plugin by enabling it in the QGIS plugin manager (refer to Tesing our plugin section below)
  5. Customize it by editing the implementation file myplugin.py
  6. Create your own custom icon, replacing the default icon.png
  7. Modify your user interface by opening ui_myplugin.ui in Qt Designer (don't forget to compile it with pyuic4 after changing it)
  8. You can use the Makefile to compile your Ui and resource files when you make changes. This requires GNU make (gmake)

Compiling our plugin


See Setting Up PyScripter for Quantum GIS on how to open a command prompt window that we can use to compile our plugin.


1. Compiling resources.qrc into resources.py

pyrcc4 -o resources.py resources.qrc
2. Compiling ui_myplugin.ui into ui_myplugin.py

pyuic4 -o ui_myplugin.py ui_myplugin.ui
We can design our user interface (ui) using Qt Designer which is bundled in Qt SDK. Open ui_myplugin.ui from within Qt Designer. Once we make a ui change we need to recompile it with pyuic4.


Testing our plugin

  1. Compile resources.grc and ui_myplugin.ui.
  2. Select Plugins->Manage Plugins. A QGIS Plugin Manager dialog box will appear.
  3. Select our plugin from the list. Click Ok to install it.
  4. Our plugin menu will appear in Plugins menu. Click on it.

Note: Each time we make changes to our plugin we need to restart QGIS.



Comments

  1. Wish I'd found this POST earlier. THANKS!!

    Only problem was I had to edit myplugin.py line 27 to change "import resources_rc" to "import resources" (i.e. remove the _rc on import of resources.

    ReplyDelete

Post a Comment

Popular posts from this blog

Setting Up PyScripter for Quantum GIS

PyScripter is a general purpose Python Integrated Development Environment (IDE). Quantum GIS (QGIS) is a desktop GIS application that can be extended with Python plugins. Both are open source softwares. We intend to use PyScripter as an IDE to build QGIS Python plugin. We are using PyScripter 2.4.1.0 and QGIS 1.6.0 in Windows. PyScripter does not come with Python. On the other hand, QGIS is built in with Python. Thus, we will setup up PyScripter to use the build in Python in QGIS. We assume both PyScripter and QGIS are already installed. Preparing PyScripter batch file We assume that QGIS is installed in C:\OSGeo4W\ folder and PyScripter is installed in C:\Program Files\PyScripter\ . 1. Copy qgis.bat in C:\OSGeo4W\ bin to pyscripter.bat 2. Edit pyscripter.bat to remove the last line that read something like this start "Quantum GIS" /B "%OSGEO4W_ROOT%"\apps\qgis\bin\qgis.exe %* and replace it with this in one line Start "PyScripter" /B "C:\Progr

MicroSD Card Module with SPI Connection

A MicroSD card can be directly connected to a 3.3v microcontroller without the need of any additional module. However, a cheap module such as shown in the picture above can be handy in terms of wiring and card replacement. Yet, if you get the module from China then you are on your own, you have to figure it out yourself how the module works. The module above needs 5v VCC to operate. The 5v is needed by the 3.3v LM1117 regulator to power the MicroSD card and the 74125 bus buffer (the 14-pin IC in the module above). Hence, the bus buffer is operating at 3.3v. The VCC is connected directly to the input of the regulator and no where else. Thus, the VCC is solely meant for the regulator. The right-side SPI bus (CS, SCK, MOSI & MISO) is connected directly to the 3.3v bus buffer. No line in the SPI bus that is connected to the VCC. Thus, the SPI bus does not follow VCC. The buffer is 5v tolerant so the right-side SPI connection can be driven at either 3.3v or 5v. Hence, the SPI ca

fatal: Couldn't find remote ref master

If you are using Github then  master is now known as main . Whatever you want to do with a master must now be referred to a main . If you search for this error message on the Internet then you will encounter with a lot of old discussions on how to set up your master properly which is probably not what you are looking for. The master  is your problem. Rename it to main . I wrote Git My Way about two years ago. Today I created another Github repository. I got this  "fatal: Couldn't find remote ref master"  error message when I wanted to sync the new repo for the first time with my notebook using the notes I wrote in the blog. All the discussions around the error message I found on the Internet were perplexing. Then I recalled that Github had renamed master to main  due to the master-slave connotation. We always have a master copy of a code, never a slave copy. Now suddenly a word context has been diminished for good. What is going to happen to the existing vast documen