blob: 405f041f6c9557f78bc8f64b793d181ef51735df [file] [log] [blame]
Fred Drake10cd3152001-11-30 18:17:24 +00001\chapter{Graphical User Interfaces with Tk \label{tkinter}}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00002
3\index{GUI}
4\index{Graphical User Interface}
5\index{Tkinter}
6\index{Tk}
7
8Tk/Tcl has long been an integral part of Python. It provides a robust
9and platform independent windowing toolkit, that is available to
10Python programmers using the \refmodule{Tkinter} module, and its
11extension, the \refmodule{Tix} module.
12
Raymond Hettinger68804312005-01-01 00:28:46 +000013The \refmodule{Tkinter} module is a thin object-oriented layer on top of
Fred Drake7cf4e5b2001-11-15 17:22:04 +000014Tcl/Tk. To use \refmodule{Tkinter}, you don't need to write Tcl code,
15but you will need to consult the Tk documentation, and occasionally
16the Tcl documentation. \refmodule{Tkinter} is a set of wrappers that
17implement the Tk widgets as Python classes. In addition, the internal
18module \module{\_tkinter} provides a threadsafe mechanism which allows
19Python and Tcl to interact.
20
Fred Drake666ca802001-11-16 06:02:55 +000021Tk is not the only GUI for Python, but is however the most commonly
22used one; see section~\ref{other-gui-modules}, ``Other User Interface
23Modules and Packages,'' for more information on other GUI toolkits for
24Python.
Fred Drake7cf4e5b2001-11-15 17:22:04 +000025
26% Other sections I have in mind are
27% Tkinter internals
28% Freezing Tkinter applications
29
30\localmoduletable
31
32
Fred Drakec66ff202001-11-16 01:05:27 +000033\section{\module{Tkinter} ---
34 Python interface to Tcl/Tk}
Fred Drake7cf4e5b2001-11-15 17:22:04 +000035
36\declaremodule{standard}{Tkinter}
37\modulesynopsis{Interface to Tcl/Tk for graphical user interfaces}
38\moduleauthor{Guido van Rossum}{guido@Python.org}
39
40The \module{Tkinter} module (``Tk interface'') is the standard Python
Fred Drake691fb552002-09-10 21:59:17 +000041interface to the Tk GUI toolkit. Both Tk and \module{Tkinter} are
42available on most \UNIX{} platforms, as well as on Windows and
43Macintosh systems. (Tk itself is not part of Python; it is maintained
44at ActiveState.)
Fred Drake7cf4e5b2001-11-15 17:22:04 +000045
46\begin{seealso}
47\seetitle[http://www.python.org/topics/tkinter/]
48 {Python Tkinter Resources}
49 {The Python Tkinter Topic Guide provides a great
50 deal of information on using Tk from Python and links to
51 other sources of information on Tk.}
52
53\seetitle[http://www.pythonware.com/library/an-introduction-to-tkinter.htm]
54 {An Introduction to Tkinter}
55 {Fredrik Lundh's on-line reference material.}
56
57\seetitle[http://www.nmt.edu/tcc/help/pubs/lang.html]
58 {Tkinter reference: a GUI for Python}
59 {On-line reference material.}
60
61\seetitle[http://jtkinter.sourceforge.net]
62 {Tkinter for JPython}
63 {The Jython interface to Tkinter.}
64
65\seetitle[http://www.amazon.com/exec/obidos/ASIN/1884777813]
66 {Python and Tkinter Programming}
67 {The book by John Grayson (ISBN 1-884777-81-3).}
68\end{seealso}
69
70
71\subsection{Tkinter Modules}
72
Fred Drake666ca802001-11-16 06:02:55 +000073Most of the time, the \refmodule{Tkinter} module is all you really
74need, but a number of additional modules are available as well. The
75Tk interface is located in a binary module named \module{_tkinter}.
76This module contains the low-level interface to Tk, and should never
77be used directly by application programmers. It is usually a shared
78library (or DLL), but might in some cases be statically linked with
79the Python interpreter.
Fred Drake7cf4e5b2001-11-15 17:22:04 +000080
81In addition to the Tk interface module, \refmodule{Tkinter} includes a
82number of Python modules. The two most important modules are the
83\refmodule{Tkinter} module itself, and a module called
84\module{Tkconstants}. The former automatically imports the latter, so
85to use Tkinter, all you need to do is to import one module:
86
87\begin{verbatim}
88import Tkinter
89\end{verbatim}
90
91Or, more often:
92
93\begin{verbatim}
94from Tkinter import *
95\end{verbatim}
96
David Aschere2b4b322004-02-18 05:59:53 +000097\begin{classdesc}{Tk}{screenName=None, baseName=None, className='Tk', useTk=1}
Fred Drake7cf4e5b2001-11-15 17:22:04 +000098The \class{Tk} class is instantiated without arguments.
99This creates a toplevel widget of Tk which usually is the main window
Raymond Hettinger68804312005-01-01 00:28:46 +0000100of an application. Each instance has its own associated Tcl interpreter.
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000101% FIXME: The following keyword arguments are currently recognized:
Neal Norwitz3e0877e2004-02-28 15:19:33 +0000102\versionchanged[The \var{useTk} parameter was added]{2.4}
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000103\end{classdesc}
104
David Aschere2b4b322004-02-18 05:59:53 +0000105\begin{funcdesc}{Tcl}{screenName=None, baseName=None, className='Tk', useTk=0}
106The \function{Tcl} function is a factory function which creates an object
107much like that created by the \class{Tk} class, except that it does not
108initialize the Tk subsystem. This is most often useful when driving the Tcl
109interpreter in an environment where one doesn't want to create extraneous
110toplevel windows, or where one cannot (i.e. Unix/Linux systems without an X
111server). An object created by the \function{Tcl} object can have a Toplevel
112window created (and the Tk subsystem initialized) by calling its
113\method{loadtk} method.
Neal Norwitz3e0877e2004-02-28 15:19:33 +0000114\versionadded{2.4}
David Aschere2b4b322004-02-18 05:59:53 +0000115\end{funcdesc}
116
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000117Other modules that provide Tk support include:
118
119\begin{description}
120% \declaremodule{standard}{Tkconstants}
121% \modulesynopsis{Constants used by Tkinter}
122% FIXME
123
Fred Drake1a763862001-12-03 21:18:30 +0000124\item[\refmodule{ScrolledText}]
125Text widget with a vertical scroll bar built in.
126
Fred Drakec66ff202001-11-16 01:05:27 +0000127\item[\module{tkColorChooser}]
128Dialog to let the user choose a color.
129
130\item[\module{tkCommonDialog}]
Fred Drake04677752001-11-30 19:24:49 +0000131Base class for the dialogs defined in the other modules listed here.
Fred Drakec66ff202001-11-16 01:05:27 +0000132
133\item[\module{tkFileDialog}]
134Common dialogs to allow the user to specify a file to open or save.
135
136\item[\module{tkFont}]
137Utilities to help work with fonts.
138
139\item[\module{tkMessageBox}]
140Access to standard Tk dialog boxes.
141
142\item[\module{tkSimpleDialog}]
143Basic dialogs and convenience functions.
144
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000145\item[\module{Tkdnd}]
146Drag-and-drop support for \refmodule{Tkinter}.
147This is experimental and should become deprecated when it is replaced
148with the Tk DND.
149
150\item[\refmodule{turtle}]
151Turtle graphics in a Tk window.
152
153\end{description}
154
155\subsection{Tkinter Life Preserver}
Fred Drakec66ff202001-11-16 01:05:27 +0000156\sectionauthor{Matt Conway}{}
157% Converted to LaTeX by Mike Clarkson.
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000158
159This section is not designed to be an exhaustive tutorial on either
160Tk or Tkinter. Rather, it is intended as a stop gap, providing some
161introductory orientation on the system.
162
163Credits:
164\begin{itemize}
165\item Tkinter was written by Steen Lumholt and Guido van Rossum.
166\item Tk was written by John Ousterhout while at Berkeley.
167\item This Life Preserver was written by Matt Conway at
168the University of Virginia.
169\item The html rendering, and some liberal editing, was
170produced from a FrameMaker version by Ken Manheimer.
171\item Fredrik Lundh elaborated and revised the class interface descriptions,
172to get them current with Tk 4.2.
173\item Mike Clarkson converted the documentation to \LaTeX, and compiled the
174User Interface chapter of the reference manual.
175\end{itemize}
176
177
178\subsubsection{How To Use This Section}
179
180This section is designed in two parts: the first half (roughly) covers
181background material, while the second half can be taken to the
182keyboard as a handy reference.
183
184When trying to answer questions of the form ``how do I do blah'', it
185is often best to find out how to do``blah'' in straight Tk, and then
186convert this back into the corresponding \refmodule{Tkinter} call.
187Python programmers can often guess at the correct Python command by
188looking at the Tk documentation. This means that in order to use
189Tkinter, you will have to know a little bit about Tk. This document
190can't fulfill that role, so the best we can do is point you to the
191best documentation that exists. Here are some hints:
192
193\begin{itemize}
194\item The authors strongly suggest getting a copy of the Tk man
195pages. Specifically, the man pages in the \code{mann} directory are most
196useful. The \code{man3} man pages describe the C interface to the Tk
197library and thus are not especially helpful for script writers.
198
199\item Addison-Wesley publishes a book called \citetitle{Tcl and the
200Tk Toolkit} by John Ousterhout (ISBN 0-201-63337-X) which is a good
201introduction to Tcl and Tk for the novice. The book is not
202exhaustive, and for many details it defers to the man pages.
203
204\item \file{Tkinter.py} is a last resort for most, but can be a good
205place to go when nothing else makes sense.
206\end{itemize}
207
208\begin{seealso}
209\seetitle[http://tcl.activestate.com/]
210 {ActiveState Tcl Home Page}
211 {The Tk/Tcl development is largely taking place at
212 ActiveState.}
213\seetitle[http://www.amazon.com/exec/obidos/ASIN/020163337X]
214 {Tcl and the Tk Toolkit}
215 {The book by John Ousterhout, the inventor of Tcl .}
216\seetitle[http://www.amazon.com/exec/obidos/ASIN/0130220280]
217 {Practical Programming in Tcl and Tk}
218 {Brent Welch's encyclopedic book.}
219\end{seealso}
220
221
222\subsubsection{A Simple Hello World Program} % HelloWorld.html
223
224%begin{latexonly}
225%\begin{figure}[hbtp]
226%\centerline{\epsfig{file=HelloWorld.gif,width=.9\textwidth}}
227%\vspace{.5cm}
228%\caption{HelloWorld gadget image}
229%\end{figure}
230%See also the hello-world \ulink{notes}{classes/HelloWorld-notes.html} and
231%\ulink{summary}{classes/HelloWorld-summary.html}.
232%end{latexonly}
233
234
235\begin{verbatim}
Fred Drakee5a55512003-05-20 15:21:08 +0000236from Tkinter import *
237
238class Application(Frame):
239 def say_hi(self):
240 print "hi there, everyone!"
241
242 def createWidgets(self):
243 self.QUIT = Button(self)
244 self.QUIT["text"] = "QUIT"
245 self.QUIT["fg"] = "red"
246 self.QUIT["command"] = self.quit
247
248 self.QUIT.pack({"side": "left"})
249
250 self.hi_there = Button(self)
251 self.hi_there["text"] = "Hello",
252 self.hi_there["command"] = self.say_hi
253
254 self.hi_there.pack({"side": "left"})
255
256 def __init__(self, master=None):
257 Frame.__init__(self, master)
258 self.pack()
259 self.createWidgets()
260
Georg Brandl532dacf2005-09-15 16:02:13 +0000261root = Tk()
262app = Application(master=root)
Fred Drakee5a55512003-05-20 15:21:08 +0000263app.mainloop()
Georg Brandl532dacf2005-09-15 16:02:13 +0000264root.destroy()
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000265\end{verbatim}
266
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000267
Fred Drakeb22c6722001-12-03 06:12:23 +0000268\subsection{A (Very) Quick Look at Tcl/Tk} % BriefTclTk.html
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000269
270The class hierarchy looks complicated, but in actual practice,
271application programmers almost always refer to the classes at the very
272bottom of the hierarchy.
273
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000274Notes:
275\begin{itemize}
276\item These classes are provided for the purposes of
277organizing certain functions under one namespace. They aren't meant to
278be instantiated independently.
Fred Drakeb22c6722001-12-03 06:12:23 +0000279
280\item The \class{Tk} class is meant to be instantiated only once in
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000281an application. Application programmers need not instantiate one
282explicitly, the system creates one whenever any of the other classes
283are instantiated.
Fred Drakeb22c6722001-12-03 06:12:23 +0000284
285\item The \class{Widget} class is not meant to be instantiated, it
286is meant only for subclassing to make ``real'' widgets (in \Cpp, this
287is called an `abstract class').
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000288\end{itemize}
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000289
290To make use of this reference material, there will be times when you
291will need to know how to read short passages of Tk and how to identify
292the various parts of a Tk command.
Fred Drake666ca802001-11-16 06:02:55 +0000293(See section~\ref{tkinter-basic-mapping} for the
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000294\refmodule{Tkinter} equivalents of what's below.)
295
296Tk scripts are Tcl programs. Like all Tcl programs, Tk scripts are
297just lists of tokens separated by spaces. A Tk widget is just its
298\emph{class}, the \emph{options} that help configure it, and the
299\emph{actions} that make it do useful things.
300
301To make a widget in Tk, the command is always of the form:
302
303\begin{verbatim}
304 classCommand newPathname options
305\end{verbatim}
306
307\begin{description}
308\item[\var{classCommand}]
309denotes which kind of widget to make (a button, a label, a menu...)
310
311\item[\var{newPathname}]
312is the new name for this widget. All names in Tk must be unique. To
313help enforce this, widgets in Tk are named with \emph{pathnames}, just
314like files in a file system. The top level widget, the \emph{root},
315is called \code{.} (period) and children are delimited by more
316periods. For example, \code{.myApp.controlPanel.okButton} might be
317the name of a widget.
318
319\item[\var{options} ]
320configure the widget's appearance and in some cases, its
321behavior. The options come in the form of a list of flags and values.
322Flags are proceeded by a `-', like unix shell command flags, and
323values are put in quotes if they are more than one word.
324\end{description}
325
326For example:
327
328\begin{verbatim}
329 button .fred -fg red -text "hi there"
330 ^ ^ \_____________________/
331 | | |
332 class new options
333 command widget (-opt val -opt val ...)
334\end{verbatim}
335
336Once created, the pathname to the widget becomes a new command. This
337new \var{widget command} is the programmer's handle for getting the new
338widget to perform some \var{action}. In C, you'd express this as
Fred Drakec66ff202001-11-16 01:05:27 +0000339someAction(fred, someOptions), in \Cpp, you would express this as
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000340fred.someAction(someOptions), and in Tk, you say:
341
342\begin{verbatim}
343 .fred someAction someOptions
344\end{verbatim}
345
346Note that the object name, \code{.fred}, starts with a dot.
347
348As you'd expect, the legal values for \var{someAction} will depend on
349the widget's class: \code{.fred disable} works if fred is a
350button (fred gets greyed out), but does not work if fred is a label
351(disabling of labels is not supported in Tk).
352
353The legal values of \var{someOptions} is action dependent. Some
354actions, like \code{disable}, require no arguments, others, like
355a text-entry box's \code{delete} command, would need arguments
356to specify what range of text to delete.
357
358
359\subsection{Mapping Basic Tk into Tkinter
360 \label{tkinter-basic-mapping}}
361
362Class commands in Tk correspond to class constructors in Tkinter.
363
364\begin{verbatim}
365 button .fred =====> fred = Button()
366\end{verbatim}
367
368The master of an object is implicit in the new name given to it at
369creation time. In Tkinter, masters are specified explicitly.
370
371\begin{verbatim}
372 button .panel.fred =====> fred = Button(panel)
373\end{verbatim}
374
375The configuration options in Tk are given in lists of hyphened tags
376followed by values. In Tkinter, options are specified as
377keyword-arguments in the instance constructor, and keyword-args for
378configure calls or as instance indices, in dictionary style, for
Fred Drake666ca802001-11-16 06:02:55 +0000379established instances. See section~\ref{tkinter-setting-options} on
380setting options.
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000381
382\begin{verbatim}
383 button .fred -fg red =====> fred = Button(panel, fg = "red")
384 .fred configure -fg red =====> fred["fg"] = red
385 OR ==> fred.config(fg = "red")
386\end{verbatim}
387
388In Tk, to perform an action on a widget, use the widget name as a
389command, and follow it with an action name, possibly with arguments
390(options). In Tkinter, you call methods on the class instance to
391invoke actions on the widget. The actions (methods) that a given
392widget can perform are listed in the Tkinter.py module.
393
394\begin{verbatim}
395 .fred invoke =====> fred.invoke()
396\end{verbatim}
397
398To give a widget to the packer (geometry manager), you call pack with
399optional arguments. In Tkinter, the Pack class holds all this
400functionality, and the various forms of the pack command are
401implemented as methods. All widgets in \refmodule{Tkinter} are
402subclassed from the Packer, and so inherit all the packing
403methods. See the \refmodule{Tix} module documentation for additional
404information on the Form geometry manager.
405
406\begin{verbatim}
407 pack .fred -side left =====> fred.pack(side = "left")
408\end{verbatim}
409
410
411\subsection{How Tk and Tkinter are Related} % Relationship.html
412
Fred Drake666ca802001-11-16 06:02:55 +0000413\note{This was derived from a graphical image; the image will be used
414 more directly in a subsequent version of this document.}
415
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000416From the top down:
417\begin{description}
418\item[\b{Your App Here (Python)}]
419A Python application makes a \refmodule{Tkinter} call.
420
421\item[\b{Tkinter (Python Module)}]
422This call (say, for example, creating a button widget), is
423implemented in the \emph{Tkinter} module, which is written in
424Python. This Python function will parse the commands and the
425arguments and convert them into a form that makes them look as if they
426had come from a Tk script instead of a Python script.
427
428\item[\b{tkinter (C)}]
429These commands and their arguments will be passed to a C function
430in the \emph{tkinter} - note the lowercase - extension module.
431
432\item[\b{Tk Widgets} (C and Tcl)]
433This C function is able to make calls into other C modules,
434including the C functions that make up the Tk library. Tk is
435implemented in C and some Tcl. The Tcl part of the Tk widgets is used
436to bind certain default behaviors to widgets, and is executed once at
437the point where the Python \refmodule{Tkinter} module is
438imported. (The user never sees this stage).
439
440\item[\b{Tk (C)}]
441The Tk part of the Tk Widgets implement the final mapping to ...
442
443\item[\b{Xlib (C)}]
444the Xlib library to draw graphics on the screen.
445\end{description}
446
447
448\subsection{Handy Reference}
449
450\subsubsection{Setting Options
451 \label{tkinter-setting-options}}
452
453Options control things like the color and border width of a widget.
454Options can be set in three ways:
455
456\begin{description}
457\item[At object creation time, using keyword arguments]:
458\begin{verbatim}
459fred = Button(self, fg = "red", bg = "blue")
460\end{verbatim}
461\item[After object creation, treating the option name like a dictionary index]:
462\begin{verbatim}
463fred["fg"] = "red"
464fred["bg"] = "blue"
465\end{verbatim}
Raymond Hettinger68804312005-01-01 00:28:46 +0000466\item[Use the config() method to update multiple attrs subsequent to
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000467object creation]:
468\begin{verbatim}
469fred.config(fg = "red", bg = "blue")
470\end{verbatim}
471\end{description}
472
473For a complete explanation of a given option and its behavior, see the
474Tk man pages for the widget in question.
475
476Note that the man pages list "STANDARD OPTIONS" and "WIDGET SPECIFIC
477OPTIONS" for each widget. The former is a list of options that are
478common to many widgets, the latter are the options that are
Georg Brandlcaa94bd2006-01-23 22:00:17 +0000479idiosyncratic to that particular widget. The Standard Options are
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000480documented on the \manpage{options}{3} man page.
481
482No distinction between standard and widget-specific options is made in
483this document. Some options don't apply to some kinds of widgets.
484Whether a given widget responds to a particular option depends on the
485class of the widget; buttons have a \code{command} option, labels do not.
486
487The options supported by a given widget are listed in that widget's
488man page, or can be queried at runtime by calling the
Fred Drakec6a525e2002-07-08 14:42:22 +0000489\method{config()} method without arguments, or by calling the
490\method{keys()} method on that widget. The return value of these
491calls is a dictionary whose key is the name of the option as a string
492(for example, \code{'relief'}) and whose values are 5-tuples.
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000493
Fred Drakec6a525e2002-07-08 14:42:22 +0000494Some options, like \code{bg} are synonyms for common options with long
495names (\code{bg} is shorthand for "background"). Passing the
496\code{config()} method the name of a shorthand option will return a
4972-tuple, not 5-tuple. The 2-tuple passed back will contain the name of
498the synonym and the ``real'' option (such as \code{('bg',
499'background')}).
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000500
501\begin{tableiii}{c|l|l}{textrm}{Index}{Meaning}{Example}
502 \lineiii{0}{option name} {\code{'relief'}}
503 \lineiii{1}{option name for database lookup} {\code{'relief'}}
504 \lineiii{2}{option class for database lookup} {\code{'Relief'}}
505 \lineiii{3}{default value} {\code{'raised'}}
506 \lineiii{4}{current value} {\code{'groove'}}
507\end{tableiii}
508
509
510Example:
511
512\begin{verbatim}
513>>> print fred.config()
514{'relief' : ('relief', 'relief', 'Relief', 'raised', 'groove')}
515\end{verbatim}
516
517Of course, the dictionary printed will include all the options
518available and their values. This is meant only as an example.
519
520
521\subsubsection{The Packer} % Packer.html
522\index{packing (widgets)}
523
Johannes Gijsbers4f18caa2004-11-07 19:36:48 +0000524The packer is one of Tk's geometry-management mechanisms.
525% See also \citetitle[classes/ClassPacker.html]{the Packer class interface}.
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000526
527Geometry managers are used to specify the relative positioning of the
528positioning of widgets within their container - their mutual
529\emph{master}. In contrast to the more cumbersome \emph{placer}
530(which is used less commonly, and we do not cover here), the packer
531takes qualitative relationship specification - \emph{above}, \emph{to
532the left of}, \emph{filling}, etc - and works everything out to
533determine the exact placement coordinates for you.
534
535The size of any \emph{master} widget is determined by the size of
536the "slave widgets" inside. The packer is used to control where slave
537widgets appear inside the master into which they are packed. You can
538pack widgets into frames, and frames into other frames, in order to
539achieve the kind of layout you desire. Additionally, the arrangement
Johannes Gijsbersd3452252004-09-11 16:50:06 +0000540is dynamically adjusted to accommodate incremental changes to the
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000541configuration, once it is packed.
542
543Note that widgets do not appear until they have had their geometry
544specified with a geometry manager. It's a common early mistake to
545leave out the geometry specification, and then be surprised when the
546widget is created but nothing appears. A widget will appear only
547after it has had, for example, the packer's \method{pack()} method
548applied to it.
549
550The pack() method can be called with keyword-option/value pairs that
551control where the widget is to appear within its container, and how it
552is to behave when the main application window is resized. Here are
553some examples:
554
555\begin{verbatim}
556 fred.pack() # defaults to side = "top"
557 fred.pack(side = "left")
558 fred.pack(expand = 1)
559\end{verbatim}
560
561
562\subsubsection{Packer Options}
563
564For more extensive information on the packer and the options that it
565can take, see the man pages and page 183 of John Ousterhout's book.
566
567\begin{description}
568\item[\b{anchor }]
569Anchor type. Denotes where the packer is to place each slave in its
570parcel.
571
572\item[\b{expand}]
573Boolean, \code{0} or \code{1}.
574
575\item[\b{fill}]
576Legal values: \code{'x'}, \code{'y'}, \code{'both'}, \code{'none'}.
577
578\item[\b{ipadx} and \b{ipady}]
579A distance - designating internal padding on each side of the slave
580widget.
581
582\item[\b{padx} and \b{pady}]
583A distance - designating external padding on each side of the slave
584widget.
585
586\item[\b{side}]
587Legal values are: \code{'left'}, \code{'right'}, \code{'top'},
588\code{'bottom'}.
589\end{description}
590
591
592\subsubsection{Coupling Widget Variables} % VarCouplings.html
593
594The current-value setting of some widgets (like text entry widgets)
595can be connected directly to application variables by using special
596options. These options are \code{variable}, \code{textvariable},
597\code{onvalue}, \code{offvalue}, and \code{value}. This
598connection works both ways: if the variable changes for any reason,
599the widget it's connected to will be updated to reflect the new value.
600
601Unfortunately, in the current implementation of \refmodule{Tkinter} it is
602not possible to hand over an arbitrary Python variable to a widget
603through a \code{variable} or \code{textvariable} option. The only
604kinds of variables for which this works are variables that are
605subclassed from a class called Variable, defined in the
606\refmodule{Tkinter} module.
607
608There are many useful subclasses of Variable already defined:
609\class{StringVar}, \class{IntVar}, \class{DoubleVar}, and
610\class{BooleanVar}. To read the current value of such a variable,
611call the \method{get()} method on
612it, and to change its value you call the \method{set()} method. If
613you follow this protocol, the widget will always track the value of
614the variable, with no further intervention on your part.
615
616For example:
617\begin{verbatim}
618class App(Frame):
619 def __init__(self, master=None):
620 Frame.__init__(self, master)
621 self.pack()
622
623 self.entrythingy = Entry()
624 self.entrythingy.pack()
625
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000626 # here is the application variable
627 self.contents = StringVar()
628 # set it to some value
629 self.contents.set("this is a variable")
630 # tell the entry widget to watch this variable
631 self.entrythingy["textvariable"] = self.contents
632
633 # and here we get a callback when the user hits return.
634 # we will have the program print out the value of the
635 # application variable when the user hits return
636 self.entrythingy.bind('<Key-Return>',
637 self.print_contents)
638
639 def print_contents(self, event):
640 print "hi. contents of entry is now ---->", \
641 self.contents.get()
642\end{verbatim}
643
644
645\subsubsection{The Window Manager} % WindowMgr.html
646\index{window manager (widgets)}
647
648In Tk, there is a utility command, \code{wm}, for interacting with the
649window manager. Options to the \code{wm} command allow you to control
650things like titles, placement, icon bitmaps, and the like. In
651\refmodule{Tkinter}, these commands have been implemented as methods
652on the \class{Wm} class. Toplevel widgets are subclassed from the
653\class{Wm} class, and so can call the \class{Wm} methods directly.
654
655%See also \citetitle[classes/ClassWm.html]{the Wm class interface}.
656
657To get at the toplevel window that contains a given widget, you can
658often just refer to the widget's master. Of course if the widget has
659been packed inside of a frame, the master won't represent a toplevel
660window. To get at the toplevel window that contains an arbitrary
661widget, you can call the \method{_root()} method. This
662method begins with an underscore to denote the fact that this function
663is part of the implementation, and not an interface to Tk functionality.
664
665Here are some examples of typical usage:
666
667\begin{verbatim}
Facundo Batista2784df72004-10-16 21:40:35 +0000668from Tkinter import *
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000669class App(Frame):
670 def __init__(self, master=None):
671 Frame.__init__(self, master)
672 self.pack()
673
674
675# create the application
676myapp = App()
677
678#
679# here are method calls to the window manager class
680#
681myapp.master.title("My Do-Nothing Application")
682myapp.master.maxsize(1000, 400)
683
684# start the program
685myapp.mainloop()
686\end{verbatim}
687
688
689\subsubsection{Tk Option Data Types} % OptionTypes.html
690
691\index{Tk Option Data Types}
692
693\begin{description}
694\item[anchor]
695Legal values are points of the compass: \code{"n"},
696\code{"ne"}, \code{"e"}, \code{"se"}, \code{"s"},
697\code{"sw"}, \code{"w"}, \code{"nw"}, and also
698\code{"center"}.
699
700\item[bitmap]
701There are eight built-in, named bitmaps: \code{'error'}, \code{'gray25'},
702\code{'gray50'}, \code{'hourglass'}, \code{'info'}, \code{'questhead'},
703\code{'question'}, \code{'warning'}. To specify an X bitmap
704filename, give the full path to the file, preceded with an \code{@},
705as in \code{"@/usr/contrib/bitmap/gumby.bit"}.
706
707\item[boolean]
Neal Norwitzcf57e502002-11-03 13:13:20 +0000708You can pass integers 0 or 1 or the strings \code{"yes"} or \code{"no"} .
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000709
710\item[callback]
711This is any Python function that takes no arguments. For example:
712\begin{verbatim}
713 def print_it():
714 print "hi there"
715 fred["command"] = print_it
716\end{verbatim}
717
718\item[color]
719Colors can be given as the names of X colors in the rgb.txt file,
720or as strings representing RGB values in 4 bit: \code{"\#RGB"}, 8
721bit: \code{"\#RRGGBB"}, 12 bit" \code{"\#RRRGGGBBB"}, or 16 bit
722\code{"\#RRRRGGGGBBBB"} ranges, where R,G,B here represent any
723legal hex digit. See page 160 of Ousterhout's book for details.
724
725\item[cursor]
726The standard X cursor names from \file{cursorfont.h} can be used,
727without the \code{XC_} prefix. For example to get a hand cursor
728(\constant{XC_hand2}), use the string \code{"hand2"}. You can also
729specify a bitmap and mask file of your own. See page 179 of
730Ousterhout's book.
731
732\item[distance]
733Screen distances can be specified in either pixels or absolute
734distances. Pixels are given as numbers and absolute distances as
735strings, with the trailing character denoting units: \code{c}
Fred Drakeb184ae82005-01-19 03:39:17 +0000736for centimetres, \code{i} for inches, \code{m} for millimetres,
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000737\code{p} for printer's points. For example, 3.5 inches is expressed
738as \code{"3.5i"}.
739
740\item[font]
741Tk uses a list font name format, such as \code{\{courier 10 bold\}}.
742Font sizes with positive numbers are measured in points;
743sizes with negative numbers are measured in pixels.
744
745\item[geometry]
746This is a string of the form \samp{\var{width}x\var{height}}, where
747width and height are measured in pixels for most widgets (in
748characters for widgets displaying text). For example:
749\code{fred["geometry"] = "200x100"}.
750
751\item[justify]
752Legal values are the strings: \code{"left"},
753\code{"center"}, \code{"right"}, and \code{"fill"}.
754
755\item[region]
756This is a string with four space-delimited elements, each of
757which is a legal distance (see above). For example: \code{"2 3 4
7585"} and \code{"3i 2i 4.5i 2i"} and \code{"3c 2c 4c 10.43c"}
759are all legal regions.
760
761\item[relief]
762Determines what the border style of a widget will be. Legal
763values are: \code{"raised"}, \code{"sunken"},
764\code{"flat"}, \code{"groove"}, and \code{"ridge"}.
765
766\item[scrollcommand]
767This is almost always the \method{set()} method of some scrollbar
768widget, but can be any widget method that takes a single argument.
769Refer to the file \file{Demo/tkinter/matt/canvas-with-scrollbars.py}
770in the Python source distribution for an example.
771
772\item[wrap:]
773Must be one of: \code{"none"}, \code{"char"}, or \code{"word"}.
774\end{description}
775
776
777\subsubsection{Bindings and Events} % Bindings.html
778
779\index{bind (widgets)}
780\index{events (widgets)}
781
782The bind method from the widget command allows you to watch for
783certain events and to have a callback function trigger when that event
784type occurs. The form of the bind method is:
785
786\begin{verbatim}
787 def bind(self, sequence, func, add=''):
788\end{verbatim}
789where:
790
791\begin{description}
792\item[sequence]
793is a string that denotes the target kind of event. (See the bind
794man page and page 201 of John Ousterhout's book for details).
795
796\item[func]
797is a Python function, taking one argument, to be invoked when the
798event occurs. An Event instance will be passed as the argument.
799(Functions deployed this way are commonly known as \var{callbacks}.)
800
801\item[add]
802is optional, either \samp{} or \samp{+}. Passing an empty string
803denotes that this binding is to replace any other bindings that this
804event is associated with. Preceeding with a \samp{+} means that this
805function is to be added to the list of functions bound to this event type.
806\end{description}
807
808For example:
809\begin{verbatim}
810 def turnRed(self, event):
811 event.widget["activeforeground"] = "red"
812
813 self.button.bind("<Enter>", self.turnRed)
814\end{verbatim}
815
Raymond Hettinger68804312005-01-01 00:28:46 +0000816Notice how the widget field of the event is being accessed in the
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000817\method{turnRed()} callback. This field contains the widget that
818caught the X event. The following table lists the other event fields
819you can access, and how they are denoted in Tk, which can be useful
820when referring to the Tk man pages.
821
822\begin{verbatim}
823Tk Tkinter Event Field Tk Tkinter Event Field
824-- ------------------- -- -------------------
825%f focus %A char
826%h height %E send_event
827%k keycode %K keysym
828%s state %N keysym_num
829%t time %T type
830%w width %W widget
831%x x %X x_root
832%y y %Y y_root
833\end{verbatim}
834
835
836\subsubsection{The index Parameter} % Index.html
837
838A number of widgets require``index'' parameters to be passed. These
839are used to point at a specific place in a Text widget, or to
840particular characters in an Entry widget, or to particular menu items
841in a Menu widget.
842
843\begin{description}
844\item[\b{Entry widget indexes (index, view index, etc.)}]
845Entry widgets have options that refer to character positions in the
846text being displayed. You can use these \refmodule{Tkinter} functions
847to access these special points in text widgets:
Fred Drake666ca802001-11-16 06:02:55 +0000848
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000849\begin{description}
850\item[AtEnd()]
851refers to the last position in the text
Fred Drake666ca802001-11-16 06:02:55 +0000852
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000853\item[AtInsert()]
854refers to the point where the text cursor is
Fred Drake666ca802001-11-16 06:02:55 +0000855
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000856\item[AtSelFirst()]
857indicates the beginning point of the selected text
Fred Drake666ca802001-11-16 06:02:55 +0000858
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000859\item[AtSelLast()]
860denotes the last point of the selected text and finally
Fred Drake666ca802001-11-16 06:02:55 +0000861
862\item[At(x\optional{, y})]
863refers to the character at pixel location \var{x}, \var{y} (with
864\var{y} not used in the case of a text entry widget, which contains a
865single line of text).
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000866\end{description}
867
868\item[\b{Text widget indexes}]
869The index notation for Text widgets is very rich and is best described
870in the Tk man pages.
871
872\item[\b{Menu indexes (menu.invoke(), menu.entryconfig(), etc.)}]
873
874Some options and methods for menus manipulate specific menu entries.
875Anytime a menu index is needed for an option or a parameter, you may
876pass in:
877\begin{itemize}
878\item an integer which refers to the numeric position of the entry in
879the widget, counted from the top, starting with 0;
880\item the string \code{'active'}, which refers to the menu position that is
881currently under the cursor;
882\item the string \code{"last"} which refers to the last menu
883item;
884\item An integer preceded by \code{@}, as in \code{@6}, where the integer is
885interpreted as a y pixel coordinate in the menu's coordinate system;
886\item the string \code{"none"}, which indicates no menu entry at all, most
887often used with menu.activate() to deactivate all entries, and
888finally,
889\item a text string that is pattern matched against the label of the
890menu entry, as scanned from the top of the menu to the bottom. Note
891that this index type is considered after all the others, which means
892that matches for menu items labelled \code{last}, \code{active}, or
893\code{none} may be interpreted as the above literals, instead.
894\end{itemize}
895\end{description}
896
Martin v. Löwisa288a232002-11-05 22:11:50 +0000897\subsubsection{Images}
898
899Bitmap/Pixelmap images can be created through the subclasses of
900\class{Tkinter.Image}:
901
902\begin{itemize}
903\item \class{BitmapImage} can be used for X11 bitmap data.
904\item \class{PhotoImage} can be used for GIF and PPM/PGM color bitmaps.
905\end{itemize}
906
907Either type of image is created through either the \code{file} or the
908\code{data} option (other options are available as well).
909
Neal Norwitzfad265e2002-11-05 22:46:39 +0000910The image object can then be used wherever an \code{image} option is
Martin v. Löwisa288a232002-11-05 22:11:50 +0000911supported by some widget (e.g. labels, buttons, menus). In these
912cases, Tk will not keep a reference to the image. When the last Python
913reference to the image object is deleted, the image data is deleted as
Neal Norwitzfad265e2002-11-05 22:46:39 +0000914well, and Tk will display an empty box wherever the image was used.
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000915
Fred Drakec66ff202001-11-16 01:05:27 +0000916\section{\module{Tix} ---
917 Extension widgets for Tk}
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000918
919\declaremodule{standard}{Tix}
920\modulesynopsis{Tk Extension Widgets for Tkinter}
921\sectionauthor{Mike Clarkson}{mikeclarkson@users.sourceforge.net}
922
Fred Drakec66ff202001-11-16 01:05:27 +0000923\index{Tix}
924
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000925The \module{Tix} (Tk Interface Extension) module provides an
926additional rich set of widgets. Although the standard Tk library has
927many useful widgets, they are far from complete. The \module{Tix}
928library provides most of the commonly needed widgets that are missing
929from standard Tk: \class{HList}, \class{ComboBox}, \class{Control}
930(a.k.a. SpinBox) and an assortment of scrollable widgets. \module{Tix}
931also includes many more widgets that are generally useful in a wide
932range of applications: \class{NoteBook}, \class{FileEntry},
933\class{PanedWindow}, etc; there are more than 40 of them.
934
935With all these new widgets, you can introduce new interaction
936techniques into applications, creating more useful and more intuitive
937user interfaces. You can design your application by choosing the most
938appropriate widgets to match the special needs of your application and
939users.
940
941\begin{seealso}
942\seetitle[http://tix.sourceforge.net/]
943 {Tix Homepage}
Fred Drakea0b76762001-12-13 04:25:37 +0000944 {The home page for \module{Tix}. This includes links to
945 additional documentation and downloads.}
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000946\seetitle[http://tix.sourceforge.net/dist/current/man/]
947 {Tix Man Pages}
948 {On-line version of the man pages and reference material.}
949\seetitle[http://tix.sourceforge.net/dist/current/docs/tix-book/tix.book.html]
950 {Tix Programming Guide}
951 {On-line version of the programmer's reference material.}
952\seetitle[http://tix.sourceforge.net/Tide/]
953 {Tix Development Applications}
954 {Tix applications for development of Tix and Tkinter programs.
955 Tide applications work under Tk or Tkinter, and include
956 \program{TixInspect}, an inspector to remotely modify and
957 debug Tix/Tk/Tkinter applications.}
958\end{seealso}
959
960
961\subsection{Using Tix}
962
Fred Drake666ca802001-11-16 06:02:55 +0000963\begin{classdesc}{Tix}{screenName\optional{, baseName\optional{, className}}}
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000964 Toplevel widget of Tix which represents mostly the main window
965 of an application. It has an associated Tcl interpreter.
966
Fred Drake666ca802001-11-16 06:02:55 +0000967Classes in the \refmodule{Tix} module subclasses the classes in the
968\refmodule{Tkinter} module. The former imports the latter, so to use
969\refmodule{Tix} with Tkinter, all you need to do is to import one
970module. In general, you can just import \refmodule{Tix}, and replace
971the toplevel call to \class{Tkinter.Tk} with \class{Tix.Tk}:
Fred Drake7cf4e5b2001-11-15 17:22:04 +0000972\begin{verbatim}
973import Tix
974from Tkconstants import *
975root = Tix.Tk()
976\end{verbatim}
977\end{classdesc}
978
979To use \refmodule{Tix}, you must have the \refmodule{Tix} widgets installed,
980usually alongside your installation of the Tk widgets.
981To test your installation, try the following:
982\begin{verbatim}
983import Tix
984root = Tix.Tk()
985root.tk.eval('package require Tix')
986\end{verbatim}
987
988If this fails, you have a Tk installation problem which must be
989resolved before proceeding. Use the environment variable \envvar{TIX_LIBRARY}
990to point to the installed \refmodule{Tix} library directory, and
991make sure you have the dynamic object library (\file{tix8183.dll} or
992\file{libtix8183.so}) in the same directory that contains your Tk
993dynamic object library (\file{tk8183.dll} or \file{libtk8183.so}). The
994directory with the dynamic object library should also have a file
995called \file{pkgIndex.tcl} (case sensitive), which contains the line:
996
997\begin{verbatim}
998package ifneeded Tix 8.1 [list load "[file join $dir tix8183.dll]" Tix]
999\end{verbatim} % $ <-- bow to font-lock
1000
1001
1002\subsection{Tix Widgets}
1003
1004\ulink{Tix}
1005{http://tix.sourceforge.net/dist/current/man/html/TixCmd/TixIntro.htm}
1006introduces over 40 widget classes to the \refmodule{Tkinter}
1007repertoire. There is a demo of all the \refmodule{Tix} widgets in the
1008\file{Demo/tix} directory of the standard distribution.
1009
1010
1011% The Python sample code is still being added to Python, hence commented out
1012
1013
1014\subsubsection{Basic Widgets}
1015
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001016\begin{classdesc}{Balloon}{}
1017A \ulink{Balloon}
Fred Drakec66ff202001-11-16 01:05:27 +00001018{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixBalloon.htm}
1019that pops up over a widget to provide help. When the user moves the
1020cursor inside a widget to which a Balloon widget has been bound, a
1021small pop-up window with a descriptive message will be shown on the
1022screen.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001023\end{classdesc}
1024
Fred Drakec66ff202001-11-16 01:05:27 +00001025% Python Demo of:
1026% \ulink{Balloon}{http://tix.sourceforge.net/dist/current/demos/samples/Balloon.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001027
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001028\begin{classdesc}{ButtonBox}{}
1029The \ulink{ButtonBox}
Fred Drakec66ff202001-11-16 01:05:27 +00001030{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixButtonBox.htm}
1031widget creates a box of buttons, such as is commonly used for \code{Ok
1032Cancel}.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001033\end{classdesc}
1034
Fred Drakec66ff202001-11-16 01:05:27 +00001035% Python Demo of:
1036% \ulink{ButtonBox}{http://tix.sourceforge.net/dist/current/demos/samples/BtnBox.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001037
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001038\begin{classdesc}{ComboBox}{}
1039The \ulink{ComboBox}
Fred Drakec66ff202001-11-16 01:05:27 +00001040{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixComboBox.htm}
1041widget is similar to the combo box control in MS Windows. The user can
1042select a choice by either typing in the entry subwdget or selecting
1043from the listbox subwidget.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001044\end{classdesc}
1045
Fred Drakec66ff202001-11-16 01:05:27 +00001046% Python Demo of:
1047% \ulink{ComboBox}{http://tix.sourceforge.net/dist/current/demos/samples/ComboBox.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001048
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001049\begin{classdesc}{Control}{}
1050The \ulink{Control}
Fred Drakec66ff202001-11-16 01:05:27 +00001051{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixControl.htm}
1052widget is also known as the \class{SpinBox} widget. The user can
1053adjust the value by pressing the two arrow buttons or by entering the
1054value directly into the entry. The new value will be checked against
1055the user-defined upper and lower limits.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001056\end{classdesc}
1057
Fred Drakec66ff202001-11-16 01:05:27 +00001058% Python Demo of:
1059% \ulink{Control}{http://tix.sourceforge.net/dist/current/demos/samples/Control.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001060
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001061\begin{classdesc}{LabelEntry}{}
1062The \ulink{LabelEntry}
Fred Drakec66ff202001-11-16 01:05:27 +00001063{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixLabelEntry.htm}
1064widget packages an entry widget and a label into one mega widget. It
1065can be used be used to simplify the creation of ``entry-form'' type of
1066interface.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001067\end{classdesc}
1068
1069% Python Demo of:
1070% \ulink{LabelEntry}{http://tix.sourceforge.net/dist/current/demos/samples/LabEntry.tcl}
1071
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001072\begin{classdesc}{LabelFrame}{}
1073The \ulink{LabelFrame}
Fred Drakec66ff202001-11-16 01:05:27 +00001074{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixLabelFrame.htm}
1075widget packages a frame widget and a label into one mega widget. To
1076create widgets inside a LabelFrame widget, one creates the new widgets
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001077relative to the \member{frame} subwidget and manage them inside the
1078\member{frame} subwidget.
1079\end{classdesc}
1080
1081% Python Demo of:
1082% \ulink{LabelFrame}{http://tix.sourceforge.net/dist/current/demos/samples/LabFrame.tcl}
1083
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001084\begin{classdesc}{Meter}{}
1085The \ulink{Meter}
Fred Drakec66ff202001-11-16 01:05:27 +00001086{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixMeter.htm}
1087widget can be used to show the progress of a background job which may
1088take a long time to execute.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001089\end{classdesc}
1090
1091% Python Demo of:
1092% \ulink{Meter}{http://tix.sourceforge.net/dist/current/demos/samples/Meter.tcl}
1093
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001094\begin{classdesc}{OptionMenu}{}
1095The \ulink{OptionMenu}
Fred Drakec66ff202001-11-16 01:05:27 +00001096{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixOptionMenu.htm}
1097creates a menu button of options.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001098\end{classdesc}
1099
Fred Drakec66ff202001-11-16 01:05:27 +00001100% Python Demo of:
1101% \ulink{OptionMenu}{http://tix.sourceforge.net/dist/current/demos/samples/OptMenu.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001102
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001103\begin{classdesc}{PopupMenu}{}
1104The \ulink{PopupMenu}
Fred Drakec66ff202001-11-16 01:05:27 +00001105{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixPopupMenu.htm}
1106widget can be used as a replacement of the \code{tk_popup}
1107command. The advantage of the \refmodule{Tix} \class{PopupMenu} widget
1108is it requires less application code to manipulate.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001109\end{classdesc}
1110
Fred Drakec66ff202001-11-16 01:05:27 +00001111% Python Demo of:
1112% \ulink{PopupMenu}{http://tix.sourceforge.net/dist/current/demos/samples/PopMenu.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001113
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001114\begin{classdesc}{Select}{}
1115The \ulink{Select}
Fred Drakec66ff202001-11-16 01:05:27 +00001116{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixSelect.htm}
1117widget is a container of button subwidgets. It can be used to provide
1118radio-box or check-box style of selection options for the user.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001119\end{classdesc}
1120
Fred Drakec66ff202001-11-16 01:05:27 +00001121% Python Demo of:
1122% \ulink{Select}{http://tix.sourceforge.net/dist/current/demos/samples/Select.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001123
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001124\begin{classdesc}{StdButtonBox}{}
1125The \ulink{StdButtonBox}
Fred Drakec66ff202001-11-16 01:05:27 +00001126{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixStdButtonBox.htm}
1127widget is a group of standard buttons for Motif-like dialog boxes.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001128\end{classdesc}
1129
Fred Drakec66ff202001-11-16 01:05:27 +00001130% Python Demo of:
1131% \ulink{StdButtonBox}{http://tix.sourceforge.net/dist/current/demos/samples/StdBBox.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001132
1133
1134\subsubsection{File Selectors}
1135
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001136\begin{classdesc}{DirList}{}
1137The \ulink{DirList}
1138{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixDirList.htm} widget
1139displays a list view of a directory, its previous directories and its
1140sub-directories. The user can choose one of the directories displayed
1141in the list or change to another directory.
1142\end{classdesc}
1143
Fred Drakec66ff202001-11-16 01:05:27 +00001144% Python Demo of:
1145% \ulink{DirList}{http://tix.sourceforge.net/dist/current/demos/samples/DirList.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001146
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001147\begin{classdesc}{DirTree}{}
1148The \ulink{DirTree}
Fred Drakec66ff202001-11-16 01:05:27 +00001149{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixDirTree.htm}
1150widget displays a tree view of a directory, its previous directories
1151and its sub-directories. The user can choose one of the directories
1152displayed in the list or change to another directory.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001153\end{classdesc}
1154
Fred Drakec66ff202001-11-16 01:05:27 +00001155% Python Demo of:
1156% \ulink{DirTree}{http://tix.sourceforge.net/dist/current/demos/samples/DirTree.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001157
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001158\begin{classdesc}{DirSelectDialog}{}
1159The \ulink{DirSelectDialog}
Fred Drakec66ff202001-11-16 01:05:27 +00001160{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixDirSelectDialog.htm}
1161widget presents the directories in the file system in a dialog
1162window. The user can use this dialog window to navigate through the
1163file system to select the desired directory.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001164\end{classdesc}
1165
Fred Drakec66ff202001-11-16 01:05:27 +00001166% Python Demo of:
1167% \ulink{DirSelectDialog}{http://tix.sourceforge.net/dist/current/demos/samples/DirDlg.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001168
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001169\begin{classdesc}{DirSelectBox}{}
1170The \class{DirSelectBox} is similar
1171to the standard Motif(TM) directory-selection box. It is generally used for
1172the user to choose a directory. DirSelectBox stores the directories mostly
1173recently selected into a ComboBox widget so that they can be quickly
1174selected again.
1175\end{classdesc}
1176
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001177\begin{classdesc}{ExFileSelectBox}{}
1178The \ulink{ExFileSelectBox}
Fred Drakec66ff202001-11-16 01:05:27 +00001179{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixExFileSelectBox.htm}
1180widget is usually embedded in a tixExFileSelectDialog widget. It
1181provides an convenient method for the user to select files. The style
1182of the \class{ExFileSelectBox} widget is very similar to the standard
1183file dialog on MS Windows 3.1.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001184\end{classdesc}
1185
Fred Drakec66ff202001-11-16 01:05:27 +00001186% Python Demo of:
1187%\ulink{ExFileSelectDialog}{http://tix.sourceforge.net/dist/current/demos/samples/EFileDlg.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001188
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001189\begin{classdesc}{FileSelectBox}{}
1190The \ulink{FileSelectBox}
Fred Drakec66ff202001-11-16 01:05:27 +00001191{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixFileSelectBox.htm}
1192is similar to the standard Motif(TM) file-selection box. It is
1193generally used for the user to choose a file. FileSelectBox stores the
1194files mostly recently selected into a \class{ComboBox} widget so that
1195they can be quickly selected again.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001196\end{classdesc}
1197
Fred Drakec66ff202001-11-16 01:05:27 +00001198% Python Demo of:
1199% \ulink{FileSelectDialog}{http://tix.sourceforge.net/dist/current/demos/samples/FileDlg.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001200
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001201\begin{classdesc}{FileEntry}{}
1202The \ulink{FileEntry}
Fred Drakec66ff202001-11-16 01:05:27 +00001203{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixFileEntry.htm}
1204widget can be used to input a filename. The user can type in the
1205filename manually. Alternatively, the user can press the button widget
1206that sits next to the entry, which will bring up a file selection
1207dialog.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001208\end{classdesc}
1209
Fred Drakec66ff202001-11-16 01:05:27 +00001210% Python Demo of:
1211% \ulink{FileEntry}{http://tix.sourceforge.net/dist/current/demos/samples/FileEnt.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001212
1213
1214\subsubsection{Hierachical ListBox}
1215
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001216\begin{classdesc}{HList}{}
1217The \ulink{HList}
Fred Drakec66ff202001-11-16 01:05:27 +00001218{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixHList.htm}
1219widget can be used to display any data that have a hierarchical
1220structure, for example, file system directory trees. The list entries
1221are indented and connected by branch lines according to their places
Raymond Hettinger68804312005-01-01 00:28:46 +00001222in the hierarchy.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001223\end{classdesc}
1224
Fred Drakec66ff202001-11-16 01:05:27 +00001225% Python Demo of:
1226% \ulink{HList}{http://tix.sourceforge.net/dist/current/demos/samples/HList1.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001227
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001228\begin{classdesc}{CheckList}{}
1229The \ulink{CheckList}
Fred Drakec66ff202001-11-16 01:05:27 +00001230{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixCheckList.htm}
1231widget displays a list of items to be selected by the user. CheckList
1232acts similarly to the Tk checkbutton or radiobutton widgets, except it
1233is capable of handling many more items than checkbuttons or
1234radiobuttons.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001235\end{classdesc}
1236
Fred Drakec66ff202001-11-16 01:05:27 +00001237% Python Demo of:
1238% \ulink{ CheckList}{http://tix.sourceforge.net/dist/current/demos/samples/ChkList.tcl}
1239% Python Demo of:
1240% \ulink{ScrolledHList (1)}{http://tix.sourceforge.net/dist/current/demos/samples/SHList.tcl}
1241% Python Demo of:
1242% \ulink{ScrolledHList (2)}{http://tix.sourceforge.net/dist/current/demos/samples/SHList2.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001243
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001244\begin{classdesc}{Tree}{}
1245The \ulink{Tree}
Fred Drakec66ff202001-11-16 01:05:27 +00001246{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixTree.htm}
Raymond Hettinger68804312005-01-01 00:28:46 +00001247widget can be used to display hierarchical data in a tree form. The
Fred Drakec66ff202001-11-16 01:05:27 +00001248user can adjust the view of the tree by opening or closing parts of
1249the tree.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001250\end{classdesc}
1251
Fred Drakec66ff202001-11-16 01:05:27 +00001252% Python Demo of:
1253% \ulink{Tree}{http://tix.sourceforge.net/dist/current/demos/samples/Tree.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001254
Fred Drakec66ff202001-11-16 01:05:27 +00001255% Python Demo of:
1256% \ulink{Tree (Dynamic)}{http://tix.sourceforge.net/dist/current/demos/samples/DynTree.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001257
1258
1259\subsubsection{Tabular ListBox}
1260
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001261\begin{classdesc}{TList}{}
1262The \ulink{TList}
Fred Drakec66ff202001-11-16 01:05:27 +00001263{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixTList.htm}
1264widget can be used to display data in a tabular format. The list
1265entries of a \class{TList} widget are similar to the entries in the Tk
1266listbox widget. The main differences are (1) the \class{TList} widget
1267can display the list entries in a two dimensional format and (2) you
1268can use graphical images as well as multiple colors and fonts for the
1269list entries.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001270\end{classdesc}
1271
Fred Drakec66ff202001-11-16 01:05:27 +00001272% Python Demo of:
1273% \ulink{ScrolledTList (1)}{http://tix.sourceforge.net/dist/current/demos/samples/STList1.tcl}
1274% Python Demo of:
1275% \ulink{ScrolledTList (2)}{http://tix.sourceforge.net/dist/current/demos/samples/STList2.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001276
1277% Grid has yet to be added to Python
1278% \subsubsection{Grid Widget}
Fred Drakec66ff202001-11-16 01:05:27 +00001279% Python Demo of:
1280% \ulink{Simple Grid}{http://tix.sourceforge.net/dist/current/demos/samples/SGrid0.tcl}
1281% Python Demo of:
1282% \ulink{ScrolledGrid}{http://tix.sourceforge.net/dist/current/demos/samples/SGrid1.tcl}
1283% Python Demo of:
1284% \ulink{Editable Grid}{http://tix.sourceforge.net/dist/current/demos/samples/EditGrid.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001285
1286
1287\subsubsection{Manager Widgets}
1288
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001289\begin{classdesc}{PanedWindow}{}
1290The \ulink{PanedWindow}
Fred Drakec66ff202001-11-16 01:05:27 +00001291{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixPanedWindow.htm}
1292widget allows the user to interactively manipulate the sizes of
1293several panes. The panes can be arranged either vertically or
1294horizontally. The user changes the sizes of the panes by dragging the
1295resize handle between two panes.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001296\end{classdesc}
1297
Fred Drakec66ff202001-11-16 01:05:27 +00001298% Python Demo of:
1299% \ulink{PanedWindow}{http://tix.sourceforge.net/dist/current/demos/samples/PanedWin.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001300
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001301\begin{classdesc}{ListNoteBook}{}
1302The \ulink{ListNoteBook}
Fred Drakec66ff202001-11-16 01:05:27 +00001303{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixListNoteBook.htm}
1304widget is very similar to the \class{TixNoteBook} widget: it can be
1305used to display many windows in a limited space using a notebook
1306metaphor. The notebook is divided into a stack of pages (windows). At
1307one time only one of these pages can be shown. The user can navigate
1308through these pages by choosing the name of the desired page in the
1309\member{hlist} subwidget.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001310\end{classdesc}
1311
Fred Drakec66ff202001-11-16 01:05:27 +00001312% Python Demo of:
1313% \ulink{ListNoteBook}{http://tix.sourceforge.net/dist/current/demos/samples/ListNBK.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001314
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001315\begin{classdesc}{NoteBook}{}
1316The \ulink{NoteBook}
Fred Drakec66ff202001-11-16 01:05:27 +00001317{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixNoteBook.htm}
1318widget can be used to display many windows in a limited space using a
1319notebook metaphor. The notebook is divided into a stack of pages. At
1320one time only one of these pages can be shown. The user can navigate
1321through these pages by choosing the visual ``tabs'' at the top of the
1322NoteBook widget.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001323\end{classdesc}
1324
Fred Drakec66ff202001-11-16 01:05:27 +00001325% Python Demo of:
1326% \ulink{NoteBook}{http://tix.sourceforge.net/dist/current/demos/samples/NoteBook.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001327
1328
1329% \subsubsection{Scrolled Widgets}
Fred Drakec66ff202001-11-16 01:05:27 +00001330% Python Demo of:
1331% \ulink{ScrolledListBox}{http://tix.sourceforge.net/dist/current/demos/samples/SListBox.tcl}
1332% Python Demo of:
1333% \ulink{ScrolledText}{http://tix.sourceforge.net/dist/current/demos/samples/SText.tcl}
1334% Python Demo of:
1335% \ulink{ScrolledWindow}{http://tix.sourceforge.net/dist/current/demos/samples/SWindow.tcl}
1336% Python Demo of:
1337% \ulink{Canvas Object View}{http://tix.sourceforge.net/dist/current/demos/samples/CObjView.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001338
1339
1340\subsubsection{Image Types}
1341
1342The \refmodule{Tix} module adds:
1343\begin{itemize}
1344\item
1345\ulink{pixmap}
Fred Drake666ca802001-11-16 06:02:55 +00001346{http://tix.sourceforge.net/dist/current/man/html/TixCmd/pixmap.htm}
1347capabilities to all \refmodule{Tix} and \refmodule{Tkinter} widgets to
1348create color images from XPM files.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001349
Fred Drakea0b76762001-12-13 04:25:37 +00001350% Python Demo of:
1351% \ulink{XPM Image In Button}{http://tix.sourceforge.net/dist/current/demos/samples/Xpm.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001352
Fred Drakea0b76762001-12-13 04:25:37 +00001353% Python Demo of:
1354% \ulink{XPM Image In Menu}{http://tix.sourceforge.net/dist/current/demos/samples/Xpm1.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001355
1356\item
1357\ulink{Compound}
Johannes Gijsbersb5646aa2005-01-29 19:49:34 +00001358{http://tix.sourceforge.net/dist/current/man/html/TixCmd/compound.htm}
Fred Drake666ca802001-11-16 06:02:55 +00001359image types can be used to create images that consists of multiple
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001360horizontal lines; each line is composed of a series of items (texts,
1361bitmaps, images or spaces) arranged from left to right. For example, a
1362compound image can be used to display a bitmap and a text string
Raymond Hettinger68804312005-01-01 00:28:46 +00001363simultaneously in a Tk \class{Button} widget.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001364
Fred Drake666ca802001-11-16 06:02:55 +00001365% Python Demo of:
1366% \ulink{Compound Image In Buttons}{http://tix.sourceforge.net/dist/current/demos/samples/CmpImg.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001367
Fred Drake666ca802001-11-16 06:02:55 +00001368% Python Demo of:
1369% \ulink{Compound Image In NoteBook}{http://tix.sourceforge.net/dist/current/demos/samples/CmpImg2.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001370
Fred Drake666ca802001-11-16 06:02:55 +00001371% Python Demo of:
1372% \ulink{Compound Image Notebook Color Tabs}{http://tix.sourceforge.net/dist/current/demos/samples/CmpImg4.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001373
Fred Drake666ca802001-11-16 06:02:55 +00001374% Python Demo of:
1375% \ulink{Compound Image Icons}{http://tix.sourceforge.net/dist/current/demos/samples/CmpImg3.tcl}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001376\end{itemize}
1377
1378
1379\subsubsection{Miscellaneous Widgets}
1380
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001381\begin{classdesc}{InputOnly}{}
1382The \ulink{InputOnly}
Fred Drake666ca802001-11-16 06:02:55 +00001383{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixInputOnly.htm}
1384widgets are to accept inputs from the user, which can be done with the
1385\code{bind} command (\UNIX{} only).
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001386\end{classdesc}
1387
1388\subsubsection{Form Geometry Manager}
1389
1390In addition, \refmodule{Tix} augments \refmodule{Tkinter} by providing:
Fred Drake666ca802001-11-16 06:02:55 +00001391
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001392\begin{classdesc}{Form}{}
1393The \ulink{Form}
Fred Drake666ca802001-11-16 06:02:55 +00001394{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tixForm.htm}
1395geometry manager based on attachment rules for all Tk widgets.
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001396\end{classdesc}
1397
1398
1399%begin{latexonly}
1400%\subsection{Tix Class Structure}
1401%
1402%\begin{figure}[hbtp]
1403%\centerline{\epsfig{file=hierarchy.png,width=.9\textwidth}}
1404%\vspace{.5cm}
1405%\caption{The Class Hierarchy of Tix Widgets}
1406%\end{figure}
1407%end{latexonly}
1408
Fred Drake44b6f842001-11-29 21:09:08 +00001409\subsection{Tix Commands}
1410
1411\begin{classdesc}{tixCommand}{}
1412The \ulink{tix commands}
1413{http://tix.sourceforge.net/dist/current/man/html/TixCmd/tix.htm}
1414provide access to miscellaneous elements of \refmodule{Tix}'s internal
1415state and the \refmodule{Tix} application context. Most of the information
1416manipulated by these methods pertains to the application as a whole,
1417or to a screen or display, rather than to a particular window.
1418
1419To view the current settings, the common usage is:
1420\begin{verbatim}
1421import Tix
1422root = Tix.Tk()
1423print root.tix_configure()
1424\end{verbatim}
1425\end{classdesc}
1426
1427\begin{methoddesc}{tix_configure}{\optional{cnf,} **kw}
1428Query or modify the configuration options of the Tix application
1429context. If no option is specified, returns a dictionary all of the
1430available options. If option is specified with no value, then the
1431method returns a list describing the one named option (this list will
1432be identical to the corresponding sublist of the value returned if no
1433option is specified). If one or more option-value pairs are
1434specified, then the method modifies the given option(s) to have the
1435given value(s); in this case the method returns an empty string.
1436Option may be any of the configuration options.
1437\end{methoddesc}
1438
1439\begin{methoddesc}{tix_cget}{option}
1440Returns the current value of the configuration option given by
1441\var{option}. Option may be any of the configuration options.
1442\end{methoddesc}
1443
1444\begin{methoddesc}{tix_getbitmap}{name}
1445Locates a bitmap file of the name \code{name.xpm} or \code{name} in
1446one of the bitmap directories (see the \method{tix_addbitmapdir()}
1447method). By using \method{tix_getbitmap()}, you can avoid hard
1448coding the pathnames of the bitmap files in your application. When
1449successful, it returns the complete pathname of the bitmap file,
1450prefixed with the character \samp{@}. The returned value can be used to
1451configure the \code{bitmap} option of the Tk and Tix widgets.
1452\end{methoddesc}
1453
1454\begin{methoddesc}{tix_addbitmapdir}{directory}
1455Tix maintains a list of directories under which the
1456\method{tix_getimage()} and \method{tix_getbitmap()} methods will
1457search for image files. The standard bitmap directory is
1458\file{\$TIX_LIBRARY/bitmaps}. The \method{tix_addbitmapdir()} method
1459adds \var{directory} into this list. By using this method, the image
1460files of an applications can also be located using the
1461\method{tix_getimage()} or \method{tix_getbitmap()} method.
1462\end{methoddesc}
1463
1464\begin{methoddesc}{tix_filedialog}{\optional{dlgclass}}
1465Returns the file selection dialog that may be shared among different
1466calls from this application. This method will create a file selection
1467dialog widget when it is called the first time. This dialog will be
1468returned by all subsequent calls to \method{tix_filedialog()}. An
1469optional dlgclass parameter can be passed as a string to specified
1470what type of file selection dialog widget is desired. Possible
1471options are \code{tix}, \code{FileSelectDialog} or
1472\code{tixExFileSelectDialog}.
1473\end{methoddesc}
1474
1475
1476\begin{methoddesc}{tix_getimage}{self, name}
1477Locates an image file of the name \file{name.xpm}, \file{name.xbm} or
1478\file{name.ppm} in one of the bitmap directories (see the
1479\method{tix_addbitmapdir()} method above). If more than one file with
1480the same name (but different extensions) exist, then the image type is
1481chosen according to the depth of the X display: xbm images are chosen
1482on monochrome displays and color images are chosen on color
1483displays. By using \method{tix_getimage()}, you can avoid hard coding
1484the pathnames of the image files in your application. When successful,
1485this method returns the name of the newly created image, which can be
1486used to configure the \code{image} option of the Tk and Tix widgets.
1487\end{methoddesc}
1488
1489\begin{methoddesc}{tix_option_get}{name}
Raymond Hettinger68804312005-01-01 00:28:46 +00001490Gets the options maintained by the Tix scheme mechanism.
Fred Drake44b6f842001-11-29 21:09:08 +00001491\end{methoddesc}
1492
1493\begin{methoddesc}{tix_resetoptions}{newScheme, newFontSet\optional{,
1494 newScmPrio}}
1495Resets the scheme and fontset of the Tix application to
1496\var{newScheme} and \var{newFontSet}, respectively. This affects only
1497those widgets created after this call. Therefore, it is best to call
1498the resetoptions method before the creation of any widgets in a Tix
1499application.
1500
1501The optional parameter \var{newScmPrio} can be given to reset the
1502priority level of the Tk options set by the Tix schemes.
1503
1504Because of the way Tk handles the X option database, after Tix has
1505been has imported and inited, it is not possible to reset the color
1506schemes and font sets using the \method{tix_config()} method.
1507Instead, the \method{tix_resetoptions()} method must be used.
1508\end{methoddesc}
1509
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001510
Fred Drake1a763862001-12-03 21:18:30 +00001511
1512\section{\module{ScrolledText} ---
1513 Scrolled Text Widget}
1514
1515\declaremodule{standard}{ScrolledText}
1516 \platform{Tk}
1517\modulesynopsis{Text widget with a vertical scroll bar.}
1518\sectionauthor{Fred L. Drake, Jr.}{fdrake@acm.org}
1519
1520The \module{ScrolledText} module provides a class of the same name
1521which implements a basic text widget which has a vertical scroll bar
1522configured to do the ``right thing.'' Using the \class{ScrolledText}
1523class is a lot easier than setting up a text widget and scroll bar
1524directly. The constructor is the same as that of the
1525\class{Tkinter.Text} class.
1526
1527The text widget and scrollbar are packed together in a \class{Frame},
Fred Drakea0b76762001-12-13 04:25:37 +00001528and the methods of the \class{Grid} and \class{Pack} geometry managers
1529are acquired from the \class{Frame} object. This allows the
1530\class{ScrolledText} widget to be used directly to achieve most normal
1531geometry management behavior.
Fred Drake1a763862001-12-03 21:18:30 +00001532
1533Should more specific control be necessary, the following attributes
1534are available:
1535
1536\begin{memberdesc}[ScrolledText]{frame}
1537 The frame which surrounds the text and scroll bar widgets.
1538\end{memberdesc}
1539
1540\begin{memberdesc}[ScrolledText]{vbar}
1541 The scroll bar widget.
1542\end{memberdesc}
1543
1544
Fred Drakec66ff202001-11-16 01:05:27 +00001545\input{libturtle}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001546
1547
1548\section{Idle \label{idle}}
1549
1550%\declaremodule{standard}{idle}
Raymond Hettinger68804312005-01-01 00:28:46 +00001551%\modulesynopsis{A Python Integrated Development Environment}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001552\moduleauthor{Guido van Rossum}{guido@Python.org}
1553
1554Idle is the Python IDE built with the \refmodule{Tkinter} GUI toolkit.
1555\index{Idle}
1556\index{Python Editor}
Raymond Hettinger68804312005-01-01 00:28:46 +00001557\index{Integrated Development Environment}
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001558
1559
1560IDLE has the following features:
1561
1562\begin{itemize}
1563\item coded in 100\% pure Python, using the \refmodule{Tkinter} GUI toolkit
1564
1565\item cross-platform: works on Windows and \UNIX{} (on Mac OS, there are
1566currently problems with Tcl/Tk)
1567
1568\item multi-window text editor with multiple undo, Python colorizing
1569and many other features, e.g. smart indent and call tips
1570
1571\item Python shell window (a.k.a. interactive interpreter)
1572
1573\item debugger (not complete, but you can set breakpoints, view and step)
1574\end{itemize}
1575
1576
1577\subsection{Menus}
1578
1579\subsubsection{File menu}
1580
1581\begin{description}
1582\item[New window] create a new editing window
1583\item[Open...] open an existing file
1584\item[Open module...] open an existing module (searches sys.path)
1585\item[Class browser] show classes and methods in current file
1586\item[Path browser] show sys.path directories, modules, classes and methods
1587\end{description}
1588\index{Class browser}
1589\index{Path browser}
1590
1591\begin{description}
1592\item[Save] save current window to the associated file (unsaved
1593windows have a * before and after the window title)
1594
1595\item[Save As...] save current window to new file, which becomes
1596the associated file
1597\item[Save Copy As...] save current window to different file
1598without changing the associated file
1599\end{description}
1600
1601\begin{description}
1602\item[Close] close current window (asks to save if unsaved)
1603\item[Exit] close all windows and quit IDLE (asks to save if unsaved)
1604\end{description}
1605
1606
1607\subsubsection{Edit menu}
1608
1609\begin{description}
1610\item[Undo] Undo last change to current window (max 1000 changes)
1611\item[Redo] Redo last undone change to current window
1612\end{description}
1613
1614\begin{description}
1615\item[Cut] Copy selection into system-wide clipboard; then delete selection
1616\item[Copy] Copy selection into system-wide clipboard
1617\item[Paste] Insert system-wide clipboard into window
1618\item[Select All] Select the entire contents of the edit buffer
1619\end{description}
1620
1621\begin{description}
1622\item[Find...] Open a search dialog box with many options
1623\item[Find again] Repeat last search
1624\item[Find selection] Search for the string in the selection
1625\item[Find in Files...] Open a search dialog box for searching files
1626\item[Replace...] Open a search-and-replace dialog box
1627\item[Go to line] Ask for a line number and show that line
1628\end{description}
1629
1630\begin{description}
1631\item[Indent region] Shift selected lines right 4 spaces
1632\item[Dedent region] Shift selected lines left 4 spaces
1633\item[Comment out region] Insert \#\# in front of selected lines
1634\item[Uncomment region] Remove leading \# or \#\# from selected lines
1635\item[Tabify region] Turns \emph{leading} stretches of spaces into tabs
1636\item[Untabify region] Turn \emph{all} tabs into the right number of spaces
1637\item[Expand word] Expand the word you have typed to match another
1638 word in the same buffer; repeat to get a different expansion
1639\item[Format Paragraph] Reformat the current blank-line-separated paragraph
1640\end{description}
1641
1642\begin{description}
1643\item[Import module] Import or reload the current module
1644\item[Run script] Execute the current file in the __main__ namespace
1645\end{description}
1646
1647\index{Import module}
1648\index{Run script}
1649
1650
1651\subsubsection{Windows menu}
1652
1653\begin{description}
1654\item[Zoom Height] toggles the window between normal size (24x80)
1655 and maximum height.
1656\end{description}
1657
1658The rest of this menu lists the names of all open windows; select one
1659to bring it to the foreground (deiconifying it if necessary).
1660
1661
1662\subsubsection{Debug menu (in the Python Shell window only)}
1663
1664\begin{description}
1665\item[Go to file/line] look around the insert point for a filename
1666 and linenumber, open the file, and show the line.
1667\item[Open stack viewer] show the stack traceback of the last exception
1668\item[Debugger toggle] Run commands in the shell under the debugger
1669\item[JIT Stack viewer toggle] Open stack viewer on traceback
1670\end{description}
1671
1672\index{stack viewer}
1673\index{debugger}
1674
1675
1676\subsection{Basic editing and navigation}
1677
1678\begin{itemize}
1679\item \kbd{Backspace} deletes to the left; \kbd{Del} deletes to the right
1680\item Arrow keys and \kbd{Page Up}/\kbd{Page Down} to move around
1681\item \kbd{Home}/\kbd{End} go to begin/end of line
1682\item \kbd{C-Home}/\kbd{C-End} go to begin/end of file
1683\item Some \program{Emacs} bindings may also work, including \kbd{C-B},
1684 \kbd{C-P}, \kbd{C-A}, \kbd{C-E}, \kbd{C-D}, \kbd{C-L}
1685\end{itemize}
1686
1687
1688\subsubsection{Automatic indentation}
1689
1690After a block-opening statement, the next line is indented by 4 spaces
1691(in the Python Shell window by one tab). After certain keywords
1692(break, return etc.) the next line is dedented. In leading
1693indentation, \kbd{Backspace} deletes up to 4 spaces if they are there.
1694\kbd{Tab} inserts 1-4 spaces (in the Python Shell window one tab).
1695See also the indent/dedent region commands in the edit menu.
1696
1697
1698\subsubsection{Python Shell window}
1699
1700\begin{itemize}
1701\item \kbd{C-C} interrupts executing command
1702\item \kbd{C-D} sends end-of-file; closes window if typed at
1703a \samp{>>>~} prompt
1704\end{itemize}
1705
1706\begin{itemize}
Fred Drake666ca802001-11-16 06:02:55 +00001707\item \kbd{Alt-p} retrieves previous command matching what you have typed
1708\item \kbd{Alt-n} retrieves next
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001709\item \kbd{Return} while on any previous command retrieves that command
Fred Drake666ca802001-11-16 06:02:55 +00001710\item \kbd{Alt-/} (Expand word) is also useful here
Fred Drake7cf4e5b2001-11-15 17:22:04 +00001711\end{itemize}
1712
1713\index{indentation}
1714
1715
1716\subsection{Syntax colors}
1717
1718The coloring is applied in a background ``thread,'' so you may
1719occasionally see uncolorized text. To change the color
1720scheme, edit the \code{[Colors]} section in \file{config.txt}.
1721
1722\begin{description}
1723\item[Python syntax colors:]
1724
1725\begin{description}
1726\item[Keywords] orange
1727\item[Strings ] green
1728\item[Comments] red
1729\item[Definitions] blue
1730\end{description}
1731
1732\item[Shell colors:]
1733\begin{description}
1734\item[Console output] brown
1735\item[stdout] blue
1736\item[stderr] dark green
1737\item[stdin] black
1738\end{description}
1739\end{description}
1740
1741
1742\subsubsection{Command line usage}
1743
1744\begin{verbatim}
1745idle.py [-c command] [-d] [-e] [-s] [-t title] [arg] ...
1746
1747-c command run this command
1748-d enable debugger
1749-e edit mode; arguments are files to be edited
1750-s run $IDLESTARTUP or $PYTHONSTARTUP first
1751-t title set title of shell window
1752\end{verbatim}
1753
1754If there are arguments:
1755
1756\begin{enumerate}
1757\item If \programopt{-e} is used, arguments are files opened for
1758 editing and \code{sys.argv} reflects the arguments passed to
1759 IDLE itself.
1760
1761\item Otherwise, if \programopt{-c} is used, all arguments are
1762 placed in \code{sys.argv[1:...]}, with \code{sys.argv[0]} set
1763 to \code{'-c'}.
1764
1765\item Otherwise, if neither \programopt{-e} nor \programopt{-c} is
1766 used, the first argument is a script which is executed with
1767 the remaining arguments in \code{sys.argv[1:...]} and
1768 \code{sys.argv[0]} set to the script name. If the script name
1769 is '-', no script is executed but an interactive Python
1770 session is started; the arguments are still available in
1771 \code{sys.argv}.
1772\end{enumerate}
Fred Drakec66ff202001-11-16 01:05:27 +00001773
1774
1775\section{Other Graphical User Interface Packages
1776 \label{other-gui-packages}}
1777
1778
1779There are an number of extension widget sets to \refmodule{Tkinter}.
1780
Fred Drake10cd3152001-11-30 18:17:24 +00001781\begin{seealso*}
Fred Drakec66ff202001-11-16 01:05:27 +00001782\seetitle[http://pmw.sourceforge.net/]{Python megawidgets}{is a
1783toolkit for building high-level compound widgets in Python using the
1784\refmodule{Tkinter} module. It consists of a set of base classes and
1785a library of flexible and extensible megawidgets built on this
1786foundation. These megawidgets include notebooks, comboboxes, selection
1787widgets, paned widgets, scrolled widgets, dialog windows, etc. Also,
1788with the Pmw.Blt interface to BLT, the busy, graph, stripchart, tabset
1789and vector commands are be available.
1790
1791The initial ideas for Pmw were taken from the Tk \code{itcl}
1792extensions \code{[incr Tk]} by Michael McLennan and \code{[incr
1793Widgets]} by Mark Ulferts. Several of the megawidgets are direct
1794translations from the itcl to Python. It offers most of the range of
1795widgets that \code{[incr Widgets]} does, and is almost as complete as
1796Tix, lacking however Tix's fast \class{HList} widget for drawing trees.
1797}
Fred Drake81209952003-07-08 13:44:27 +00001798
1799\seetitle[http://tkinter.effbot.org/]{Tkinter3000 Widget Construction
1800 Kit (WCK)}{%
1801is a library that allows you to write new Tkinter widgets in pure
1802Python. The WCK framework gives you full control over widget
1803creation, configuration, screen appearance, and event handling. WCK
1804widgets can be very fast and light-weight, since they can operate
1805directly on Python data structures, without having to transfer data
1806through the Tk/Tcl layer.}
Fred Drake10cd3152001-11-30 18:17:24 +00001807\end{seealso*}
Fred Drakec66ff202001-11-16 01:05:27 +00001808
1809
Fred Drake666ca802001-11-16 06:02:55 +00001810Tk is not the only GUI for Python, but is however the
Fred Drakec66ff202001-11-16 01:05:27 +00001811most commonly used one.
1812
Fred Drake10cd3152001-11-30 18:17:24 +00001813\begin{seealso*}
Fred Drakec66ff202001-11-16 01:05:27 +00001814\seetitle[http://www.wxwindows.org]{wxWindows}{
1815is a GUI toolkit that combines the most attractive attributes of Qt,
1816Tk, Motif, and GTK+ in one powerful and efficient package. It is
Fred Drakec37b65e2001-11-28 07:26:15 +00001817implemented in \Cpp. wxWindows supports two flavors of \UNIX{}
Fred Drakec66ff202001-11-16 01:05:27 +00001818implementation: GTK+ and Motif, and under Windows, it has a standard
1819Microsoft Foundation Classes (MFC) appearance, because it uses Win32
1820widgets. There is a Python class wrapper, independent of Tkinter.
1821
1822wxWindows is much richer in widgets than \refmodule{Tkinter}, with its
1823help system, sophisticated HTML and image viewers, and other
1824specialized widgets, extensive documentation, and printing capabilities.
1825}
Fred Drake9b414ac2002-05-31 18:21:56 +00001826\seetitle[]{PyQt}{
1827PyQt is a \program{sip}-wrapped binding to the Qt toolkit. Qt is an
1828extensive \Cpp{} GUI toolkit that is available for \UNIX, Windows and
1829Mac OS X. \program{sip} is a tool for generating bindings for \Cpp{}
1830libraries as Python classes, and is specifically designed for Python.
1831An online manual is available at
1832\url{http://www.opendocspublishing.com/pyqt/} (errata are located at
1833\url{http://www.valdyas.org/python/book.html}).
1834}
1835\seetitle[http://www.riverbankcomputing.co.uk/pykde/index.php]{PyKDE}{
1836PyKDE is a \program{sip}-wrapped interface to the KDE desktop
1837libraries. KDE is a desktop environment for \UNIX{} computers; the
1838graphical components are based on Qt.
Fred Drakec66ff202001-11-16 01:05:27 +00001839}
1840\seetitle[http://fxpy.sourceforge.net/]{FXPy}{
1841is a Python extension module which provides an interface to the
1842\citetitle[http://www.cfdrc.com/FOX/fox.html]{FOX} GUI.
1843FOX is a \Cpp{} based Toolkit for developing Graphical User Interfaces
1844easily and effectively. It offers a wide, and growing, collection of
1845Controls, and provides state of the art facilities such as drag and
1846drop, selection, as well as OpenGL widgets for 3D graphical
1847manipulation. FOX also implements icons, images, and user-convenience
1848features such as status line help, and tooltips.
1849
1850Even though FOX offers a large collection of controls already, FOX
1851leverages \Cpp{} to allow programmers to easily build additional Controls
1852and GUI elements, simply by taking existing controls, and creating a
1853derived class which simply adds or redefines the desired behavior.
1854}
Fred Draked50bd6c2003-07-28 14:39:13 +00001855\seetitle[http://www.daa.com.au/\textasciitilde james/software/pygtk/]{PyGTK}{
Fred Drakec66ff202001-11-16 01:05:27 +00001856is a set of bindings for the \ulink{GTK}{http://www.gtk.org/} widget set.
1857It provides an object oriented interface that is slightly higher
1858level than the C one. It automatically does all the type casting and
1859reference counting that you would have to do normally with the C
Fred Drake16ecb212002-10-12 15:02:46 +00001860API. There are also
1861\ulink{bindings}{http://www.daa.com.au/\textasciitilde james/gnome/}
Fred Drakec66ff202001-11-16 01:05:27 +00001862to \ulink{GNOME}{http://www.gnome.org}, and a
1863\ulink{tutorial}
Fred Drake16ecb212002-10-12 15:02:46 +00001864{http://laguna.fmedic.unam.mx/\textasciitilde daniel/pygtutorial/pygtutorial/index.html}
Fred Drakec66ff202001-11-16 01:05:27 +00001865is available.
1866}
Fred Drake10cd3152001-11-30 18:17:24 +00001867\end{seealso*}
Fred Drakec66ff202001-11-16 01:05:27 +00001868
1869% XXX Reference URLs that compare the different UI packages