the basic component of a tk-based application is called a widget. a component is also sometimes called a window, since, in tk, "window" and "widget" are often used interchangeably. tk is a package that provides a rich set of graphical components for creating graphical applications with tcl.
tk provides a range of widgets ranging from basic gui widgets like buttons and menus to data display widgets. the widgets are very configurable as they have default configurations making them easy to use.
tk applications follow a widget hierarchy where any number of widgets may be placed within another widget, and those widgets within another widget. the main widget in a tk program is referred to as the root widget and can be created by making a new instance of the tkroot class.
creating a widget
the syntax for creating a widget is given below.
type variablename arguments options
the type here refers to the widget type like button, label, and so on. arguments can be optional and required based on individual syntax of each widget. the options range from size to formatting of each component.
widget naming convention
widget uses a structure similar to naming packages. in tk, the root window is named with a period (.) and an element in window, for example button is named .mybutton1. the variable name should start with a lowercase letter, digit, or punctuation mark (except a period). after the first character, other characters may be uppercase or lowercase letters, numbers, or punctuation marks (except periods). it is recommended to use a lowercase letter to start the label.
color naming convention
the colors can be declared using name like red, green, and so on. it can also use hexadecimal representing with #. the number of hexadecimal digits can be 3, 6, 9, or 12.
dimension convention
the default unit is pixels and it is used when we specify no dimension. the other dimensions are i for inches, m for millimeters, c for centimeters and p for points.
common options
there are so many common options available to all widgets and they are listed below in the following table −
sr.no. | syntax & description |
---|---|
1 |
-background color used to set background color for widget. |
2 |
-borderwidth width used to draw with border in 3d effects. |
3 |
-font fontdescriptor used to set font for widget. |
4 |
-foreground color used to set foreground color for widget. |
5 |
-height number used to set height for widget. |
6 |
-highlightbackground color used to set the color rectangle to draw around a widget when the widget does not have input focus. |
7 |
-highlightcolor color used to set the color rectangle to draw around a widget when the widget has input focus. |
8 |
-padx number sets the padx for the widget. |
9 |
-pady number sets the pady for the widget. |
10 |
-relief condition sets the 3d relief for this widget. the condition may be raised, sunken, flat, ridge, solid, or groove. |
11 |
-text text sets the text for the widget. |
12 |
-textvariable varname variable associated with the widget. when the text of widget changes, the variable is set with text of widget. |
13 |
-width number sets the width for widget. |
a simple example for options is shown below.
#!/usr/bin/wish grid [label .mylabel -background red -text "hello world" -relief ridge -borderwidth 3] -padx 100 -pady 100
when we run the above program, we will get the following output.

the list of available widgets are categorized below −
basic widgets
sr.no. | widget & description |
---|---|
1 |
label widget for displaying single line of text. |
2 |
button widget that is clickable and triggers an action. |
3 |
entry widget used to accept a single line of text as input. |
4 |
message widget for displaying multiple lines of text. |
5 |
text widget for displaying and optionally edit multiple lines of text. |
6 |
toplevel window with all borders and decorations provided by the window manager. |
layout widgets
sr.no. | widget & description |
---|---|
1 |
frame container widget to hold other widgets. |
2 |
place widget to hold other widgets in specific place with coordinates of its origin and an exact size. |
3 |
pack simple widget to organize widgets in blocks before placing them in the parent widget. |
4 |
grid widget to nest widgets packing in different directions. |
selection widgets
sr.no. | widget & description |
---|---|
1 |
radiobutton widget that has a set of on/off buttons and labels, one of which may be selected. |
2 |
checkbutton widget that has a set of on/off buttons and labels, many of which may be selected.. |
3 |
menu widget that acts as holder for menu items. |
4 |
listbox widget that displays a list of cells, one or more of which may be selected. |
mega widgets
sr.no. | widget & description |
---|---|
1 |
dialog widget for displaying dialog boxes. |
2 |
spinbox widget that allows users to choose numbers. |
3 |
combobox widget that combines an entry with a list of choices available to the use. |
4 |
notebook tabbed widget that helps to switch between one of several pages, using an index tab. |
5 |
progressbar widget to provide visual feedback to the progress of a long operation like file upload. |
6 |
treeview widget to display and allow browsing through a hierarchy of items more in form of tree. |
7 |
scrollbar scrolling widgets without a text or canvas widgets. |
8 |
scale scale widget to choose a numeric value through sliders. |
other widgets
sr.no. | widget & description |
---|---|
1 |
canvas drawing widget for displaying graphics and images.. |
we will cover each of these widgets in the upcoming chapters.