- NAME
- ttk_notebook - Multi-paned container widget
 
- SYNOPSIS
- ttk::notebook pathName ?options?
- pathName add pathName.subwindow ?options...?
- pathName insert index pathName.subwindow ?options...?
 
- DESCRIPTION
- STANDARD OPTIONS
- -class
- -cursor, cursor, Cursor
- -style
- -takefocus, takeFocus, TakeFocus
 
- WIDGET-SPECIFIC OPTIONS
- -height, height, Height
- -padding, padding, Padding
- -width, width, Width
 
- TAB OPTIONS
- -state, state, State
- -sticky, sticky, Sticky
- -padding, padding, Padding
- -text, text, Text
- -image, image, Image
- -compound, compound, Compound
- -underline, underline, Underline
 
- WIDGET COMMAND
- pathname add child ?options...?
- pathname configure ?options?
- pathname cget option
- pathname forget tabid
- pathname index tabid
- pathname insert pos subwindow options...
- pathname instate statespec ?script...?
- pathname select ?tabid?
- pathname state ?statespec?
- pathname tab tabid ?-options ?value ...
- pathname tabs
 
- KEYBOARD TRAVERSAL
 
- TAB IDENTIFIERS
 
- VIRTUAL EVENTS
- EXAMPLE
- SEE ALSO
- KEYWORDS
ttk_notebook - Multi-paned container widget
ttk::notebook pathName ?options?
pathName add pathName.subwindow ?options...?
pathName insert index pathName.subwindow ?options...?
A ttk::notebook widget manages a collection of subpanes 
and displays a single one at a time.
Each pane is associated with a tab, which the user
may select to change the currently-displayed pane.
- -class
- -cursor, cursor, Cursor
- -style
- -takefocus, takeFocus, TakeFocus
- Command-Line Name: -height
- Database Name: height
- Database Class: Height
- If present and greater than zero, 
specifies the desired height of the pane area
(not including internal padding or tabs).
Otherwise, the maximum height of all panes is used.
- Command-Line Name: -padding
- Database Name: padding
- Database Class: Padding
- Specifies the amount of extra space to add around the outside
of the notebook.
The padding is a list of up to four length specifications 
left top right bottom.
If fewer than four elements are specified, 
bottom defaults to top,
right defaults to left, and 
top defaults to left.
- Command-Line Name: -width
- Database Name: width
- Database Class: Width
- If present and greater than zero, 
specifies the desired width of the pane area
(not including internal padding).
Otherwise, the maximum width of all panes is used.
The following options may be specified for individual notebook panes:
- Command-Line Name: -state
- Database Name: state
- Database Class: State
- Either normal, disabled or hidden.  
If disabled, then the tab is not selectable. If hidden,
then the tab is not shown.
- Command-Line Name: -sticky
- Database Name: sticky
- Database Class: Sticky
- Specifies how the child pane is positioned within the pane area.
Value is a string containing zero or more of the characters
n, s, e, or w.
Each letter refers to a side (north, south, east, or west) 
that the child window will "stick" to,
as per the grid geometry manager.
- Command-Line Name: -padding
- Database Name: padding
- Database Class: Padding
- Specifies the amount of extra space to add between the notebook and this pane.
Syntax is the same as for the widget -padding option.
- Command-Line Name: -text
- Database Name: text
- Database Class: Text
- Specifies a string to be displayed in the tab.
- Command-Line Name: -image
- Database Name: image
- Database Class: Image
- Specifies an image to display in the tab,
which must have been created with the image create command.
- Command-Line Name: -compound
- Database Name: compound
- Database Class: Compound
- Specifies how to display the image relative to the text,
in the case both -text and -image are present.
See label(n) for legal values.
- Command-Line Name: -underline
- Database Name: underline
- Database Class: Underline
- Specifies the integer index (0-based) of a character to underline 
in the text string.
The underlined character is used for mnemonic activation
if ttk::notebook::enableTraversal is called.
- pathname add child ?options...?
- 
Adds a new tab to the notebook.
When the tab is selected, the child window
will be displayed.
child must be a direct child of the notebook window.
See TAB OPTIONS for the list of available options.
- pathname configure ?options?
- 
See ttk_widget(n).
- pathname cget option
- 
See ttk_widget(n).
- pathname forget tabid
- 
Removes the tab specified by tabid,
unmaps and unmanages the associated child window.
- pathname index tabid
- 
Returns the numeric index of the tab specified by tabid,
or the total number of tabs if tabid is the string "end".
- pathname insert pos subwindow options...
- 
Inserts a pane at the specified position.
pos is either the string end, an integer index, 
or the name of a managed subwindow.
If subwindow is already managed by the notebook, 
moves it to the specified position.
See TAB OPTIONS for the list of available options.
- pathname instate statespec ?script...?
- 
See ttk_widget(n).
- pathname select ?tabid?
- 
Selects the specified tab.  The associated child pane will be displayed,
and the previously-selected pane (if different) is unmapped.
If tabid is omitted, returns the widget name of the
currently selected pane.
- pathname state ?statespec?
- 
See ttk_widget(n).
- pathname tab tabid ?-options ?value ...
- 
Query or modify the options of the specific tab.
If no -option is specified, returns a dictionary of the tab option values.
If one -option is specified, returns the value of that option.
Otherwise, sets the -options to the corresponding values.
See TAB OPTIONS for the available options.
- pathname tabs
- 
Returns a list of all windows managed by the widget.
To enable keyboard traversal for a toplevel window
containing a notebook widget $nb, call:ttk::notebook::enableTraversal $nb
This will extend the bindings for the toplevel widget
containing the notebook as follows:
- • 
Control-Tab selects the tab following the currently selected one.
- • 
Shift-Control-Tab selects the tab preceding the currently selected one.
- • 
Alt-K, where K is the mnemonic (underlined) character
of any tab, will select that tab.
Multiple notebooks in a single toplevel may be enabled for traversal,
including nested notebooks.  
However, notebook traversal only works properly if all panes
are direct children of the notebook.
The tabid argument to the above commands may take
any of the following forms:
- • 
An integer between zero and the number of tabs;
- • 
The name of a child pane window;
- • 
A positional specification of the form "@x,y",
which identifies the tab 
- • 
The literal string "current",
which identifies the currently-selected tab; or:
- • 
The literal string "end",
which returns the number of tabs 
(only valid for "pathname index").
The notebook widget generates a <<NotebookTabChanged>>
virtual event after a new tab is selected.notebook .nb
.nb add [frame .nb.f1] -text "First tab"
.nb add [frame .nb.f2] -text "Second tab"
.nb select .nb.f2
ttk::notebook::enableTraversal .nb
ttk_widget, grid
pane, tab
Copyright © 1995-1997 Roger E. Critchlow Jr.
Copyright © 2004 Joe English