blob: 95cd1c7712e7c988379ec0b917d4de112bcbdc36 [file] [log] [blame]
Georg Brandl116aa622007-08-15 14:28:22 +00001.. _tkinter:
2
3*********************************
4Graphical User Interfaces with Tk
5*********************************
6
7.. index::
8 single: GUI
9 single: Graphical User Interface
10 single: Tkinter
11 single: Tk
12
13Tk/Tcl has long been an integral part of Python. It provides a robust and
14platform independent windowing toolkit, that is available to Python programmers
Guilherme Polo5f238482009-01-28 14:41:10 +000015using the :mod:`tkinter` package, and its extension, the :mod:`tkinter.tix` and
16the :mod:`tkinter.ttk` modules.
Georg Brandl116aa622007-08-15 14:28:22 +000017
Georg Brandlac6060c2008-05-17 18:44:45 +000018The :mod:`tkinter` package is a thin object-oriented layer on top of Tcl/Tk. To
19use :mod:`tkinter`, you don't need to write Tcl code, but you will need to
Georg Brandl116aa622007-08-15 14:28:22 +000020consult the Tk documentation, and occasionally the Tcl documentation.
Georg Brandlac6060c2008-05-17 18:44:45 +000021:mod:`tkinter` is a set of wrappers that implement the Tk widgets as Python
Georg Brandl116aa622007-08-15 14:28:22 +000022classes. In addition, the internal module :mod:`_tkinter` provides a threadsafe
23mechanism which allows Python and Tcl to interact.
24
Georg Brandlac6060c2008-05-17 18:44:45 +000025:mod:`tkinter`'s chief virtues are that it is fast, and that it usually comes
Georg Brandl48310cd2009-01-03 21:18:54 +000026bundled with Python. Although its standard documentation is weak, good
27material is available, which includes: references, tutorials, a book and
28others. :mod:`tkinter` is also famous for having an outdated look and feel,
29which has been vastly improved in Tk 8.5. Nevertheless, there are many other
30GUI libraries that you could be interested in. For more information about
Alexandre Vassalotti8ae3e052008-05-16 00:41:41 +000031alternatives, see the :ref:`other-gui-packages` section.
Georg Brandl116aa622007-08-15 14:28:22 +000032
33.. toctree::
Georg Brandl48310cd2009-01-03 21:18:54 +000034
Georg Brandl116aa622007-08-15 14:28:22 +000035 tkinter.rst
Guilherme Polo5f238482009-01-28 14:41:10 +000036 tkinter.ttk.rst
Georg Brandlac6060c2008-05-17 18:44:45 +000037 tkinter.tix.rst
38 tkinter.scrolledtext.rst
Georg Brandl116aa622007-08-15 14:28:22 +000039 idle.rst
40 othergui.rst
41
Christian Heimes5b5e81c2007-12-31 16:14:33 +000042.. Other sections I have in mind are
43 Tkinter internals
44 Freezing Tkinter applications
Georg Brandl116aa622007-08-15 14:28:22 +000045
46