Documentation/4.1/Developers/Tutorials/PythonAndUIFile

From Slicer Wiki
Revision as of 04:41, 12 April 2012 by JChris.FillionR (talk | contribs) (4.0 -> 4.1)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to: navigation, search
Home < Documentation < 4.1 < Developers < Tutorials < PythonAndUIFile

Back to Developers Information


This tutorial will demonstrate how UI file created using QtDesigner can be loaded and used from a python script loaded using the Slicer python interactor.

As depicted below, let's assume you created a UI file where a QLineEdit and QPushButton are layout horizontally.

Example of UI file with a QPushButton and QLineEdit

Loading the UI file and accessing the associated objects can be done using QUILoader.

The following code snippet aims at loading the UI file and connecting the associated QPushButton and QLineEdit.

# Load UI file
uiloader = qt.QUiLoader()
file = qt.QFile("/home/jchris/Projects/sandbox/qSlicerLineEditWidget.ui")
file.open(qt.QFile.ReadOnly)
line_edit_widget = uiloader.load(file)
file.close()

# Get references to both the QPushButton and the QLineEdit
clear_button = line_edit_widget.findChild(qt.QPushButton, 'ClearButton')
line_edit = line_edit_widget.findChild(qt.QLineEdit, 'LineEdit')

clear_button.connect('clicked()', line_edit, 'clear()')

line_edit_widget.show() 

Idea of possible improvements

  • Instead of obtaining the reference using findChild, it use an helper (to be named properly) to ease the access to members.

For example:

line_edit_widget = HELPER(uiloader.load(file))
line_edit_widget.ClearButton.connect('clicked()', line_edit_widget.LineEdit, 'clear()')

or how about

designedFile = HELPER(fileName.ui)