![LOGO](https://raw.githubusercontent.com/PySimpleGUI/PySimpleGUI/master/images/for_readme/Logo%20with%20text%20for%20GitHub%20Top.png)
# ELEMENT AND FUNCTION CALL REFERENCE
Here you will find the details for all Elements, Objects, and Functions that are available to you. If you want to use a complex element and don't understand the parameters, then this is the right place to come. For every element you're shown the parameters used to create it as well as all methods available to call.
## Currently PySimpleGUI (tkinter) only
This documentation is created using the PySimpleGUI.py file which means it's based on the tkinter code. Some of the calls are different, might not exist at all, or there may be more methods/functions for the other PySimpleGUI ports (Qt, Wx, Web).
Work is underway to get the PySimpleGUIQt docstrings completed and corrected.
## Caution - Some functions / methods may be internal only yet exposed in this documentation
This section of the documentation is generated directly from the source code. As a result, sometimes internal only functions or methods that you are not supposed to be calling are accidentally shown in this documentation. Hopefully these accidents don't happen often.
Here are all of the Elements, the Window & SystemTray classes, and all functions
---------
## Button Element
Button Element - Defines all possible buttons. The shortcuts such as Submit, FileBrowse, ... each create a Button
```
Button(button_text = "",
button_type = 7,
target = (None, None),
tooltip = None,
file_types = (('ALL Files', '*.*'),),
initial_folder = None,
default_extension = "",
disabled = False,
change_submits = False,
enable_events = False,
image_filename = None,
image_data = None,
image_size = (None, None),
image_subsample = None,
border_width = None,
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
disabled_button_color = None,
highlight_colors = None,
mouseover_colors = (None, None),
use_ttk_buttons = None,
font = None,
bind_return_key = False,
focus = False,
pad = None,
key = None,
k = None,
right_click_menu = None,
expand_x = False,
expand_y = False,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | Text to be displayed on the button |
| int | button_type | You should NOT be setting this directly. ONLY the shortcut functions set this |
| str or (int, int) | target | key or (row,col) target for the button. Note that -1 for column means 1 element to the left of this one. The constant ThisRow is used to indicate the current row. The Button itself is a valid target for some types of button |
| str | tooltip | text, that will appear when mouse hovers over the element |
| Tuple[(str, str), ...] | file_types | the filetypes that will be used to match files. To indicate all files: (("ALL Files", "*.*"),). Note - NOT SUPPORTED ON MAC |
| str | initial_folder | starting path for folders and files |
| str | default_extension | If no extension entered by user, add this to filename (only used in saveas dialogs) |
| (bool or str) | disabled | If True button will be created disabled. If BUTTON_DISABLED_MEANS_IGNORE then the button will be ignored rather than disabled using tkinter |
| bool | change_submits | DO NOT USE. Only listed for backwards compat - Use enable_events instead |
| bool | enable_events | Turns on the element specific events. If this button is a target, should it generate an event when filled in |
| str | image_filename | image filename if there is a button image. GIFs and PNGs only. |
| bytes or str | image_data | Raw or Base64 representation of the image to put on button. Choose either filename or data |
| (int, int) | image_size | Size of the image in pixels (width, height) |
| int | image_subsample | amount to reduce the size of the image. Divides the size by this number. 2=1/2, 3=1/3, 4=1/4, etc |
| int | border_width | width of border around button in pixels |
| (int, int) or (None, None) or int | size | (w, h) w=characters-wide, h=rows-high. If an int instead of a tuple is supplied, then height is auto-set to 1 |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | if True the button size is sized to fit the text |
| (str, str) or str or (int, int) or None | button_color | Color of button. default is from theme or the window. Easy to remember which is which if you say "ON" between colors. "red" on "green". Normally a tuple, but can be a simplified-button-color-string "foreground on background". Can be a single color if want to set only the background. |
| (str, str) or str | disabled_button_color | colors to use when button is disabled (text, background). Use None for a color if don't want to change. Only ttk buttons support both text and background colors. tk buttons only support changing text color |
| (str, str) | highlight_colors | colors to use when button has focus (has focus, does not have focus). None will use colors based on theme. Only used by Linux and only for non-TTK button |
| (str, str) or str | mouseover_colors | Important difference between Linux & Windows! Linux - Colors when mouse moved over button. Windows - colors when button is pressed. The default is to switch the text and background colors (an inverse effect) |
| bool | use_ttk_buttons | True = use ttk buttons. False = do not use ttk buttons. None (Default) = use ttk buttons only if on a Mac and not with button images |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | bind_return_key | If True the return key will cause this button to be pressed |
| bool | focus | if True, initial focus will be put on this button |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### click
Generates a click of the button as if the user clicked the button
Calls the tkinter invoke method for the button
```python
click()
```
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### get_text
Returns the current text shown on a button
`get_text()`
|Type|Name|Meaning|
|---|---|---|
|(str)| **return** | The text currently displayed on the button |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### set_vscroll_position
Attempts to set the vertical scroll postition for an element's Widget
```
set_vscroll_position(percent_from_top)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| float | percent_from_top | From 0 to 1.0, the percentage from the top to move scrollbar to |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Button Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(text = None,
button_color = (None, None),
disabled = None,
image_data = None,
image_filename = None,
visible = None,
image_subsample = None,
disabled_button_color = (None, None),
image_size = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | text | sets button text |
| (str, str) or str or (int, int) or None | button_color | Color of button. default is from theme or the window. Easy to remember which is which if you say "ON" between colors. "red" on "green". Normally a tuple, but can be a simplified-button-color-string "foreground on background". Can be a single color if want to set only the background. |
| (bool or str) | disabled | True/False to enable/disable at the GUI level. Use BUTTON_DISABLED_MEANS_IGNORE to ignore clicks (won't change colors) |
| bytes or str | image_data | Raw or Base64 representation of the image to put on button. Choose either filename or data |
| str | image_filename | image filename if there is a button image. GIFs and PNGs only. |
| (str, str) | disabled_button_color | colors to use when button is disabled (text, background). Use None for a color if don't want to change. Only ttk buttons support both text and background colors. tk buttons only support changing text color |
| bool | visible | control visibility of element |
| int | image_subsample | amount to reduce the size of the image. Divides the size by this number. 2=1/2, 3=1/3, 4=1/4, etc |
| (int, int) | image_size | Size of the image in pixels (width, height) |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### Click
Generates a click of the button as if the user clicked the button
Calls the tkinter invoke method for the button
```python
Click()
```
### GetText
Returns the current text shown on a button
`GetText()`
|Type|Name|Meaning|
|---|---|---|
|(str)| **return** | The text currently displayed on the button |
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Button Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(text = None,
button_color = (None, None),
disabled = None,
image_data = None,
image_filename = None,
visible = None,
image_subsample = None,
disabled_button_color = (None, None),
image_size = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | text | sets button text |
| (str, str) or str or (int, int) or None | button_color | Color of button. default is from theme or the window. Easy to remember which is which if you say "ON" between colors. "red" on "green". Normally a tuple, but can be a simplified-button-color-string "foreground on background". Can be a single color if want to set only the background. |
| (bool or str) | disabled | True/False to enable/disable at the GUI level. Use BUTTON_DISABLED_MEANS_IGNORE to ignore clicks (won't change colors) |
| bytes or str | image_data | Raw or Base64 representation of the image to put on button. Choose either filename or data |
| str | image_filename | image filename if there is a button image. GIFs and PNGs only. |
| (str, str) | disabled_button_color | colors to use when button is disabled (text, background). Use None for a color if don't want to change. Only ttk buttons support both text and background colors. tk buttons only support changing text color |
| bool | visible | control visibility of element |
| int | image_subsample | amount to reduce the size of the image. Divides the size by this number. 2=1/2, 3=1/3, 4=1/4, etc |
| (int, int) | image_size | Size of the image in pixels (width, height) |
---------
## ButtonMenu Element
The Button Menu Element. Creates a button that when clicked will show a menu similar to right click menu
```
ButtonMenu(button_text,
menu_def,
tooltip = None,
disabled = False,
image_filename = None,
image_data = None,
image_size = (None, None),
image_subsample = None,
border_width = None,
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
text_color = None,
background_color = None,
disabled_text_color = None,
font = None,
item_font = None,
pad = None,
expand_x = False,
expand_y = False,
key = None,
k = None,
tearoff = False,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | Text to be displayed on the button |
| List[List[str]] | menu_def | A list of lists of Menu items to show when this element is clicked. See docs for format as they are the same for all menu types |
| str | tooltip | text, that will appear when mouse hovers over the element |
| bool | disabled | If True button will be created disabled |
| str | image_filename | image filename if there is a button image. GIFs and PNGs only. |
| bytes or str | image_data | Raw or Base64 representation of the image to put on button. Choose either filename or data |
| (int, int) | image_size | Size of the image in pixels (width, height) |
| int | image_subsample | amount to reduce the size of the image. Divides the size by this number. 2=1/2, 3=1/3, 4=1/4, etc |
| int | border_width | width of border around button in pixels |
| (int, int) or (None, None) or int | size | (w, h) w=characters-wide, h=rows-high. If an int instead of a tuple is supplied, then height is auto-set to 1 |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | if True the button size is sized to fit the text |
| (str, str) or str | button_color | of button. Easy to remember which is which if you say "ON" between colors. "red" on "green" |
| str | background_color | color of the background |
| str | text_color | element's text color. Can be in #RRGGBB format or a color name "black" |
| str | disabled_text_color | color to use for text when item is disabled. Can be in #RRGGBB format or a color name "black" |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| (str or (str, int[, str]) or None) | item_font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike, for the menu items |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| bool | key | Used with window.find_element and with return values to uniquely identify this element to uniquely identify this element :param expand_x: If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| bool | tearoff | Determines if menus should allow them to be torn off |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### set_vscroll_position
Attempts to set the vertical scroll postition for an element's Widget
```
set_vscroll_position(percent_from_top)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| float | percent_from_top | From 0 to 1.0, the percentage from the top to move scrollbar to |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the ButtonMenu Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(menu_definition = None, visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List] | menu_definition | (New menu definition (in menu definition format) |
| bool | visible | control visibility of element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### Click
Generates a click of the button as if the user clicked the button
Calls the tkinter invoke method for the button
```python
Click()
```
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the ButtonMenu Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(menu_definition = None, visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List] | menu_definition | (New menu definition (in menu definition format) |
| bool | visible | control visibility of element |
---------
## Canvas Element
```
Canvas(canvas = None,
background_color = None,
size = (None, None),
s = (None, None),
pad = None,
key = None,
k = None,
tooltip = None,
right_click_menu = None,
expand_x = False,
expand_y = False,
visible = True,
border_width = 0,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (tk.Canvas) | canvas | Your own tk.Canvas if you already created it. Leave blank to create a Canvas |
| str | background_color | color of background |
| (int,int) or (None, None) | size | (width in char, height in rows) size in pixels to make canvas |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| str | tooltip | text, that will appear when mouse hovers over the element |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | visible | set visibility state of the element |
| int | border_width | width of border around element in pixels. Not normally used with Canvas element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### tk_canvas
#### property: tk_canvas
Returns the underlying tkiner Canvas widget
|Type|Name|Meaning|
|---|---|---|
|(tk.Canvas)| **return** | The tkinter canvas widget |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### TKCanvas
#### property: TKCanvas
Returns the underlying tkiner Canvas widget
|Type|Name|Meaning|
|---|---|---|
|(tk.Canvas)| **return** | The tkinter canvas widget |
---------
## Checkbox Element
Checkbox Element - Displays a checkbox and text next to it
```
Checkbox(text,
default = False,
size = (None, None),
s = (None, None),
auto_size_text = None,
font = None,
background_color = None,
text_color = None,
checkbox_color = None,
change_submits = False,
enable_events = False,
disabled = False,
key = None,
k = None,
pad = None,
tooltip = None,
right_click_menu = None,
expand_x = False,
expand_y = False,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | text | Text to display next to checkbox |
| bool | default | Set to True if you want this checkbox initially checked |
| (int, int) or (None, None) or int | size | (w, h) w=characters-wide, h=rows-high. If an int instead of a tuple is supplied, then height is auto-set to 1 |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_text | if True will size the element to match the length of the text |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str | background_color | color of background |
| str | text_color | color of the text |
| str | checkbox_color | color of background of the box that has the check mark in it. The checkmark is the same color as the text |
| bool | change_submits | DO NOT USE. Only listed for backwards compat - Use enable_events instead |
| bool | enable_events | Turns on the element specific events. Checkbox events happen when an item changes |
| bool | disabled | set disable state |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str | tooltip | text, that will appear when mouse hovers over the element |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get
Return the current state of this checkbox
`get()`
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Current state of checkbox |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Checkbox Element. Must call `Window.Read` or `Window.Finalize` prior.
Note that changing visibility may cause element to change locations when made visible after invisible
```
update(value = None,
text = None,
background_color = None,
text_color = None,
checkbox_color = None,
disabled = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | value | if True checks the checkbox, False clears it |
| str | text | Text to display next to checkbox |
| str | background_color | color of background |
| str | text_color | color of the text. Note this also changes the color of the checkmark |
| bool | disabled | disable or enable element |
| bool | visible | control visibility of element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### Get
Return the current state of this checkbox
`Get()`
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Current state of checkbox |
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Checkbox Element. Must call `Window.Read` or `Window.Finalize` prior.
Note that changing visibility may cause element to change locations when made visible after invisible
```
Update(value = None,
text = None,
background_color = None,
text_color = None,
checkbox_color = None,
disabled = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | value | if True checks the checkbox, False clears it |
| str | text | Text to display next to checkbox |
| str | background_color | color of background |
| str | text_color | color of the text. Note this also changes the color of the checkmark |
| bool | disabled | disable or enable element |
| bool | visible | control visibility of element |
---------
## Column Element
A container element that is used to create a layout within your window's layout
```
Column(layout,
background_color = None,
size = (None, None),
s = (None, None),
pad = None,
scrollable = False,
vertical_scroll_only = False,
right_click_menu = None,
key = None,
k = None,
visible = True,
justification = None,
element_justification = None,
vertical_alignment = None,
grab = None,
expand_x = None,
expand_y = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Element]] | layout | Layout that will be shown in the Column container |
| str | background_color | color of background of entire Column |
| (int, int) | size | (width, height) size in pixels (doesn't work quite right, sometimes only 1 dimension is set by tkinter. Use a Sizer Element to help set sizes |
| (int, int) or (None, None) | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| bool | scrollable | if True then scrollbars will be added to the column |
| bool | vertical_scroll_only | if Truen then no horizontal scrollbar will be shown |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| str or int or tuple or object | key | Value that uniquely identifies this element from all other elements. Used when Finding an element or in return values. Must be unique to the window |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| bool | visible | set visibility state of the element |
| str | justification | set justification for the Column itself. Note entire row containing the Column will be affected |
| str | element_justification | All elements inside the Column will have this justification 'left', 'right', 'center' are valid values |
| str | vertical_alignment | Place the column at the 'top', 'center', 'bottom' of the row (can also use t,c,r). Defaults to no setting (tkinter decides) |
| bool | grab | If True can grab this element and move the window around. Default is False |
| bool | expand_x | If True the column will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the column will automatically expand in the Y direction to fill available space |
| Any | metadata | User metadata that can be set to ANYTHING |
### add_row
Not recommended user call. Used to add rows of Elements to the Column Element.
```
add_row(args=*<1 or N object>)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[Element] | *args | The list of elements for this row |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### contents_changed
When a scrollable column has part of its layout changed by making elements visible or invisible or the
layout is extended for the Column, then this method needs to be called so that the new scroll area
is computed to match the new contents.
```python
contents_changed()
```
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### layout
Can use like the Window.Layout method, but it's better to use the layout parameter when creating
```
layout(rows)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Element]] | rows | The rows of Elements |
| (Column) | **RETURN** | Used for chaining
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### set_vscroll_position
Attempts to set the vertical scroll postition for an element's Widget
```
set_vscroll_position(percent_from_top)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| float | percent_from_top | From 0 to 1.0, the percentage from the top to move scrollbar to |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Column Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | visible | control visibility of element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### AddRow
Not recommended user call. Used to add rows of Elements to the Column Element.
```
AddRow(args=*<1 or N object>)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[Element] | *args | The list of elements for this row |
### Layout
Can use like the Window.Layout method, but it's better to use the layout parameter when creating
```
Layout(rows)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Element]] | rows | The rows of Elements |
| (Column) | **RETURN** | Used for chaining
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Column Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | visible | control visibility of element |
---------
## Combo Element
ComboBox Element - A combination of a single-line input and a drop-down menu. User can type in their own value or choose from list.
```
Combo(values,
default_value = None,
size = (None, None),
s = (None, None),
auto_size_text = None,
background_color = None,
text_color = None,
bind_return_key = False,
change_submits = False,
enable_events = False,
disabled = False,
key = None,
k = None,
pad = None,
expand_x = False,
expand_y = False,
tooltip = None,
readonly = False,
font = None,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[Any] or Tuple[Any] | values | values to choose. While displayed as text, the items returned are what the caller supplied, not text |
| Any | default_value | Choice to be displayed as initial value. Must match one of values variable contents |
| (int, int) or (None, None) or int | size | width, height. Width = characters-wide, height = NOTE it's the number of entries to show in the list. If an Int is passed rather than a tuple, then height is auto-set to 1 and width is value of the int |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_text | True if element should be the same size as the contents |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | bind_return_key | If True, then the return key will cause a the Combo to generate an event |
| bool | change_submits | DEPRICATED DO NOT USE. Use `enable_events` instead |
| bool | enable_events | Turns on the element specific events. Combo event is when a choice is made |
| bool | disabled | set disable state for element |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool) :param tooltip: text that will appear when mouse hovers over this element | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | readonly | make element readonly (user can't change). True means user cannot change |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get
Returns the current (right now) value of the Combo. DO NOT USE THIS AS THE NORMAL WAY OF READING A COMBO!
You should be using values from your call to window.read instead. Know what you're doing if you use it.
`get()`
|Type|Name|Meaning|
|---|---|---|
|Any | None| **return** | Returns the value of what is currently chosen |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Combo Element. Must call `Window.Read` or `Window.Finalize` prior.
Note that the state can be in 3 states only.... enabled, disabled, readonly even
though more combinations are available. The easy way to remember is that if you
change the readonly parameter then you are enabling the element.
```
update(value = None,
values = None,
set_to_index = None,
disabled = None,
readonly = None,
font = None,
visible = None,
size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | value | change which value is current selected based on new list of previous list of choices |
| List[Any] | values | change list of choices |
| int | set_to_index | change selection to a particular choice starting with index = 0 |
| bool | disabled | disable or enable state of the element |
| bool | readonly | if True make element readonly (user cannot change any choices). Enables the element if either choice are made. |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | visible | control visibility of element |
| (int, int) | size | width, height. Width = characters-wide, height = NOTE it's the number of entries to show in the list |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### Get
Returns the current (right now) value of the Combo. DO NOT USE THIS AS THE NORMAL WAY OF READING A COMBO!
You should be using values from your call to window.read instead. Know what you're doing if you use it.
`Get()`
|Type|Name|Meaning|
|---|---|---|
|Any | None| **return** | Returns the value of what is currently chosen |
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Combo Element. Must call `Window.Read` or `Window.Finalize` prior.
Note that the state can be in 3 states only.... enabled, disabled, readonly even
though more combinations are available. The easy way to remember is that if you
change the readonly parameter then you are enabling the element.
```
Update(value = None,
values = None,
set_to_index = None,
disabled = None,
readonly = None,
font = None,
visible = None,
size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | value | change which value is current selected based on new list of previous list of choices |
| List[Any] | values | change list of choices |
| int | set_to_index | change selection to a particular choice starting with index = 0 |
| bool | disabled | disable or enable state of the element |
| bool | readonly | if True make element readonly (user cannot change any choices). Enables the element if either choice are made. |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | visible | control visibility of element |
| (int, int) | size | width, height. Width = characters-wide, height = NOTE it's the number of entries to show in the list |
---------
## Frame Element
A Frame Element that contains other Elements. Encloses with a line around elements and a text label.
```
Frame(title,
layout,
title_color = None,
background_color = None,
title_location = None,
relief = "groove",
size = (None, None),
s = (None, None),
font = None,
pad = None,
border_width = None,
key = None,
k = None,
tooltip = None,
right_click_menu = None,
expand_x = False,
expand_y = False,
visible = True,
element_justification = "left",
vertical_alignment = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | title | text that is displayed as the Frame's "label" or title |
| List[List[Elements]] | layout | The layout to put inside the Frame |
| str | title_color | color of the title text |
| str | background_color | background color of the Frame |
| enum | title_location | location to place the text title. Choices include: TITLE_LOCATION_TOP TITLE_LOCATION_BOTTOM TITLE_LOCATION_LEFT TITLE_LOCATION_RIGHT TITLE_LOCATION_TOP_LEFT TITLE_LOCATION_TOP_RIGHT TITLE_LOCATION_BOTTOM_LEFT TITLE_LOCATION_BOTTOM_RIGHT |
| enum | relief | relief style. Values are same as other elements with reliefs. Choices include RELIEF_RAISED RELIEF_SUNKEN RELIEF_FLAT RELIEF_RIDGE RELIEF_GROOVE RELIEF_SOLID |
| (int, int) | size | (width, height) DO NOT use this. Instead, place your layout in a Column element with the size set on the Column element. Set pad=(0,0) on your Column |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| int | border_width | width of border around element in pixels |
| str or int or tuple or object | key | Value that uniquely identifies this element from all other elements. Used when Finding an element or in return values. Must be unique to the window |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| str | tooltip | text, that will appear when mouse hovers over the element |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | visible | set visibility state of the element |
| str | element_justification | All elements inside the Frame will have this justification 'left', 'right', 'center' are valid values |
| str | vertical_alignment | Place the column at the 'top', 'center', 'bottom' of the row (can also use t,c,r). Defaults to no setting (tkinter decides) |
| Any | metadata | User metadata that can be set to ANYTHING |
### add_row
Not recommended user call. Used to add rows of Elements to the Frame Element.
```
add_row(args=*<1 or N object>)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[Element] | *args | The list of elements for this row |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### layout
Can use like the Window.Layout method, but it's better to use the layout parameter when creating
```
layout(rows)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Element]] | rows | The rows of Elements |
| (Frame) | **RETURN** | Used for chaining
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Frame Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(value = None, visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | value | New text value to show on frame |
| bool | visible | control visibility of element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### AddRow
Not recommended user call. Used to add rows of Elements to the Frame Element.
```
AddRow(args=*<1 or N object>)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[Element] | *args | The list of elements for this row |
### Layout
Can use like the Window.Layout method, but it's better to use the layout parameter when creating
```
Layout(rows)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Element]] | rows | The rows of Elements |
| (Frame) | **RETURN** | Used for chaining
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Frame Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(value = None, visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | value | New text value to show on frame |
| bool | visible | control visibility of element |
---------
## Graph Element
Creates an area for you to draw on. The MAGICAL property this Element has is that you interact
with the element using your own coordinate system. This is an important point!! YOU define where the location
is for (0,0). Want (0,0) to be in the middle of the graph like a math 4-quadrant graph? No problem! Set your
lower left corner to be (-100,-100) and your upper right to be (100,100) and you've got yourself a graph with
(0,0) at the center.
One of THE coolest of the Elements.
You can also use float values. To do so, be sure and set the float_values parameter.
Mouse click and drag events are possible and return the (x,y) coordinates of the mouse
Drawing primitives return an "id" that is referenced when you want to operation on that item (e.g. to erase it)
```
Graph(canvas_size,
graph_bottom_left,
graph_top_right,
background_color = None,
pad = None,
change_submits = False,
drag_submits = False,
enable_events = False,
key = None,
k = None,
tooltip = None,
right_click_menu = None,
expand_x = False,
expand_y = False,
visible = True,
float_values = False,
border_width = 0,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | canvas_size | size of the canvas area in pixels |
| (int, int) | graph_bottom_left | (x,y) The bottoms left corner of your coordinate system |
| (int, int) | graph_top_right | (x,y) The top right corner of your coordinate system |
| str | background_color | background color of the drawing area |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| bool | change_submits | * DEPRICATED DO NOT USE. Use `enable_events` instead |
| bool | drag_submits | if True and Events are enabled for the Graph, will report Events any time the mouse moves while button down |
| bool | enable_events | If True then clicks on the Graph are immediately reported as an event. Use this instead of change_submits |
| str or int or tuple or object | key | Value that uniquely identifies this element from all other elements. Used when Finding an element or in return values. Must be unique to the window |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| str | tooltip | text, that will appear when mouse hovers over the element |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | visible | set visibility state of the element (Default = True) |
| bool | float_values | If True x,y coordinates are returned as floats, not ints |
| int | border_width | width of border around element in pixels. Not normally used for Graph Elements |
| Any | metadata | User metadata that can be set to ANYTHING |
### Update
Changes some of the settings for the Graph Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(background_color = None, visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| ??? | background_color | color of background |
| bool | visible | control visibility of element |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### bring_figure_to_front
Changes Z-order of figures on the Graph. Brings the indicated figure to the front of all other drawn figures
```
bring_figure_to_front(figure)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | figure | value returned by tkinter when creating the figure / drawing |
### change_coordinates
Changes the corrdinate system to a new one. The same 2 points in space are used to define the coorinate
system - the bottom left and the top right values of your graph.
```
change_coordinates(graph_bottom_left, graph_top_right)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) (x,y) | graph_bottom_left | The bottoms left corner of your coordinate system |
| (int, int) (x,y) | graph_top_right | The top right corner of your coordinate system |
### delete_figure
Remove from the Graph the figure represented by id. The id is given to you anytime you call a drawing primitive
```
delete_figure(id)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | id | the id returned to you when calling one of the drawing methods |
### draw_arc
Draws different types of arcs. Uses a "bounding box" to define location
```
draw_arc(top_left,
bottom_right,
extent,
start_angle,
style = None,
arc_color = "black",
line_width = 1,
fill_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or Tuple[float, float] | top_left | the top left point of bounding rectangle |
| (int, int) or Tuple[float, float] | bottom_right | the bottom right point of bounding rectangle |
| float | extent | Andle to end drawing. Used in conjunction with start_angle |
| float | start_angle | Angle to begin drawing. Used in conjunction with extent |
| str | style | Valid choices are One of these Style strings- 'pieslice', 'chord', 'arc', 'first', 'last', 'butt', 'projecting', 'round', 'bevel', 'miter' |
| str | arc_color | color to draw arc with |
| str | fill_color | color to fill the area |
| int or None | **RETURN** | id returned from tkinter that you'll need if you want to manipulate the arc
### draw_circle
Draws a circle, cenetered at the location provided. Can set the fill and outline colors
```
draw_circle(center_location,
radius,
fill_color = None,
line_color = "black",
line_width = 1)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or Tuple[float, float] | center_location | Center location using USER'S coordinate system |
| int or float | radius | Radius in user's coordinate values. |
| str | fill_color | color of the point to draw |
| str | line_color | color of the outer line that goes around the circle (sorry, can't set thickness) |
| int | line_width | width of the line around the circle, the outline, in pixels |
| int or None | **RETURN** | id returned from tkinter that you'll need if you want to manipulate the circle
### draw_image
Places an image onto your canvas. It's a really important method for this element as it enables so much
```
draw_image(filename = None,
data = None,
location = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | filename | if image is in a file, path and filename for the image. (GIF and PNG only!) |
| str or bytes | data | if image is in Base64 format or raw? format then use instead of filename |
| (int, int) or Tuple[float, float] | location | the (x,y) location to place image's top left corner |
| int or None | **RETURN** | id returned from tkinter that you'll need if you want to manipulate the image
### draw_line
Draws a line from one point to another point using USER'S coordinates. Can set the color and width of line
```
draw_line(point_from,
point_to,
color = "black",
width = 1)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or Tuple[float, float] | point_from | Starting point for line |
| (int, int) or Tuple[float, float] | point_to | Ending point for line |
| str | color | Color of the line |
| int | width | width of line in pixels |
| int or None | **RETURN** | id returned from tktiner or None if user closed the window. id is used when you
### draw_oval
Draws an oval based on coordinates in user coordinate system. Provide the location of a "bounding rectangle"
```
draw_oval(top_left,
bottom_right,
fill_color = None,
line_color = None,
line_width = 1)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or Tuple[float, float] | top_left | the top left point of bounding rectangle |
| (int, int) or Tuple[float, float] | bottom_right | the bottom right point of bounding rectangle |
| str | fill_color | color of the interrior |
| str | line_color | color of outline of oval |
| int | line_width | width of the line around the oval, the outline, in pixels |
| int or None | **RETURN** | id returned from tkinter that you'll need if you want to manipulate the oval
### draw_point
Draws a "dot" at the point you specify using the USER'S coordinate system
```
draw_point(point,
size = 2,
color = "black")
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or Tuple[float, float] | point | Center location using USER'S coordinate system |
| int or float | size | Radius? (Or is it the diameter?) in user's coordinate values. |
| str | color | color of the point to draw |
| int or None | **RETURN** | id returned from tkinter that you'll need if you want to manipulate the point
### draw_polygon
Draw a polygon given list of points
```
draw_polygon(points,
fill_color = None,
line_color = None,
line_width = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[(int, int) or Tuple[float, float]] | points | list of points that define the polygon |
| str | fill_color | color of the interior |
| str | line_color | color of outline |
| int | line_width | width of the line in pixels |
| int or None | **RETURN** | id returned from tkinter that you'll need if you want to manipulate the rectangle
### draw_rectangle
Draw a rectangle given 2 points. Can control the line and fill colors
```
draw_rectangle(top_left,
bottom_right,
fill_color = None,
line_color = None,
line_width = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or Tuple[float, float] | top_left | the top left point of rectangle |
| (int, int) or Tuple[float, float] | bottom_right | the bottom right point of rectangle |
| str | fill_color | color of the interior |
| str | line_color | color of outline |
| int | line_width | width of the line in pixels |
| int or None | **RETURN** | int | None id returned from tkinter that you'll need if you want to manipulate the rectangle
### draw_text
Draw some text on your graph. This is how you label graph number lines for example
```
draw_text(text,
location,
color = "black",
font = None,
angle = 0,
text_location = "center")
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | text | text to display |
| (int, int) or Tuple[float, float] | location | location to place first letter |
| str | color | text color |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| float | angle | Angle 0 to 360 to draw the text. Zero represents horizontal text |
| enum | text_location | "anchor" location for the text. Values start with TEXT_LOCATION_ |
| int or None | **RETURN** | id returned from tkinter that you'll need if you want to manipulate the text
### erase
Erase the Graph - Removes all figures previously "drawn" using the Graph methods (e.g. DrawText)
```python
erase()
```
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_bounding_box
Given a figure, returns the upper left and lower right bounding box coordinates
```
get_bounding_box(figure)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| object | figure | a previously drawing figure |
| Tuple[int, int, int, int] or Tuple[float, float, float, float] | **RETURN** | upper left x, upper left y, lower right x, lower right y
### get_figures_at_location
Returns a list of figures located at a particular x,y location within the Graph
```
get_figures_at_location(location)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or Tuple[float, float] | location | point to check |
| List[int] | **RETURN** | a list of previously drawn "Figures" (returned from the drawing primitives)
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### move
Moves the entire drawing area (the canvas) by some delta from the current position. Units are indicated in your coordinate system indicated number of ticks in your coordinate system
```
move(x_direction, y_direction)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int or float | x_direction | how far to move in the "X" direction in your coordinates |
| int or float | y_direction | how far to move in the "Y" direction in your coordinates |
### move_figure
Moves a previously drawn figure using a "delta" from current position
```
move_figure(figure,
x_direction,
y_direction)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| id | figure | Previously obtained figure-id. These are returned from all Draw methods |
| int or float | x_direction | delta to apply to position in the X direction |
| int or float | y_direction | delta to apply to position in the Y direction |
### relocate_figure
Move a previously made figure to an arbitrary (x,y) location. This differs from the Move methods because it
uses absolute coordinates versus relative for Move
```
relocate_figure(figure,
x,
y)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| id | figure | Previously obtained figure-id. These are returned from all Draw methods |
| int or float | x | location on X axis (in user coords) to move the upper left corner of the figure |
| int or float | y | location on Y axis (in user coords) to move the upper left corner of the figure |
### send_figure_to_back
Changes Z-order of figures on the Graph. Sends the indicated figure to the back of all other drawn figures
```
send_figure_to_back(figure)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | figure | value returned by tkinter when creating the figure / drawing |
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### tk_canvas
#### property: tk_canvas
Returns the underlying tkiner Canvas widget
|Type|Name|Meaning|
|---|---|---|
|(tk.Canvas)| **return** | The tkinter canvas widget |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Graph Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(background_color = None, visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| ??? | background_color | color of background |
| bool | visible | control visibility of element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### BringFigureToFront
Changes Z-order of figures on the Graph. Brings the indicated figure to the front of all other drawn figures
```
BringFigureToFront(figure)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | figure | value returned by tkinter when creating the figure / drawing |
### DeleteFigure
Remove from the Graph the figure represented by id. The id is given to you anytime you call a drawing primitive
```
DeleteFigure(id)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | id | the id returned to you when calling one of the drawing methods |
### DrawArc
Draws different types of arcs. Uses a "bounding box" to define location
```
DrawArc(top_left,
bottom_right,
extent,
start_angle,
style = None,
arc_color = "black",
line_width = 1,
fill_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or Tuple[float, float] | top_left | the top left point of bounding rectangle |
| (int, int) or Tuple[float, float] | bottom_right | the bottom right point of bounding rectangle |
| float | extent | Andle to end drawing. Used in conjunction with start_angle |
| float | start_angle | Angle to begin drawing. Used in conjunction with extent |
| str | style | Valid choices are One of these Style strings- 'pieslice', 'chord', 'arc', 'first', 'last', 'butt', 'projecting', 'round', 'bevel', 'miter' |
| str | arc_color | color to draw arc with |
| str | fill_color | color to fill the area |
| int or None | **RETURN** | id returned from tkinter that you'll need if you want to manipulate the arc
### DrawCircle
Draws a circle, cenetered at the location provided. Can set the fill and outline colors
```
DrawCircle(center_location,
radius,
fill_color = None,
line_color = "black",
line_width = 1)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or Tuple[float, float] | center_location | Center location using USER'S coordinate system |
| int or float | radius | Radius in user's coordinate values. |
| str | fill_color | color of the point to draw |
| str | line_color | color of the outer line that goes around the circle (sorry, can't set thickness) |
| int | line_width | width of the line around the circle, the outline, in pixels |
| int or None | **RETURN** | id returned from tkinter that you'll need if you want to manipulate the circle
### DrawImage
Places an image onto your canvas. It's a really important method for this element as it enables so much
```
DrawImage(filename = None,
data = None,
location = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | filename | if image is in a file, path and filename for the image. (GIF and PNG only!) |
| str or bytes | data | if image is in Base64 format or raw? format then use instead of filename |
| (int, int) or Tuple[float, float] | location | the (x,y) location to place image's top left corner |
| int or None | **RETURN** | id returned from tkinter that you'll need if you want to manipulate the image
### DrawLine
Draws a line from one point to another point using USER'S coordinates. Can set the color and width of line
```
DrawLine(point_from,
point_to,
color = "black",
width = 1)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or Tuple[float, float] | point_from | Starting point for line |
| (int, int) or Tuple[float, float] | point_to | Ending point for line |
| str | color | Color of the line |
| int | width | width of line in pixels |
| int or None | **RETURN** | id returned from tktiner or None if user closed the window. id is used when you
### DrawOval
Draws an oval based on coordinates in user coordinate system. Provide the location of a "bounding rectangle"
```
DrawOval(top_left,
bottom_right,
fill_color = None,
line_color = None,
line_width = 1)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or Tuple[float, float] | top_left | the top left point of bounding rectangle |
| (int, int) or Tuple[float, float] | bottom_right | the bottom right point of bounding rectangle |
| str | fill_color | color of the interrior |
| str | line_color | color of outline of oval |
| int | line_width | width of the line around the oval, the outline, in pixels |
| int or None | **RETURN** | id returned from tkinter that you'll need if you want to manipulate the oval
### DrawPoint
Draws a "dot" at the point you specify using the USER'S coordinate system
```
DrawPoint(point,
size = 2,
color = "black")
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or Tuple[float, float] | point | Center location using USER'S coordinate system |
| int or float | size | Radius? (Or is it the diameter?) in user's coordinate values. |
| str | color | color of the point to draw |
| int or None | **RETURN** | id returned from tkinter that you'll need if you want to manipulate the point
### DrawPolygon
Draw a polygon given list of points
```
DrawPolygon(points,
fill_color = None,
line_color = None,
line_width = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[(int, int) or Tuple[float, float]] | points | list of points that define the polygon |
| str | fill_color | color of the interior |
| str | line_color | color of outline |
| int | line_width | width of the line in pixels |
| int or None | **RETURN** | id returned from tkinter that you'll need if you want to manipulate the rectangle
### DrawRectangle
Draw a rectangle given 2 points. Can control the line and fill colors
```
DrawRectangle(top_left,
bottom_right,
fill_color = None,
line_color = None,
line_width = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or Tuple[float, float] | top_left | the top left point of rectangle |
| (int, int) or Tuple[float, float] | bottom_right | the bottom right point of rectangle |
| str | fill_color | color of the interior |
| str | line_color | color of outline |
| int | line_width | width of the line in pixels |
| int or None | **RETURN** | int | None id returned from tkinter that you'll need if you want to manipulate the rectangle
### DrawText
Draw some text on your graph. This is how you label graph number lines for example
```
DrawText(text,
location,
color = "black",
font = None,
angle = 0,
text_location = "center")
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | text | text to display |
| (int, int) or Tuple[float, float] | location | location to place first letter |
| str | color | text color |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| float | angle | Angle 0 to 360 to draw the text. Zero represents horizontal text |
| enum | text_location | "anchor" location for the text. Values start with TEXT_LOCATION_ |
| int or None | **RETURN** | id returned from tkinter that you'll need if you want to manipulate the text
### Erase
Erase the Graph - Removes all figures previously "drawn" using the Graph methods (e.g. DrawText)
```python
Erase()
```
### GetBoundingBox
Given a figure, returns the upper left and lower right bounding box coordinates
```
GetBoundingBox(figure)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| object | figure | a previously drawing figure |
| Tuple[int, int, int, int] or Tuple[float, float, float, float] | **RETURN** | upper left x, upper left y, lower right x, lower right y
### GetFiguresAtLocation
Returns a list of figures located at a particular x,y location within the Graph
```
GetFiguresAtLocation(location)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or Tuple[float, float] | location | point to check |
| List[int] | **RETURN** | a list of previously drawn "Figures" (returned from the drawing primitives)
### Move
Moves the entire drawing area (the canvas) by some delta from the current position. Units are indicated in your coordinate system indicated number of ticks in your coordinate system
```
Move(x_direction, y_direction)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int or float | x_direction | how far to move in the "X" direction in your coordinates |
| int or float | y_direction | how far to move in the "Y" direction in your coordinates |
### MoveFigure
Moves a previously drawn figure using a "delta" from current position
```
MoveFigure(figure,
x_direction,
y_direction)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| id | figure | Previously obtained figure-id. These are returned from all Draw methods |
| int or float | x_direction | delta to apply to position in the X direction |
| int or float | y_direction | delta to apply to position in the Y direction |
### RelocateFigure
Move a previously made figure to an arbitrary (x,y) location. This differs from the Move methods because it
uses absolute coordinates versus relative for Move
```
RelocateFigure(figure,
x,
y)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| id | figure | Previously obtained figure-id. These are returned from all Draw methods |
| int or float | x | location on X axis (in user coords) to move the upper left corner of the figure |
| int or float | y | location on Y axis (in user coords) to move the upper left corner of the figure |
### SendFigureToBack
Changes Z-order of figures on the Graph. Sends the indicated figure to the back of all other drawn figures
```
SendFigureToBack(figure)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | figure | value returned by tkinter when creating the figure / drawing |
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### TKCanvas
#### property: TKCanvas
Returns the underlying tkiner Canvas widget
|Type|Name|Meaning|
|---|---|---|
|(tk.Canvas)| **return** | The tkinter canvas widget |
---------
## HorizontalSeparator Element
Horizontal Separator Element draws a Horizontal line at the given location.
```
HorizontalSeparator(color = None,
pad = None,
key = None,
k = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | color | Color of the line. Defaults to theme's text color. Can be name or #RRGGBB format |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | Value that uniquely identifies this element from all other elements. Used when Finding an element or in return values. Must be unique to the window |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
---------
## Image Element
Image Element - show an image in the window. Should be a GIF or a PNG only
```
Image(source = None,
filename = None,
data = None,
background_color = None,
size = (None, None),
s = (None, None),
pad = None,
key = None,
k = None,
tooltip = None,
right_click_menu = None,
expand_x = False,
expand_y = False,
visible = True,
enable_events = False,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str or bytes or None | source | A filename or a base64 bytes. Will automatically detect the type and fill in filename or data for you. |
| str or None | filename | image filename if there is a button image. GIFs and PNGs only. |
| bytes or str or None | data | Raw or Base64 representation of the image to put on button. Choose either filename or data |
| | background_color | color of background |
| (int, int) | size | (width, height) size of image in pixels |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| str | tooltip | text, that will appear when mouse hovers over the element |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | visible | set visibility state of the element |
| bool | enable_events | Turns on the element specific events. For an Image element, the event is "image clicked" |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Image Element. Must call `Window.Read` or `Window.Finalize` prior.
To clear an image that's been displayed, call with NONE of the options set. A blank update call will
delete the previously shown image.
```
update(source = None,
filename = None,
data = None,
size = (None, None),
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str or bytes or None | source | A filename or a base64 bytes. Will automatically detect the type and fill in filename or data for you. |
| str | filename | filename to the new image to display. |
| str or tkPhotoImage | data | Base64 encoded string OR a tk.PhotoImage object |
| Tuple[int,int] | size | (width, height) size of image in pixels |
| bool | visible | control visibility of element |
### update_animation
Show an Animated GIF. Call the function as often as you like. The function will determine when to show the next frame and will automatically advance to the next frame at the right time.
NOTE - does NOT perform a sleep call to delay
```
update_animation(source, time_between_frames = 0)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str or bytes or None | source | Filename or Base64 encoded string containing Animated GIF |
| int | time_between_frames | Number of milliseconds to wait between showing frames |
### update_animation_no_buffering
Show an Animated GIF. Call the function as often as you like. The function will determine when to show the next frame and will automatically advance to the next frame at the right time.
NOTE - does NOT perform a sleep call to delay
```
update_animation_no_buffering(source, time_between_frames = 0)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str or bytes | source | Filename or Base64 encoded string containing Animated GIF |
| int | time_between_frames | Number of milliseconds to wait between showing frames |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Image Element. Must call `Window.Read` or `Window.Finalize` prior.
To clear an image that's been displayed, call with NONE of the options set. A blank update call will
delete the previously shown image.
```
Update(source = None,
filename = None,
data = None,
size = (None, None),
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str or bytes or None | source | A filename or a base64 bytes. Will automatically detect the type and fill in filename or data for you. |
| str | filename | filename to the new image to display. |
| str or tkPhotoImage | data | Base64 encoded string OR a tk.PhotoImage object |
| Tuple[int,int] | size | (width, height) size of image in pixels |
| bool | visible | control visibility of element |
### UpdateAnimation
Show an Animated GIF. Call the function as often as you like. The function will determine when to show the next frame and will automatically advance to the next frame at the right time.
NOTE - does NOT perform a sleep call to delay
```
UpdateAnimation(source, time_between_frames = 0)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str or bytes or None | source | Filename or Base64 encoded string containing Animated GIF |
| int | time_between_frames | Number of milliseconds to wait between showing frames |
---------
## Input Element
Display a single text input field. Based on the tkinter Widget `Entry`
```
Input(default_text = "",
size = (None, None),
s = (None, None),
disabled = False,
password_char = "",
justification = None,
background_color = None,
text_color = None,
font = None,
tooltip = None,
border_width = None,
change_submits = False,
enable_events = False,
do_not_clear = True,
key = None,
k = None,
focus = False,
pad = None,
use_readonly_for_disable = True,
readonly = False,
disabled_readonly_background_color = None,
disabled_readonly_text_color = None,
expand_x = False,
expand_y = False,
right_click_menu = None,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | default_text | Text initially shown in the input box as a default value(Default value = ''). Will automatically be converted to string |
| (int, int) or (int, None) or int | size | w=characters-wide, h=rows-high. If an int is supplied rather than a tuple, then a tuple is created width=int supplied and heigh=1 |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | disabled | set disable state for element (Default = False) |
| char | password_char | Password character if this is a password field (Default value = '') |
| str | justification | justification for data display. Valid choices - left, right, center |
| str | background_color | color of background in one of the color formats |
| str | text_color | color of the text |
| (str or (str, int[, str]) or None) | font | specifies the font family, size. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str | tooltip | text, that will appear when mouse hovers over the element |
| int | border_width | width of border around element in pixels |
| bool | change_submits | * DEPRICATED DO NOT USE. Use `enable_events` instead |
| bool | enable_events | If True then changes to this element are immediately reported as an event. Use this instead of change_submits (Default = False) |
| bool | do_not_clear | If False then the field will be set to blank after ANY event (button, any event) (Default = True) |
| str or int or tuple or object | key | Value that uniquely identifies this element from all other elements. Used when Finding an element or in return values. Must be unique to the window |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| bool | focus | Determines if initial focus should go to this element. |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element. Normally (horizontal pixels, vertical pixels) but can be split apart further into ((horizontal left, horizontal right), (vertical above, vertical below)). If int is given, then converted to tuple (int, int) with the value provided duplicated |
| bool | use_readonly_for_disable | If True (the default) tkinter state set to 'readonly'. Otherwise state set to 'disabled' |
| bool | readonly | If True tkinter state set to 'readonly'. Use this in place of use_readonly_for_disable as another way of achieving readonly. Note cannot set BOTH readonly and disabled as tkinter only supplies a single flag |
| str | disabled_readonly_background_color | If state is set to readonly or disabled, the color to use for the background |
| str | disabled_readonly_text_color | If state is set to readonly or disabled, the color to use for the text |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | visible | set visibility state of the element (Default = True) |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get
Read and return the current value of the input element. Must call `Window.Read` or `Window.Finalize` prior
`get()`
|Type|Name|Meaning|
|---|---|---|
|(str)| **return** | current value of Input field or '' if error encountered |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### set_vscroll_position
Attempts to set the vertical scroll postition for an element's Widget
```
set_vscroll_position(percent_from_top)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| float | percent_from_top | From 0 to 1.0, the percentage from the top to move scrollbar to |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Input Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(value = None,
disabled = None,
select = None,
visible = None,
text_color = None,
background_color = None,
move_cursor_to = "end",
password_char = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | value | new text to display as default text in Input field |
| bool | disabled | disable or enable state of the element (sets Entry Widget to readonly or normal) |
| bool | select | if True, then the text will be selected |
| bool | visible | change visibility of element |
| str | text_color | change color of text being typed |
| str | background_color | change color of the background |
| int or str | move_cursor_to | Moves the cursor to a particular offset. Defaults to 'end' |
| str | password_char | Password character if this is a password field |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### Get
Read and return the current value of the input element. Must call `Window.Read` or `Window.Finalize` prior
`Get()`
|Type|Name|Meaning|
|---|---|---|
|(str)| **return** | current value of Input field or '' if error encountered |
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Input Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(value = None,
disabled = None,
select = None,
visible = None,
text_color = None,
background_color = None,
move_cursor_to = "end",
password_char = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | value | new text to display as default text in Input field |
| bool | disabled | disable or enable state of the element (sets Entry Widget to readonly or normal) |
| bool | select | if True, then the text will be selected |
| bool | visible | change visibility of element |
| str | text_color | change color of text being typed |
| str | background_color | change color of the background |
| int or str | move_cursor_to | Moves the cursor to a particular offset. Defaults to 'end' |
| str | password_char | Password character if this is a password field |
---------
## Listbox Element
A List Box. Provide a list of values for the user to choose one or more of. Returns a list of selected rows
when a window.read() is executed.
```
Listbox(values,
default_values = None,
select_mode = None,
change_submits = False,
enable_events = False,
bind_return_key = False,
size = (None, None),
s = (None, None),
disabled = False,
auto_size_text = None,
font = None,
no_scrollbar = False,
background_color = None,
text_color = None,
highlight_background_color = None,
highlight_text_color = None,
key = None,
k = None,
pad = None,
tooltip = None,
expand_x = False,
expand_y = False,
right_click_menu = None,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[Any] or Tuple[Any] | values | list of values to display. Can be any type including mixed types as long as they have __str__ method |
| List[Any] | default_values | which values should be initially selected |
| [enum] | select_mode | Select modes are used to determine if only 1 item can be selected or multiple and how they can be selected. Valid choices begin with "LISTBOX_SELECT_MODE_" and include: LISTBOX_SELECT_MODE_SINGLE LISTBOX_SELECT_MODE_MULTIPLE LISTBOX_SELECT_MODE_BROWSE LISTBOX_SELECT_MODE_EXTENDED |
| bool | change_submits | DO NOT USE. Only listed for backwards compat - Use enable_events instead |
| bool | enable_events | Turns on the element specific events. Listbox generates events when an item is clicked |
| bool | bind_return_key | If True, then the return key will cause a the Listbox to generate an event |
| (int, int) or (int, None) or int | size | w=characters-wide, h=rows-high. If an int instead of a tuple is supplied, then height is auto-set to 1 |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | disabled | set disable state for element |
| bool | auto_size_text | True if element should be the same size as the contents |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_scrollbar | Controls if a scrollbar should be shown. If True, no scrollbar will be shown |
| str | background_color | color of background |
| str | text_color | color of the text |
| str | highlight_background_color | color of the background when an item is selected. Defaults to normal text color (a reverse look) |
| str | highlight_text_color | color of the text when an item is selected. Defaults to the normal background color (a rerverse look) |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str | tooltip | text, that will appear when mouse hovers over the element |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get
Returns the list of items currently selected in this listbox. It should be identical
to the value you would receive when performing a window.read() call.
`get()`
|Type|Name|Meaning|
|---|---|---|
|List[Any]| **return** | The list of currently selected items. The actual items are returned, not the indexes |
### get_indexes
Returns the items currently selected as a list of indexes
`get_indexes()`
|Type|Name|Meaning|
|---|---|---|
|List[int]| **return** | A list of offsets into values that is currently selected |
### get_list_values
Returns list of Values provided by the user in the user's format
`get_list_values()`
|Type|Name|Meaning|
|---|---|---|
|List[Any]| **return** | List of values. Can be any / mixed types -> [] |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### set_value
Set listbox highlighted choices
```
set_value(values)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[Any] or Tuple[Any] | values | new values to choose based on previously set values |
### set_vscroll_position
Attempts to set the vertical scroll postition for an element's Widget
```
set_vscroll_position(percent_from_top)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| float | percent_from_top | From 0 to 1.0, the percentage from the top to move scrollbar to |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Listbox Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(values = None,
disabled = None,
set_to_index = None,
scroll_to_index = None,
select_mode = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[Any] | values | new list of choices to be shown to user |
| bool | disabled | disable or enable state of the element |
| int or list or tuple | set_to_index | highlights the item(s) indicated. If parm is an int one entry will be set. If is a list, then each entry in list is highlighted |
| int | scroll_to_index | scroll the listbox so that this index is the first shown |
| str | select_mode | changes the select mode according to tkinter's listbox widget |
| bool | visible | control visibility of element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### GetIndexes
Returns the items currently selected as a list of indexes
`GetIndexes()`
|Type|Name|Meaning|
|---|---|---|
|List[int]| **return** | A list of offsets into values that is currently selected |
### GetListValues
Returns list of Values provided by the user in the user's format
`GetListValues()`
|Type|Name|Meaning|
|---|---|---|
|List[Any]| **return** | List of values. Can be any / mixed types -> [] |
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### SetValue
Set listbox highlighted choices
```
SetValue(values)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[Any] or Tuple[Any] | values | new values to choose based on previously set values |
### Update
Changes some of the settings for the Listbox Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(values = None,
disabled = None,
set_to_index = None,
scroll_to_index = None,
select_mode = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[Any] | values | new list of choices to be shown to user |
| bool | disabled | disable or enable state of the element |
| int or list or tuple | set_to_index | highlights the item(s) indicated. If parm is an int one entry will be set. If is a list, then each entry in list is highlighted |
| int | scroll_to_index | scroll the listbox so that this index is the first shown |
| str | select_mode | changes the select mode according to tkinter's listbox widget |
| bool | visible | control visibility of element |
---------
## Menu Element
Menu Element is the Element that provides a Menu Bar that goes across the top of the window, just below titlebar.
Here is an example layout. The "&" are shortcut keys ALT+key.
Is a List of - "Item String" + List
Where Item String is what will be displayed on the Menubar itself.
The List that follows the item represents the items that are shown then Menu item is clicked
Notice how an "entry" in a mennu can be a list which means it branches out and shows another menu, etc. (resursive)
menu_def = [['&File', ['!&Open', '&Save::savekey', '---', '&Properties', 'E&xit']],
['!&Edit', ['!&Paste', ['Special', 'Normal', ], 'Undo'], ],
['&Debugger', ['Popout', 'Launch Debugger']],
['&Toolbar', ['Command &1', 'Command &2', 'Command &3', 'Command &4']],
['&Help', '&About...'], ]
Finally, "keys" can be added to entries so make them unique. The "Save" entry has a key associated with it. You
can see it has a "::" which signifies the beginning of a key. The user will not see the key portion when the
menu is shown. The key portion is returned as part of the event.
```
Menu(menu_definition,
background_color = None,
text_color = None,
disabled_text_color = None,
size = (None, None),
s = (None, None),
tearoff = False,
font = None,
pad = None,
key = None,
k = None,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Tuple[str, List[str]]] | menu_definition | The Menu definition specified using lists (docs explain the format) |
| str | background_color | color of the background |
| str | text_color | element's text color. Can be in #RRGGBB format or a color name "black" |
| str | disabled_text_color | color to use for text when item is disabled. Can be in #RRGGBB format or a color name "black" |
| (int, int) | size | Not used in the tkinter port |
| (int, int) or (None, None) | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | tearoff | if True, then can tear the menu off from the window ans use as a floating window. Very cool effect |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str or int or tuple or object | key | Value that uniquely identifies this element from all other elements. Used when Finding an element or in return values. Must be unique to the window |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Update a menubar - can change the menu definition and visibility. The entire menu has to be specified
```
update(menu_definition = None, visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Tuple[str, List[str]]] | menu_definition | ??? |
| bool | visible | control visibility of element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Update a menubar - can change the menu definition and visibility. The entire menu has to be specified
```
Update(menu_definition = None, visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Tuple[str, List[str]]] | menu_definition | ??? |
| bool | visible | control visibility of element |
---------
## MenubarCustom Element
Note that while the MenubarCustom is an element, it is implemented using a function.
It is actually a "compound element" that consists of several elements combined into a single Column element.
See the Column element to get a list of method calls available. The function returns a Column element.
A custom Menubar that replaces the OS provided Menubar
Why?
Two reasons - 1. they look great (see custom titlebar) 2. if you have a custom titlebar, then you have to use a custom menubar if you want a menubar
```
MenubarCustom(menu_definition,
disabled_text_color = None,
bar_font = None,
font = None,
tearoff = False,
pad = None,
background_color = None,
text_color = None,
bar_background_color = None,
bar_text_color = None,
key = None,
k = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Tuple[str, List[str]]] | menu_definition | The Menu definition specified using lists (docs explain the format) |
| str | disabled_text_color | color to use for text when item is disabled. Can be in #RRGGBB format or a color name "black" |
| (str or (str, int[, str]) or None) | bar_font | specifies the font family, size to be used for the chars in the bar itself |
| (str or (str, int[, str]) or None) | font | specifies the font family, size to be used for the menu items |
| bool | tearoff | if True, then can tear the menu off from the window ans use as a floating window. Very cool effect |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str | background_color | color to use for background of the menus that are displayed after making a section. Can be in #RRGGBB format or a color name "black". Defaults to the color of the bar text |
| str | text_color | color to use for the text of the many items in the displayed menus. Can be in #RRGGBB format or a color name "black". Defaults to the bar background |
| str | bar_background_color | color to use for the menubar. Can be in #RRGGBB format or a color name "black". Defaults to theme's button text color |
| str | bar_text_color | color to use for the menu items text when item is disabled. Can be in #RRGGBB format or a color name "black". Defaults to theme's button background color |
| str or int or tuple or object | key | Value that uniquely identifies this element from all other elements. Used when Finding an element or in return values. Must be unique to the window |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
---------
## Multiline Element
Multiline Element - Display and/or read multiple lines of text. This is both an input and output element.
Other PySimpleGUI ports have a separate MultilineInput and MultilineOutput elements. May want to split this
one up in the future too.
```
Multiline(default_text = "",
enter_submits = False,
disabled = False,
autoscroll = False,
border_width = None,
size = (None, None),
s = (None, None),
auto_size_text = None,
background_color = None,
text_color = None,
change_submits = False,
enable_events = False,
do_not_clear = True,
key = None,
k = None,
write_only = False,
auto_refresh = False,
reroute_stdout = False,
reroute_stderr = False,
reroute_cprint = False,
echo_stdout_stderr = False,
focus = False,
font = None,
pad = None,
tooltip = None,
justification = None,
no_scrollbar = False,
expand_x = False,
expand_y = False,
rstrip = True,
right_click_menu = None,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | default_text | Initial text to show |
| bool | enter_submits | if True, the Window.Read call will return is enter key is pressed in this element |
| bool | disabled | set disable state |
| bool | autoscroll | If True the contents of the element will automatically scroll as more data added to the end |
| int | border_width | width of border around element in pixels |
| (int, int) or (None, None) or int | size | (w, h) w=characters-wide, h=rows-high. If an int instead of a tuple is supplied, then height is auto-set to 1 |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_text | if True will size the element to match the length of the text |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | change_submits | DO NOT USE. Only listed for backwards compat - Use enable_events instead |
| bool | enable_events | Turns on the element specific events. Spin events happen when an item changes |
| bool | do_not_clear | if False the element will be cleared any time the Window.Read call returns |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| bool | write_only | If True then no entry will be added to the values dictionary when the window is read |
| bool | auto_refresh | If True then anytime the element is updated, the window will be refreshed so that the change is immediately displayed |
| bool | reroute_stdout | If True then all output to stdout will be output to this element |
| bool | reroute_stderr | If True then all output to stderr will be output to this element |
| bool | reroute_cprint | If True your cprint calls will output to this element. It's the same as you calling cprint_set_output_destination |
| bool | echo_stdout_stderr | If True then output to stdout and stderr will be output to this element AND also to the normal console location |
| bool | focus | if True initial focus will go to this element |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str | tooltip | text, that will appear when mouse hovers over the element |
| str | justification | text justification. left, right, center. Can use single characters l, r, c. |
| bool | no_scrollbar | If False then a scrollbar will be shown (the default) |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | rstrip | If True the value returned in will have whitespace stripped from the right side |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get
Return current contents of the Multiline Element
`get()`
|Type|Name|Meaning|
|---|---|---|
|(str)| **return** | current contents of the Multiline Element (used as an input type of Multiline |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### print
Print like Python normally prints except route the output to a multiline element and also add colors if desired
colors -(str, str) or str. A combined text/background color definition in a single parameter
There are also "aliases" for text_color, background_color and colors (t, b, c)
t - An alias for color of the text (makes for shorter calls)
b - An alias for the background_color parameter
c - (str, str) - "shorthand" way of specifying color. (foreground, backgrouned)
c - str - can also be a string of the format "foreground on background" ("white on red")
With the aliases it's possible to write the same print but in more compact ways:
cprint('This will print white text on red background', c=('white', 'red'))
cprint('This will print white text on red background', c='white on red')
cprint('This will print white text on red background', text_color='white', background_color='red')
cprint('This will print white text on red background', t='white', b='red')
```
print(args=*<1 or N object>,
end = None,
sep = None,
text_color = None,
background_color = None,
justification = None,
font = None,
colors = None,
t = None,
b = None,
c = None,
autoscroll = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | args | The arguments to print |
| str | end | The end char to use just like print uses |
| str | sep | The separation character like print uses |
| str | text_color | The color of the text |
| str | background_color | The background color of the line |
| str | justification | text justification. left, right, center. Can use single characters l, r, c. Sets only for this value, not entire element |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike for the args being printed |
| str or str, str | colors | Either a tuple or a string that has both the text and background colors. Or just the text color |
| str | t | Color of the text |
| str | b | The background color of the line |
| str or str, str | c | Either a tuple or a string that has both the text and background colors or just tex color (same as the color parm) |
| bool | autoscroll | If True the contents of the element will automatically scroll as more data added to the end |
### reroute_stderr_to_here
Sends stderr to this element
```python
reroute_stderr_to_here()
```
### reroute_stdout_to_here
Sends stdout (prints) to this element
```python
reroute_stdout_to_here()
```
### restore_stderr
Restore a previously re-reouted stderr back to the original destination
```python
restore_stderr()
```
### restore_stdout
Restore a previously re-reouted stdout back to the original destination
```python
restore_stdout()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### set_vscroll_position
Attempts to set the vertical scroll postition for an element's Widget
```
set_vscroll_position(percent_from_top)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| float | percent_from_top | From 0 to 1.0, the percentage from the top to move scrollbar to |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Multiline Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(value = None,
disabled = None,
append = False,
font = None,
text_color = None,
background_color = None,
text_color_for_value = None,
background_color_for_value = None,
visible = None,
autoscroll = None,
justification = None,
font_for_value = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | value | new text to display |
| bool | disabled | disable or enable state of the element |
| bool | append | if True then new value will be added onto the end of the current value. if False then contents will be replaced. |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike for the entire element |
| str | text_color | color of the text |
| str | background_color | color of background |
| str | text_color_for_value | color of the new text being added (the value paramter) |
| str | background_color_for_value | color of the new background of the text being added (the value paramter) |
| bool | visible | set visibility state of the element |
| bool | autoscroll | if True then contents of element are scrolled down when new text is added to the end |
| str | justification | text justification. left, right, center. Can use single characters l, r, c. Sets only for this value, not entire element |
| str or (str, int) | font_for_value | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike for the value being updated |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### Get
Return current contents of the Multiline Element
`Get()`
|Type|Name|Meaning|
|---|---|---|
|(str)| **return** | current contents of the Multiline Element (used as an input type of Multiline |
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Multiline Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(value = None,
disabled = None,
append = False,
font = None,
text_color = None,
background_color = None,
text_color_for_value = None,
background_color_for_value = None,
visible = None,
autoscroll = None,
justification = None,
font_for_value = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | value | new text to display |
| bool | disabled | disable or enable state of the element |
| bool | append | if True then new value will be added onto the end of the current value. if False then contents will be replaced. |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike for the entire element |
| str | text_color | color of the text |
| str | background_color | color of background |
| str | text_color_for_value | color of the new text being added (the value paramter) |
| str | background_color_for_value | color of the new background of the text being added (the value paramter) |
| bool | visible | set visibility state of the element |
| bool | autoscroll | if True then contents of element are scrolled down when new text is added to the end |
| str | justification | text justification. left, right, center. Can use single characters l, r, c. Sets only for this value, not entire element |
| str or (str, int) | font_for_value | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike for the value being updated |
---------
## OptionMenu Element
Option Menu is an Element available ONLY on the tkinter port of PySimpleGUI. It's is a widget that is unique
to tkinter. However, it looks much like a ComboBox. Instead of an arrow to click to pull down the list of
choices, another little graphic is shown on the widget to indicate where you click. After clicking to activate,
it looks like a Combo Box that you scroll to select a choice.
```
OptionMenu(values,
default_value = None,
size = (None, None),
s = (None, None),
disabled = False,
auto_size_text = None,
expand_x = False,
expand_y = False,
background_color = None,
text_color = None,
key = None,
k = None,
pad = None,
tooltip = None,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[Any] or Tuple[Any] | values | Values to be displayed |
| Any | default_value | the value to choose by default |
| (int, int) (width, UNUSED) | size | (width, height) size in characters (wide), height is ignored and present to be consistent with other elements |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | disabled | control enabled / disabled |
| bool | auto_size_text | True if size of Element should match the contents of the items |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| str | background_color | color of background |
| str | text_color | color of the text |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str | tooltip | text that will appear when mouse hovers over this element |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### set_vscroll_position
Attempts to set the vertical scroll postition for an element's Widget
```
set_vscroll_position(percent_from_top)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| float | percent_from_top | From 0 to 1.0, the percentage from the top to move scrollbar to |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the OptionMenu Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(value = None,
values = None,
disabled = None,
visible = None,
size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | value | the value to choose by default |
| List[Any] | values | Values to be displayed |
| bool | disabled | disable or enable state of the element |
| bool | visible | control visibility of element |
| (int, int) (width, UNUSED) | size | (width, height) size in characters (wide), height is ignored and present to be consistent with other elements |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the OptionMenu Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(value = None,
values = None,
disabled = None,
visible = None,
size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | value | the value to choose by default |
| List[Any] | values | Values to be displayed |
| bool | disabled | disable or enable state of the element |
| bool | visible | control visibility of element |
| (int, int) (width, UNUSED) | size | (width, height) size in characters (wide), height is ignored and present to be consistent with other elements |
---------
## Output Element
Output Element - a multi-lined text area where stdout and stderr are re-routed to.
The Multiline Element is the superior and recommended method for showing the output of stdout.
The Multiline Element has been added to significantly while the Output element has not.
Of course, Output Element continues to operate and be backwards compatible, but you're missing out on
features such as routing the cprint output to the element.
```
Output(size = (None, None),
s = (None, None),
background_color = None,
text_color = None,
pad = None,
echo_stdout_stderr = False,
font = None,
tooltip = None,
key = None,
k = None,
right_click_menu = None,
expand_x = False,
expand_y = False,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or (None, None) or int | size | (w, h) w=characters-wide, h=rows-high. If an int instead of a tuple is supplied, then height is auto-set to 1 |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| str | background_color | color of background |
| str | text_color | color of the text |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| bool | echo_stdout_stderr | If True then output to stdout will be output to this element AND also to the normal console location |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str | tooltip | text, that will appear when mouse hovers over the element |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### tk_out
#### property: tk_out
Returns the TKOutput object used to create the element
|Type|Name|Meaning|
|---|---|---|
|(TKOutput)| **return** | The TKOutput object |
### set_vscroll_position
Attempts to set the vertical scroll postition for an element's Widget
```
set_vscroll_position(percent_from_top)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| float | percent_from_top | From 0 to 1.0, the percentage from the top to move scrollbar to |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Output Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(value = None, visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | value | string that will replace current contents of the output area |
| bool | visible | control visibility of element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### Get
Returns the current contents of the output. Similar to Get method other Elements
`Get()`
|Type|Name|Meaning|
|---|---|---|
|(str)| **return** | the current value of the output |
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### TKOut
#### property: TKOut
Returns the TKOutput object used to create the element
|Type|Name|Meaning|
|---|---|---|
|(TKOutput)| **return** | The TKOutput object |
### Update
Changes some of the settings for the Output Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(value = None, visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | value | string that will replace current contents of the output area |
| bool | visible | control visibility of element |
---------
## Pane Element
A sliding Pane that is unique to tkinter. Uses Columns to create individual panes
```
Pane(pane_list,
background_color = None,
size = (None, None),
s = (None, None),
pad = None,
orientation = "vertical",
show_handle = True,
relief = "raised",
handle_size = None,
border_width = None,
key = None,
k = None,
expand_x = None,
expand_y = None,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[Column] | pane_list | Must be a list of Column Elements. Each Column supplied becomes one pane that's shown |
| str | background_color | color of background |
| (int, int) | size | (width, height) w=characters-wide, h=rows-high How much room to reserve for the Pane |
| (int, int) or (None, None) | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str | orientation | 'horizontal' or 'vertical' or ('h' or 'v'). Direction the Pane should slide |
| bool | show_handle | if True, the handle is drawn that makes it easier to grab and slide |
| enum | relief | relief style. Values are same as other elements that use relief values. RELIEF_RAISED RELIEF_SUNKEN RELIEF_FLAT RELIEF_RIDGE RELIEF_GROOVE RELIEF_SOLID |
| int | handle_size | Size of the handle in pixels |
| int | border_width | width of border around element in pixels |
| str or int or tuple or object | key | Value that uniquely identifies this element from all other elements. Used when Finding an element or in return values. Must be unique to the window |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| bool | expand_x | If True the column will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the column will automatically expand in the Y direction to fill available space |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Pane Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | visible | control visibility of element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Pane Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | visible | control visibility of element |
---------
## ProgressBar Element
Progress Bar Element - Displays a colored bar that is shaded as progress of some operation is made
```
ProgressBar(max_value,
orientation = None,
size = (None, None),
s = (None, None),
auto_size_text = None,
bar_color = None,
style = None,
border_width = None,
relief = None,
key = None,
k = None,
pad = None,
right_click_menu = None,
expand_x = False,
expand_y = False,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | max_value | max value of progressbar |
| str | orientation | 'horizontal' or 'vertical' |
| (int, int) or (int, None) | size | Size of the bar. If horizontal (chars wide, pixels high), vert (pixels wide, rows high) |
| (int, int) or (None, None) | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_text | Not sure why this is here |
| (str, str) or str | bar_color | The 2 colors that make up a progress bar. Easy to remember which is which if you say "ON" between colors. "red" on "green". |
| str | style | Progress bar style defined as one of these 'default', 'winnative', 'clam', 'alt', 'classic', 'vista', 'xpnative' |
| int | border_width | The amount of pixels that go around the outside of the bar |
| str | relief | relief style. Values are same as progress meter relief values. Can be a constant or a string: `RELIEF_RAISED RELIEF_SUNKEN RELIEF_FLAT RELIEF_RIDGE RELIEF_GROOVE RELIEF_SOLID` (Default value = DEFAULT_PROGRESS_BAR_RELIEF) |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the ProgressBar Element. Must call `Window.Read` or `Window.Finalize` prior
Now has the ability to modify the count so that the update_bar method is not longer needed separately
```
update(current_count,
max = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | current_count | sets the current value |
| int | max | changes the max value |
| bool | visible | control visibility of element |
| (bool) | **RETURN** | Returns True if update was OK. False means something wrong with window or it was closed
### update_bar
DEPRECATED BUT STILL USABLE - has been combined with the normal ProgressBar.update method.
Change what the bar shows by changing the current count and optionally the max count
```
update_bar(current_count, max = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | current_count | sets the current value |
| int | max | changes the max value |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the ProgressBar Element. Must call `Window.Read` or `Window.Finalize` prior
Now has the ability to modify the count so that the update_bar method is not longer needed separately
```
Update(current_count,
max = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | current_count | sets the current value |
| int | max | changes the max value |
| bool | visible | control visibility of element |
| (bool) | **RETURN** | Returns True if update was OK. False means something wrong with window or it was closed
### UpdateBar
DEPRECATED BUT STILL USABLE - has been combined with the normal ProgressBar.update method.
Change what the bar shows by changing the current count and optionally the max count
```
UpdateBar(current_count, max = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | current_count | sets the current value |
| int | max | changes the max value |
---------
## Radio Element
Radio Button Element - Used in a group of other Radio Elements to provide user with ability to select only
1 choice in a list of choices.
```
Radio(text,
group_id,
default = False,
disabled = False,
size = (None, None),
s = (None, None),
auto_size_text = None,
background_color = None,
text_color = None,
circle_color = None,
font = None,
key = None,
k = None,
pad = None,
tooltip = None,
change_submits = False,
enable_events = False,
right_click_menu = None,
expand_x = False,
expand_y = False,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | text | Text to display next to button |
| Any | group_id | Groups together multiple Radio Buttons. Any type works |
| bool | default | Set to True for the one element of the group you want initially selected |
| bool | disabled | set disable state |
| (int, int) or (None, None) or int | size | (w, h) w=characters-wide, h=rows-high. If an int instead of a tuple is supplied, then height is auto-set to 1 |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_text | if True will size the element to match the length of the text |
| str | background_color | color of background |
| str | text_color | color of the text |
| str | circle_color | color of background of the circle that has the dot selection indicator in it |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str | tooltip | text, that will appear when mouse hovers over the element |
| bool | change_submits | DO NOT USE. Only listed for backwards compat - Use enable_events instead |
| bool | enable_events | Turns on the element specific events. Radio Button events happen when an item is selected |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get
A snapshot of the value of Radio Button -> (bool)
`get()`
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | True if this radio button is selected |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### reset_group
Sets all Radio Buttons in the group to not selected
```python
reset_group()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Radio Button Element. Must call `Window.read` or `Window.finalize` prior
```
update(value = None,
text = None,
background_color = None,
text_color = None,
circle_color = None,
disabled = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | value | if True change to selected and set others in group to unselected |
| str | text | Text to display next to radio button |
| str | background_color | color of background |
| str | text_color | color of the text. Note this also changes the color of the selection dot |
| str | circle_color | color of background of the circle that has the dot selection indicator in it |
| bool | disabled | disable or enable state of the element |
| bool | visible | control visibility of element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### Get
A snapshot of the value of Radio Button -> (bool)
`Get()`
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | True if this radio button is selected |
### ResetGroup
Sets all Radio Buttons in the group to not selected
```python
ResetGroup()
```
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Radio Button Element. Must call `Window.read` or `Window.finalize` prior
```
Update(value = None,
text = None,
background_color = None,
text_color = None,
circle_color = None,
disabled = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | value | if True change to selected and set others in group to unselected |
| str | text | Text to display next to radio button |
| str | background_color | color of background |
| str | text_color | color of the text. Note this also changes the color of the selection dot |
| str | circle_color | color of background of the circle that has the dot selection indicator in it |
| bool | disabled | disable or enable state of the element |
| bool | visible | control visibility of element |
---------
## Sizegrip Element
Sizegrip element will be added to the bottom right corner of your window.
It should be placed on the last row of your window along with any other elements on that row.
The color will match the theme's background color.
```
Sizegrip(background_color = None, key = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | background_color | color to use for the background of the grip |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### set_vscroll_position
Attempts to set the vertical scroll postition for an element's Widget
```
set_vscroll_position(percent_from_top)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| float | percent_from_top | From 0 to 1.0, the percentage from the top to move scrollbar to |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
A dummy update call. This will only be called if an element hasn't implemented an update method
It is provided here for docstring purposes. If you got here by browing code via PyCharm, know
that this is not the function that will be called. Your actual element's update method will be called
```
update(args=*<1 or N object>, kwargs)
```
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
## Slider Element
A slider, horizontal or vertical
```
Slider(range = (None, None),
default_value = None,
resolution = None,
tick_interval = None,
orientation = None,
disable_number_display = False,
border_width = None,
relief = None,
change_submits = False,
enable_events = False,
disabled = False,
size = (None, None),
s = (None, None),
font = None,
background_color = None,
text_color = None,
trough_color = None,
key = None,
k = None,
pad = None,
expand_x = False,
expand_y = False,
tooltip = None,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) or Tuple[float, float] | range | slider's range (min value, max value) |
| int or float | default_value | starting value for the slider |
| int or float | resolution | the smallest amount the slider can be moved |
| int or float | tick_interval | how often a visible tick should be shown next to slider |
| str | orientation | 'horizontal' or 'vertical' ('h' or 'v' also work) |
| bool | disable_number_display | if True no number will be displayed by the Slider Element |
| int | border_width | width of border around element in pixels |
| str or None | relief | relief style. Use constants - RELIEF_RAISED RELIEF_SUNKEN RELIEF_FLAT RELIEF_RIDGE RELIEF_GROOVE RELIEF_SOLID |
| bool | change_submits | * DEPRICATED DO NOT USE. Use `enable_events` instead |
| bool | enable_events | If True then moving the slider will generate an Event |
| bool | disabled | set disable state for element |
| (int, int) | size | (l=length chars/rows, w=width pixels) |
| (int, int) or (None, None) | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str | background_color | color of slider's background |
| str | text_color | color of the slider's text |
| str | trough_color | color of the slider's trough |
| str or int or tuple or object | key | Value that uniquely identifies this element from all other elements. Used when Finding an element or in return values. Must be unique to the window |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| str | tooltip | text, that will appear when mouse hovers over the element |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Slider Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(value = None,
range = (None, None),
disabled = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int or float | value | sets current slider value |
| (int, int) or Tuple[float, float | range | Sets a new range for slider |
| bool | disabled | disable or enable state of the element |
| bool | visible | control visibility of element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Slider Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(value = None,
range = (None, None),
disabled = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int or float | value | sets current slider value |
| (int, int) or Tuple[float, float | range | Sets a new range for slider |
| bool | disabled | disable or enable state of the element |
| bool | visible | control visibility of element |
---------
## Spin Element
A spinner with up/down buttons and a single line of text. Choose 1 values from list
```
Spin(values,
initial_value = None,
disabled = False,
change_submits = False,
enable_events = False,
readonly = False,
size = (None, None),
s = (None, None),
auto_size_text = None,
font = None,
background_color = None,
text_color = None,
key = None,
k = None,
pad = None,
tooltip = None,
right_click_menu = None,
expand_x = False,
expand_y = False,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Tuple[Any] or List[Any] | values | List of valid values |
| Any | initial_value | Initial item to show in window. Choose from list of values supplied |
| bool | disabled | set disable state |
| bool | change_submits | DO NOT USE. Only listed for backwards compat - Use enable_events instead |
| bool | enable_events | Turns on the element specific events. Spin events happen when an item changes |
| bool | readonly | Turns on the element specific events. Spin events happen when an item changes |
| (int, int) or (None, None) or int | size | (w, h) w=characters-wide, h=rows-high. If an int instead of a tuple is supplied, then height is auto-set to 1 |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_text | if True will size the element to match the length of the text |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str | background_color | color of background |
| str | text_color | color of the text |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str | tooltip | text, that will appear when mouse hovers over the element |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get
Return the current chosen value showing in spinbox.
This value will be the same as what was provided as list of choices. If list items are ints, then the
item returned will be an int (not a string)
`get()`
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | The currently visible entry |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Spin Element. Must call `Window.Read` or `Window.Finalize` prior
Note that the state can be in 3 states only.... enabled, disabled, readonly even
though more combinations are available. The easy way to remember is that if you
change the readonly parameter then you are enabling the element.
```
update(value = None,
values = None,
disabled = None,
readonly = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | value | set the current value from list of choices |
| List[Any] | values | set available choices |
| bool | disabled | disable. Note disabled and readonly cannot be mixed. It must be one OR the other |
| bool | readonly | make element readonly. Note disabled and readonly cannot be mixed. It must be one OR the other |
| bool | visible | control visibility of element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### Get
Return the current chosen value showing in spinbox.
This value will be the same as what was provided as list of choices. If list items are ints, then the
item returned will be an int (not a string)
`Get()`
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | The currently visible entry |
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Spin Element. Must call `Window.Read` or `Window.Finalize` prior
Note that the state can be in 3 states only.... enabled, disabled, readonly even
though more combinations are available. The easy way to remember is that if you
change the readonly parameter then you are enabling the element.
```
Update(value = None,
values = None,
disabled = None,
readonly = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | value | set the current value from list of choices |
| List[Any] | values | set available choices |
| bool | disabled | disable. Note disabled and readonly cannot be mixed. It must be one OR the other |
| bool | readonly | make element readonly. Note disabled and readonly cannot be mixed. It must be one OR the other |
| bool | visible | control visibility of element |
---------
## StatusBar Element
A StatusBar Element creates the sunken text-filled strip at the bottom. Many Windows programs have this line
```
StatusBar(text,
size = (None, None),
s = (None, None),
auto_size_text = None,
click_submits = None,
enable_events = False,
relief = "sunken",
font = None,
text_color = None,
background_color = None,
justification = None,
pad = None,
key = None,
k = None,
right_click_menu = None,
expand_x = False,
expand_y = False,
tooltip = None,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | text | Text that is to be displayed in the widget |
| (int, int) or (int, None) or int | size | (w, h) w=characters-wide, h=rows-high. If an int instead of a tuple is supplied, then height is auto-set to 1 |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_text | True if size should fit the text length |
| bool | click_submits | DO NOT USE. Only listed for backwards compat - Use enable_events instead |
| bool | enable_events | Turns on the element specific events. StatusBar events occur when the bar is clicked |
| enum | relief | relief style. Values are same as progress meter relief values. Can be a constant or a string: `RELIEF_RAISED RELIEF_SUNKEN RELIEF_FLAT RELIEF_RIDGE RELIEF_GROOVE RELIEF_SOLID` |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str | text_color | color of the text |
| str | background_color | color of background |
| str | justification | how string should be aligned within space provided by size. Valid choices = `left`, `right`, `center` |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| str | tooltip | text, that will appear when mouse hovers over the element |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Status Bar Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(value = None,
background_color = None,
text_color = None,
font = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | value | new text to show |
| str | background_color | color of background |
| str | text_color | color of the text |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | visible | set visibility state of the element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Status Bar Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(value = None,
background_color = None,
text_color = None,
font = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | value | new text to show |
| str | background_color | color of background |
| str | text_color | color of the text |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | visible | set visibility state of the element |
---------
## Stretch Element
Acts like a Stretch element found in the Qt port.
Used in a Horizontal fashion. Placing one on each side of an element will enter the element.
Place one to the left and the element to the right will be right justified. See VStretch for vertical type
```
Stretch()
```
---------
## Tab Element
Tab Element is another "Container" element that holds a layout and displays a tab with text. Used with TabGroup only
Tabs are never placed directly into a layout. They are always "Contained" in a TabGroup layout
```
Tab(title,
layout,
title_color = None,
background_color = None,
font = None,
pad = None,
disabled = False,
border_width = None,
key = None,
k = None,
tooltip = None,
right_click_menu = None,
expand_x = False,
expand_y = False,
visible = True,
element_justification = "left",
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | title | text to show on the tab |
| List[List[Element]] | layout | The element layout that will be shown in the tab |
| str | title_color | color of the tab text (note not currently working on tkinter) |
| str | background_color | color of background of the entire layout |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| bool | disabled | If True button will be created disabled |
| int | border_width | width of border around element in pixels |
| str or int or tuple or object | key | Value that uniquely identifies this element from all other elements. Used when Finding an element or in return values. Must be unique to the window |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| str | tooltip | text, that will appear when mouse hovers over the element |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | visible | set visibility state of the element |
| str | element_justification | All elements inside the Tab will have this justification 'left', 'right', 'center' are valid values |
| Any | metadata | User metadata that can be set to ANYTHING |
### add_row
Not recommended use call. Used to add rows of Elements to the Frame Element.
```
add_row(args=*<1 or N object>)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[Element] | *args | The list of elements for this row |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### layout
Not user callable. Use layout parameter instead. Creates the layout using the supplied rows of Elements
```
layout(rows)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Element]] | rows | List[List[Element]] The list of rows |
| | **RETURN** | (Tab) used for chaining
### select
Create a tkinter event that mimics user clicking on a tab. Must have called window.Finalize / Read first!
```python
select()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Tab Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(title = None,
disabled = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | title | tab title |
| bool | disabled | disable or enable state of the element |
| bool | visible | control visibility of element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### AddRow
Not recommended use call. Used to add rows of Elements to the Frame Element.
```
AddRow(args=*<1 or N object>)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[Element] | *args | The list of elements for this row |
### Layout
Not user callable. Use layout parameter instead. Creates the layout using the supplied rows of Elements
```
Layout(rows)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Element]] | rows | List[List[Element]] The list of rows |
| | **RETURN** | (Tab) used for chaining
### Select
Create a tkinter event that mimics user clicking on a tab. Must have called window.Finalize / Read first!
```python
Select()
```
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Tab Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(title = None,
disabled = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | title | tab title |
| bool | disabled | disable or enable state of the element |
| bool | visible | control visibility of element |
---------
## TabGroup Element
TabGroup Element groups together your tabs into the group of tabs you see displayed in your window
```
TabGroup(layout,
tab_location = None,
title_color = None,
tab_background_color = None,
selected_title_color = None,
selected_background_color = None,
background_color = None,
font = None,
change_submits = False,
enable_events = False,
pad = None,
border_width = None,
theme = None,
key = None,
k = None,
size = (None, None),
s = (None, None),
tooltip = None,
right_click_menu = None,
expand_x = False,
expand_y = False,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Tab]] | layout | Layout of Tabs. Different than normal layouts. ALL Tabs should be on first row |
| str | tab_location | location that tabs will be displayed. Choices are left, right, top, bottom, lefttop, leftbottom, righttop, rightbottom, bottomleft, bottomright, topleft, topright |
| str | title_color | color of text on tabs |
| str | tab_background_color | color of all tabs that are not selected |
| str | selected_title_color | color of tab text when it is selected |
| str | selected_background_color | color of tab when it is selected |
| str | background_color | color of background area that tabs are located on |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | change_submits | * DEPRICATED DO NOT USE. Use `enable_events` instead |
| bool | enable_events | If True then switching tabs will generate an Event |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| int | border_width | width of border around element in pixels |
| enum | theme | DEPRICATED - You can only specify themes using set options or when window is created. It's not possible to do it on an element basis |
| str or int or tuple or object | key | Value that uniquely identifies this element from all other elements. Used when Finding an element or in return values. Must be unique to the window |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| (intorNone, intorNone) | size | (width, height) w=pixels-wide, h=pixels-high. Either item in tuple can be None to indicate use the computed value and set only 1 direction |
| (intorNone, intorNone) | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| str | tooltip | text, that will appear when mouse hovers over the element |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### add_tab
Add a new tab to an existing TabGroup
This call was written so that tabs can be added at runtime as your user performs operations.
Your Window should already be created and finalized.
```
add_tab(tab_element)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Tab | tab_element | A Tab Element that has a layout in it |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### find_key_from_tab_name
Searches through the layout to find the key that matches the text on the tab. Implies names should be unique
```
find_key_from_tab_name(tab_name)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tab_name | name of a tab |
| key or None | **RETURN** | Returns the key or None if no key found
### get
Returns the current value for the Tab Group, which will be the currently selected tab's KEY or the text on
the tab if no key is defined. Returns None if an error occurs.
Note that this is exactly the same data that would be returned from a call to Window.Read. Are you sure you
are using this method correctly?
`get()`
|Type|Name|Meaning|
|---|---|---|
|Any | None| **return** | The key of the currently selected tab or the tab's text if it has no key |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### set_vscroll_position
Attempts to set the vertical scroll postition for an element's Widget
```
set_vscroll_position(percent_from_top)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| float | percent_from_top | From 0 to 1.0, the percentage from the top to move scrollbar to |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### FindKeyFromTabName
Searches through the layout to find the key that matches the text on the tab. Implies names should be unique
```
FindKeyFromTabName(tab_name)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tab_name | name of a tab |
| key or None | **RETURN** | Returns the key or None if no key found
### Get
Returns the current value for the Tab Group, which will be the currently selected tab's KEY or the text on
the tab if no key is defined. Returns None if an error occurs.
Note that this is exactly the same data that would be returned from a call to Window.Read. Are you sure you
are using this method correctly?
`Get()`
|Type|Name|Meaning|
|---|---|---|
|Any | None| **return** | The key of the currently selected tab or the tab's text if it has no key |
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
---------
## Table Element
```
Table(values,
headings = None,
visible_column_map = None,
col_widths = None,
def_col_width = 10,
auto_size_columns = True,
max_col_width = 20,
select_mode = None,
display_row_numbers = False,
num_rows = None,
row_height = None,
font = None,
justification = "right",
text_color = None,
background_color = None,
alternating_row_color = None,
selected_row_colors = (None, None),
header_text_color = None,
header_background_color = None,
header_font = None,
row_colors = None,
vertical_scroll_only = True,
hide_vertical_scroll = False,
size = (None, None),
s = (None, None),
change_submits = False,
enable_events = False,
bind_return_key = False,
pad = None,
key = None,
k = None,
tooltip = None,
right_click_menu = None,
expand_x = False,
expand_y = False,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[str or int or float]] | values | ??? |
| List[str] | headings | The headings to show on the top line |
| List[bool] | visible_column_map | One entry for each column. False indicates the column is not shown |
| List[int] | col_widths | Number of characters that each column will occupy |
| int | def_col_width | Default column width in characters |
| bool | auto_size_columns | if True columns will be sized automatically |
| int | max_col_width | Maximum width for all columns in characters |
| enum | select_mode | Select Mode. Valid values start with "TABLE_SELECT_MODE_". Valid values are: TABLE_SELECT_MODE_NONE TABLE_SELECT_MODE_BROWSE TABLE_SELECT_MODE_EXTENDED |
| bool | display_row_numbers | if True, the first column of the table will be the row # |
| int | num_rows | The number of rows of the table to display at a time |
| int | row_height | height of a single row in pixels |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str | justification | 'left', 'right', 'center' are valid choices |
| str | text_color | color of the text |
| str | background_color | color of background |
| str | alternating_row_color | if set then every other row will have this color in the background. |
| str or (str, str) | selected_row_colors | Sets the text color and background color for a selected row. Same format as button colors - tuple ('red', 'yellow') or string 'red on yellow'. Defaults to theme's button color |
| str | header_text_color | sets the text color for the header |
| str | header_background_color | sets the background color for the header |
| (str or (str, int[, str]) or None) | header_font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| List[Tuple[int, str] or Tuple[Int, str, str]] | row_colors | list of tuples of (row, background color) OR (row, foreground color, background color). Sets the colors of listed rows to the color(s) provided (note the optional foreground color) |
| bool | vertical_scroll_only | if True only the vertical scrollbar will be visible |
| bool | hide_vertical_scroll | if True vertical scrollbar will be hidden |
| (int, int) | size | DO NOT USE! Use num_rows instead |
| bool | change_submits | DO NOT USE. Only listed for backwards compat - Use enable_events instead |
| bool | enable_events | Turns on the element specific events. Table events happen when row is clicked |
| bool | bind_return_key | if True, pressing return key will cause event coming from Table, ALSO a left button double click will generate an event if this parameter is True |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| str | tooltip | text, that will appear when mouse hovers over the element |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get
Dummy function for tkinter port. In the Qt port you can read back the values in the table in case they were
edited. Don't know yet how to enable editing of a Tree in tkinter so just returning the values provided by
user when Table was created or Updated.
`get()`
|Type|Name|Meaning|
|---|---|---|
|List[List[Any]]| **return** | the current table values (for now what was originally provided up updated) |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Table Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(values = None,
num_rows = None,
visible = None,
select_rows = None,
alternating_row_color = None,
row_colors = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[str or int or float]] | values | A new 2-dimensional table to show |
| int | num_rows | How many rows to display at a time |
| bool | visible | if True then will be visible |
| List[int] | select_rows | List of rows to select as if user did |
| str | alternating_row_color | the color to make every other row |
| List[Tuple[int, str] or Tuple[Int, str, str]] | row_colors | list of tuples of (row, background color) OR (row, foreground color, background color). Changes the colors of listed rows to the color(s) provided (note the optional foreground color) |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### Get
Dummy function for tkinter port. In the Qt port you can read back the values in the table in case they were
edited. Don't know yet how to enable editing of a Tree in tkinter so just returning the values provided by
user when Table was created or Updated.
`Get()`
|Type|Name|Meaning|
|---|---|---|
|List[List[Any]]| **return** | the current table values (for now what was originally provided up updated) |
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Table Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(values = None,
num_rows = None,
visible = None,
select_rows = None,
alternating_row_color = None,
row_colors = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[str or int or float]] | values | A new 2-dimensional table to show |
| int | num_rows | How many rows to display at a time |
| bool | visible | if True then will be visible |
| List[int] | select_rows | List of rows to select as if user did |
| str | alternating_row_color | the color to make every other row |
| List[Tuple[int, str] or Tuple[Int, str, str]] | row_colors | list of tuples of (row, background color) OR (row, foreground color, background color). Changes the colors of listed rows to the color(s) provided (note the optional foreground color) |
---------
## Text Element
Text - Display some text in the window. Usually this means a single line of text. However, the text can also be multiple lines. If multi-lined there are no scroll bars.
```
Text(text = "",
size = (None, None),
s = (None, None),
auto_size_text = None,
click_submits = False,
enable_events = False,
relief = None,
font = None,
text_color = None,
background_color = None,
border_width = None,
justification = None,
pad = None,
key = None,
k = None,
right_click_menu = None,
expand_x = False,
expand_y = False,
grab = None,
tooltip = None,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | text | The text to display. Can include /n to achieve multiple lines. Will convert (optional) parameter into a string |
| (int, int) or (int, None) or (None, None) or (int, ) or int | size | (w, h) w=characters-wide, h=rows-high. If an int instead of a tuple is supplied, then height is auto-set to 1 |
| (int, int) or (int, None) or (None, None) or (int, ) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_text | if True size of the Text Element will be sized to fit the string provided in 'text' parm |
| bool | click_submits | DO NOT USE. Only listed for backwards compat - Use enable_events instead |
| bool | enable_events | Turns on the element specific events. Text events happen when the text is clicked |
| (str/enum) | relief | relief style around the text. Values are same as progress meter relief values. Should be a constant that is defined at starting with "RELIEF_" - `RELIEF_RAISED, RELIEF_SUNKEN, RELIEF_FLAT, RELIEF_RIDGE, RELIEF_GROOVE, RELIEF_SOLID` |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str | text_color | color of the text |
| str | background_color | color of background |
| int | border_width | number of pixels for the border (if using a relief) |
| str | justification | how string should be aligned within space provided by size. Valid choices = `left`, `right`, `center` |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | grab | If True can grab this element and move the window around. Default is False |
| str | tooltip | text, that will appear when mouse hovers over the element |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
#### get
Gets the current value of the displayed text
`get()`
|Type|Name|Meaning|
|---|---|---|
|(str)| **return** | The current value |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Text Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(value = None,
background_color = None,
text_color = None,
font = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | value | new text to show |
| str | background_color | color of background |
| str | text_color | color of the text |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | visible | set visibility state of the element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
#### Get
Gets the current value of the displayed text
`Get()`
|Type|Name|Meaning|
|---|---|---|
|(str)| **return** | The current value |
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Text Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(value = None,
background_color = None,
text_color = None,
font = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | value | new text to show |
| str | background_color | color of background |
| str | text_color | color of the text |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | visible | set visibility state of the element |
---------
## Titlebar Element
Note that while the Titlebar is an element, it is implemented using a function.
It is actually a "compound element" that consists of several elements combined into a single Column element.
See the Column element to get a list of method calls available. The function returns a Column element.
A custom titlebar that replaces the OS provided titlebar, thus giving you control
the is not possible using the OS provided titlebar such as the color.
NOTE LINUX USERS - at the moment the minimize function is not yet working. Windows users
should have no problem and it should function as a normal window would.
This titlebar is created from a row of elements that is then encapulated into a
single Column element which is what the Titlebar returns to you.
A custom titlebar removes the margins from your window. Ify ou want the remainder
of your Window to have margins, place the layout after the Titlebar into a Column and
set the pad of that Column to the dimensions you would like your margins to have.
The Titlebar is a COLUMN element. You can thus call the update method for the column and
perform operations such as making the column visible/invisible
```
Titlebar(title = "",
icon = None,
text_color = None,
background_color = None,
font = None,
key = None,
k = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str or bytes or None | icon | Can be either a filename or Base64 byte string of a PNG. For Windows if filename, it MUST be ICO format. For Linux, must NOT be ICO |
| str | title | The "title" to show in the titlebar |
| str or None | text_color | Text color for titlebar |
| str or None | background_color | Background color for titlebar |
| (str or (str, int[, str]) or None) | font | Font to be used for the text and the symbols |
| str or int or tuple or object or None | key | Identifies an Element. Should be UNIQUE to this window. |
| str or int or tuple or object or None | k | Exactly the same as key. Choose one of them to use |
| Column | **RETURN** | A single Column element that has eveything in 1 element
---------
## Tree Element
Tree Element - Presents data in a tree-like manner, much like a file/folder browser. Uses the TreeData class
to hold the user's data and pass to the element for display.
```
Tree(data = None,
headings = None,
visible_column_map = None,
col_widths = None,
col0_width = 10,
def_col_width = 10,
auto_size_columns = True,
max_col_width = 20,
select_mode = None,
show_expanded = False,
change_submits = False,
enable_events = False,
font = None,
justification = "right",
text_color = None,
background_color = None,
selected_row_colors = (None, None),
header_text_color = None,
header_background_color = None,
header_font = None,
num_rows = None,
row_height = None,
pad = None,
key = None,
k = None,
tooltip = None,
right_click_menu = None,
expand_x = False,
expand_y = False,
visible = True,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| TreeData | data | The data represented using a PySimpleGUI provided TreeData class |
| List[str] | headings | List of individual headings for each column |
| List[bool] | visible_column_map | Determines if a column should be visible. If left empty, all columns will be shown |
| List[int] | col_widths | List of column widths so that individual column widths can be controlled |
| int | col0_width | Size of Column 0 which is where the row numbers will be optionally shown |
| int | def_col_width | default column width |
| bool | auto_size_columns | if True, the size of a column is determined using the contents of the column |
| int | max_col_width | the maximum size a column can be |
| enum | select_mode | Use same values as found on Table Element. Valid values include: TABLE_SELECT_MODE_NONE TABLE_SELECT_MODE_BROWSE TABLE_SELECT_MODE_EXTENDED |
| bool | show_expanded | if True then the tree will be initially shown with all nodes completely expanded |
| bool | change_submits | DO NOT USE. Only listed for backwards compat - Use enable_events instead |
| bool | enable_events | Turns on the element specific events. Tree events happen when row is clicked |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str | justification | 'left', 'right', 'center' are valid choices |
| str | text_color | color of the text |
| str | background_color | color of background |
| str or (str, str) | selected_row_colors | Sets the text color and background color for a selected row. Same format as button colors - tuple ('red', 'yellow') or string 'red on yellow'. Defaults to theme's button color |
| str | header_text_color | sets the text color for the header |
| str | header_background_color | sets the background color for the header |
| (str or (str, int[, str]) or None) | header_font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| int | num_rows | The number of rows of the table to display at a time |
| int | row_height | height of a single row in pixels |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| str | tooltip | text, that will appear when mouse hovers over the element |
| List[List[str] or str]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| bool | expand_x | If True the element will automatically expand in the X direction to fill available space |
| bool | expand_y | If True the element will automatically expand in the Y direction to fill available space |
| bool | visible | set visibility state of the element |
| Any | metadata | User metadata that can be set to ANYTHING |
### add_treeview_data
Not a user function. Recursive method that inserts tree data into the tkinter treeview widget.
```
add_treeview_data(node)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| TreeData | node | The node to insert. Will insert all nodes from starting point downward, recursively |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### block_focus
Enable or disable the element from getting focus by using the keyboard.
If the block parameter is True, then this element will not be given focus by using
the keyboard to go from one element to another.
You CAN click on the element and utilize it.
```
block_focus(block = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | block | if True the element will not get focus via the keyboard |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### set_vscroll_position
Attempts to set the vertical scroll postition for an element's Widget
```
set_vscroll_position(percent_from_top)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| float | percent_from_top | From 0 to 1.0, the percentage from the top to move scrollbar to |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### update
Changes some of the settings for the Tree Element. Must call `Window.Read` or `Window.Finalize` prior
```
update(values = None,
key = None,
value = None,
text = None,
icon = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| TreeData | values | Representation of the tree |
| str or int or tuple or object | key | identifies a particular item in tree to update |
| Any | value | sets the node identified by key to a particular value |
| str | text | sets the node identified by ket to this string |
| bytes or str | icon | can be either a base64 icon or a filename for the icon |
| bool | visible | control visibility of element |
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### Update
Changes some of the settings for the Tree Element. Must call `Window.Read` or `Window.Finalize` prior
```
Update(values = None,
key = None,
value = None,
text = None,
icon = None,
visible = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| TreeData | values | Representation of the tree |
| str or int or tuple or object | key | identifies a particular item in tree to update |
| Any | value | sets the node identified by key to a particular value |
| str | text | sets the node identified by ket to this string |
| bytes or str | icon | can be either a base64 icon or a filename for the icon |
| bool | visible | control visibility of element |
---------
## TreeData (for Tree Element)
Class that user fills in to represent their tree data. It's a very simple tree representation with a root "Node"
with possibly one or more children "Nodes". Each Node contains a key, text to display, list of values to display
and an icon. The entire tree is built using a single method, Insert. Nothing else is required to make the tree.
Instantiate the object, initializes the Tree Data, creates a root node for you
```python
TreeData()
```
### Node
Contains information about the individual node in the tree
```
Node(parent,
key,
text,
values,
icon = None)
```
### insert
Inserts a node into the tree. This is how user builds their tree, by Inserting Nodes
This is the ONLY user callable method in the TreeData class
```
insert(parent,
key,
text,
values,
icon = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Node | parent | the parent Node |
| str or int or tuple or object | key | Used to uniquely identify this node |
| str | text | The text that is displayed at this node's location |
| List[Any] | values | The list of values that are displayed at this node |
| str or bytes | icon | icon |
### Insert
Inserts a node into the tree. This is how user builds their tree, by Inserting Nodes
This is the ONLY user callable method in the TreeData class
```
Insert(parent,
key,
text,
values,
icon = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Node | parent | the parent Node |
| str or int or tuple or object | key | Used to uniquely identify this node |
| str | text | The text that is displayed at this node's location |
| List[Any] | values | The list of values that are displayed at this node |
| str or bytes | icon | icon |
---------
## VerticalSeparator Element
Vertical Separator Element draws a vertical line at the given location. It will span 1 "row". Usually paired with
Column Element if extra height is needed
```
VerticalSeparator(color = None,
pad = None,
key = None,
k = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | color | Color of the line. Defaults to theme's text color. Can be name or #RRGGBB format |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | Value that uniquely identifies this element from all other elements. Used when Finding an element or in return values. Must be unique to the window |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
### bind
Used to add tkinter events to an Element.
The tkinter specific data is in the Element's member variable user_bind_event
```
bind(bind_string, key_modifier)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str | key_modifier | Additional data to be added to the element's key when event is returned |
### expand
Causes the Element to expand to fill available space in the X and Y directions. Can specify which or both directions
```
expand(expand_x = False,
expand_y = False,
expand_row = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | expand_x | If True Element will expand in the Horizontal directions |
| bool | expand_y | If True Element will expand in the Vertical directions |
| bool | expand_row | If True the row containing the element will also expand. Without this your element is "trapped" within the row |
### get_size
Return the size of an element in Pixels. Care must be taken as some elements use characters to specify their size but will return pixels when calling this get_size method.
`get_size()`
|Type|Name|Meaning|
|---|---|---|
|(int, int)| **return** | width and height of the element |
### grab_anywhere_exclude
Excludes this element from being used by the grab_anywhere feature
Handy for elements like a Graph element when dragging is enabled. You want the Graph element to get the drag events instead of the window dragging.
```python
grab_anywhere_exclude()
```
### grab_anywhere_include
Includes this element in the grab_anywhere feature
This will allow you to make a Multline element drag a window for example
```python
grab_anywhere_include()
```
### hide_row
Hide the entire row an Element is located on.
Use this if you must have all space removed when you are hiding an element, including the row container
```python
hide_row()
```
### metadata
#### property: metadata
Metadata is an Element property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### set_cursor
Sets the cursor for the current Element.
"Cursor" is used in 2 different ways in this call.
For the parameter "cursor" it's actually the mouse pointer.
If you do not want any mouse pointer, then use the string "none"
For the parameter "cursor_color" it's the color of the beam used when typing into an input element
```
set_cursor(cursor = None, cursor_color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
| str | cursor_color | color to set the "cursor" to |
### set_focus
Sets the current focus to be on this element
```
set_focus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### set_size
Changes the size of an element to a specific size.
It's possible to specify None for one of sizes so that only 1 of the element's dimensions are changed.
```
set_size(size = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | The size in characters, rows typically. In some cases they are pixels |
### set_tooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
set_tooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
### unbind
Removes a previously bound tkinter event from an Element.
```
unbind(bind_string)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
### unhide_row
Unhides (makes visible again) the row container that the Element is located on.
Note that it will re-appear at the bottom of the window / container, most likely.
```python
unhide_row()
```
### visible
#### property: visible
Returns visibility state for the element. This is a READONLY property
|Type|Name|Meaning|
|---|---|---|
|(bool)| **return** | Visibility state for element |
---------
## VStretch Element
Acts like a Stretch element found in the Qt port.
Used in a Vertical fashion.
```
VStretch()
```
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### SetFocus
Sets the current focus to be on this element
```
SetFocus(force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | force | if True will call focus_force otherwise calls focus_set |
### SetTooltip
Called by application to change the tooltip text for an Element. Normally invoked using the Element Object such as: window.Element('key').SetToolTip('New tip').
```
SetTooltip(tooltip_text)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | tooltip_text | the text to show in tooltip. |
---------
## UserSettings (Class interface to User Settings APIs... can also use the function call interface)
User Settings
```
UserSettings(filename = None,
path = None,
silent_on_error = False,
autosave = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str or None) | filename | The name of the file to use. Can be a full path and filename or just filename |
| (str or None) | path | The folder that the settings file will be stored in. Do not include the filename. |
| bool | silent_on_error | If True errors will not be reported |
| bool | autosave | If True the settings file is saved after every update |
### delete_entry
Deletes an individual entry. If no filename has been specified up to this point,
then a default filename will be used.
After value has been deleted, the settings file is written to disk.
```
delete_entry(key)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | key | Setting to be deleted. Can be any valid dictionary key type (i.e. must be hashable) |
### delete_file
Deltes the filename and path for your settings file. Either paramter can be optional.
If you don't choose a path, one is provided for you that is OS specific
Windows path default = users/name/AppData/Local/PySimpleGUI/settings.
If you don't choose a filename, your application's filename + '.json' will be used
Also sets your current dictionary to a blank one.
```
delete_file(filename = None, path = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str or None) | filename | The name of the file to use. Can be a full path and filename or just filename |
| (str or None) | path | The folder that the settings file will be stored in. Do not include the filename. |
### exists
Check if a particular settings file exists. Returns True if file exists
```
exists(filename = None, path = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str or None) | filename | The name of the file to use. Can be a full path and filename or just filename |
| (str or None) | path | The folder that the settings file will be stored in. Do not include the filename. |
### get
Returns the value of a specified setting. If the setting is not found in the settings dictionary, then
the user specified default value will be returned. It no default is specified and nothing is found, then
the "default value" is returned. This default can be specified in this call, or previously defined
by calling set_default. If nothing specified now or previously, then None is returned as default.
```
get(key, default = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | key | Key used to lookup the setting in the settings dictionary |
| Any | default | Value to use should the key not be found in the dictionary |
| (Any) | **RETURN** | Value of specified settings
### get_dict
Returns the current settings dictionary. If you've not setup the filename for the
settings, a default one will be used and then read.
Note that you can display the dictionary in text format by printing the object itself.
`get_dict()`
|Type|Name|Meaning|
|---|---|---|
|Dict| **return** | The current settings dictionary |
### get_filename
Sets the filename and path for your settings file. Either paramter can be optional.
If you don't choose a path, one is provided for you that is OS specific
Windows path default = users/name/AppData/Local/PySimpleGUI/settings.
If you don't choose a filename, your application's filename + '.json' will be used.
Normally the filename and path are split in the user_settings calls. However for this call they
can be combined so that the filename contains both the path and filename.
```
get_filename(filename = None, path = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str or None) | filename | The name of the file to use. Can be a full path and filename or just filename |
| (str or None) | path | The folder that the settings file will be stored in. Do not include the filename. |
| (str) | **RETURN** | The full pathname of the settings file that has both the path and filename combined.
### load
Specifies the path and filename to use for the settings and reads the contents of the file.
The filename can be a full filename including a path, or the path can be specified separately.
If no filename is specified, then the caller's filename will be used with the extension ".json"
```
load(filename = None, path = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str or None) | filename | Filename to load settings from (and save to in the future) |
| (str or None) | path | Path to the file. Defaults to a specific folder depending on the operating system |
| (dict) | **RETURN** | The settings dictionary (i.e. all settings)
### read
Reads settings file and returns the dictionary.
`read()`
|Type|Name|Meaning|
|---|---|---|
|(dict)| **return** | settings dictionary |
### save
Saves the current settings dictionary. If a filename or path is specified in the call, then it will override any
previously specitfied filename to create a new settings file. The settings dictionary is then saved to the newly defined file.
```
save(filename = None, path = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str or None) | filename | The fFilename to save to. Can specify a path or just the filename. If no filename specified, then the caller's filename will be used. |
| (str or None) | path | The (optional) path to use to save the file. |
| (str) | **RETURN** | The full path and filename used to save the settings
### set
Sets an individual setting to the specified value. If no filename has been specified up to this point,
then a default filename will be used.
After value has been modified, the settings file is written to disk.
```
set(key, value)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | key | Setting to be saved. Can be any valid dictionary key type |
| Any | value | Value to save as the setting's value. Can be anything |
| bool | autosave | If True then the value will be saved to the file |
| (Any) | **RETURN** | value that key was set to
### set_default_value
Set the value that will be returned if a requested setting is not found
```
set_default_value(default)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | default | value to be returned if a setting is not found in the settings dictionary |
### set_location
Sets the location of the settings file
```
set_location(filename = None, path = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str or None) | filename | The name of the file to use. Can be a full path and filename or just filename |
| (str or None) | path | The folder that the settings file will be stored in. Do not include the filename. |
### write_new_dictionary
Writes a specified dictionary to the currently defined settings filename.
```
write_new_dictionary(settings_dict)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| dict | settings_dict | The dictionary to be written to the currently defined settings file |
---------
## Window
Represents a single Window
```
Window(title,
layout = None,
default_element_size = None,
default_button_element_size = (None, None),
auto_size_text = None,
auto_size_buttons = None,
location = (None, None),
size = (None, None),
element_padding = None,
margins = (None, None),
button_color = None,
font = None,
progress_bar_color = (None, None),
background_color = None,
border_depth = None,
auto_close = False,
auto_close_duration = 3,
icon = None,
force_toplevel = False,
alpha_channel = 1,
return_keyboard_events = False,
use_default_focus = True,
text_justification = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
resizable = False,
disable_close = False,
disable_minimize = False,
right_click_menu = None,
transparent_color = None,
debugger_enabled = True,
right_click_menu_background_color = None,
right_click_menu_text_color = None,
right_click_menu_disabled_text_color = None,
right_click_menu_selected_colors = (None, None),
right_click_menu_font = None,
right_click_menu_tearoff = False,
finalize = False,
element_justification = "left",
ttk_theme = None,
use_ttk_buttons = None,
modal = False,
enable_close_attempted_event = False,
titlebar_background_color = None,
titlebar_text_color = None,
titlebar_font = None,
titlebar_icon = None,
use_custom_titlebar = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | title | The title that will be displayed in the Titlebar and on the Taskbar |
| List[List[Elements]] | layout | The layout for the window. Can also be specified in the Layout method |
| (int, int) - (width, height) | default_element_size | size in characters (wide) and rows (high) for all elements in this window |
| (int, int) | default_button_element_size | (width, height) size in characters (wide) and rows (high) for all Button elements in this window |
| bool | auto_size_text | True if Elements in Window should be sized to exactly fir the length of text |
| bool | auto_size_buttons | True if Buttons in this Window should be sized to exactly fit the text on this. |
| (int, int) | location | (x,y) location, in pixels, to locate the upper left corner of the window on the screen. Default is to center on screen. |
| (int, int) | size | (width, height) size in pixels for this window. Normally the window is autosized to fit contents, not set to an absolute size by the user. Try not to set this value. You risk, the contents being cut off, etc. Let the layout determine the window size instead |
| (int, int or (int, int),(int,int)) or int | element_padding | Default amount of padding to put around elements in window (left/right, top/bottom) or ((left, right), (top, bottom)), or an int. If an int, then it's converted into a tuple (int, int) |
| (int, int) | margins | (left/right, top/bottom) Amount of pixels to leave inside the window's frame around the edges before your elements are shown. |
| (str, str) or str | button_color | Default button colors for all buttons in the window |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| (str, str) | progress_bar_color | (bar color, background color) Sets the default colors for all progress bars in the window |
| str | background_color | color of background |
| int | border_depth | Default border depth (width) for all elements in the window |
| bool | auto_close | If True, the window will automatically close itself |
| int | auto_close_duration | Number of seconds to wait before closing the window |
| (str or bytes) | icon | Can be either a filename or Base64 value. For Windows if filename, it MUST be ICO format. For Linux, must NOT be ICO. Most portable is to use a Base64 of a PNG file. This works universally across all OS's |
| bool | force_toplevel | If True will cause this window to skip the normal use of a hidden master window |
| float | alpha_channel | Sets the opacity of the window. 0 = invisible 1 = completely visible. Values bewteen 0 & 1 will produce semi-transparent windows in SOME environments (The Raspberry Pi always has this value at 1 and cannot change. |
| bool | return_keyboard_events | if True key presses on the keyboard will be returned as Events from Read calls |
| bool | use_default_focus | If True will use the default focus algorithm to set the focus to the "Correct" element |
| 'left' or 'right' or 'center' | text_justification | Default text justification for all Text Elements in window |
| bool | no_titlebar | If true, no titlebar nor frame will be shown on window. This means you cannot minimize the window and it will not show up on the taskbar |
| bool | grab_anywhere | If True can use mouse to click and drag to move the window. Almost every location of the window will work except input fields on some systems |
| bool | keep_on_top | If True, window will be created on top of all other windows on screen. It can be bumped down if another window created with this parm |
| bool | resizable | If True, allows the user to resize the window. Note the not all Elements will change size or location when resizing. |
| bool | disable_close | If True, the X button in the top right corner of the window will no work. Use with caution and always give a way out toyour users |
| bool | disable_minimize | if True the user won't be able to minimize window. Good for taking over entire screen and staying that way. |
| List[List[ List[str] or str ]] | right_click_menu | A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |
| str | transparent_color | Any portion of the window that has this color will be completely transparent. You can even click through these spots to the window under this window. |
| bool | debugger_enabled | If True then the internal debugger will be enabled |
| str | right_click_menu_background_color | Background color for right click menus |
| str | right_click_menu_text_color | Text color for right click menus |
| str | right_click_menu_disabled_text_color | Text color for disabled right click menu items |
| (str, str) or str or Tuple | right_click_menu_selected_colors | Text AND background colors for a selected item. Can be a Tuple OR a color string. simplified-button-color-string "foreground on background". Can be a single color if want to set only the background. Normally a tuple, but can be a simplified-dual-color-string "foreground on background". Can be a single color if want to set only the background. |
| (str or (str, int[, str]) or None) | right_click_menu_font | Font for right click menus |
| bool | right_click_menu_tearoff | If True then all right click menus can be torn off |
| bool | finalize | If True then the Finalize method will be called. Use this rather than chaining .Finalize for cleaner code |
| str | element_justification | All elements in the Window itself will have this justification 'left', 'right', 'center' are valid values |
| str | ttk_theme | Set the tkinter ttk "theme" of the window. Default = DEFAULT_TTK_THEME. Sets all ttk widgets to this theme as their default |
| bool | use_ttk_buttons | Affects all buttons in window. True = use ttk buttons. False = do not use ttk buttons. None = use ttk buttons only if on a Mac |
| bool | modal | If True then this window will be the only window a user can interact with until it is closed |
| bool | enable_close_attempted_event | If True then the window will not close when "X" clicked. Instead an event WINDOW_CLOSE_ATTEMPTED_EVENT if returned from window.read |
| (str or None) | titlebar_background_color | If custom titlebar indicated by use_custom_titlebar, then use this as background color |
| (str or None) | titlebar_text_color | If custom titlebar indicated by use_custom_titlebar, then use this as text color |
| (str or (str, int[, str]) or None) | titlebar_font | If custom titlebar indicated by use_custom_titlebar, then use this as title font |
| (bytes or str) | titlebar_icon | If custom titlebar indicated by use_custom_titlebar, then use this as the icon (file or base64 bytes) |
| bool | use_custom_titlebar | If True, then a custom titlebar will be used instead of the normal titlebar |
| Any | metadata | User metadata that can be set to ANYTHING |
### add_row
Adds a single row of elements to a window's self.Rows variables.
Generally speaking this is NOT how users should be building Window layouts.
Users, create a single layout (a list of lists) and pass as a parameter to Window object, or call Window.Layout(layout)
```
add_row(args=*<1 or N object>)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| | *args | List[Elements] |
### add_rows
Loops through a list of lists of elements and adds each row, list, to the layout.
This is NOT the best way to go about creating a window. Sending the entire layout at one time and passing
it as a parameter to the Window call is better.
```
add_rows(rows)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Elements]] | rows | A list of a list of elements |
### alpha_channel
#### property: alpha_channel
A property that changes the current alpha channel value (internal value)
|Type|Name|Meaning|
|---|---|---|
|(float)| **return** | the current alpha channel setting according to self, not read directly from tkinter |
### bind
Used to add tkinter events to a Window.
The tkinter specific data is in the Window's member variable user_bind_event
```
bind(bind_string, key)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | bind_string | The string tkinter expected in its bind function |
| str or int or tuple or object | key | The event that will be generated when the tkinter event occurs |
### bring_to_front
Brings this window to the top of all other windows (perhaps may not be brought before a window made to "stay
on top")
```python
bring_to_front()
```
### close
Closes window. Users can safely call even if window has been destroyed. Should always call when done with
a window so that resources are properly freed up within your thread.
```python
close()
```
### current_location
Get the current location of the window's top left corner.
Sometimes, depending on the environment, the value returned does not include the titlebar,etc
A new option, more_accurate, can be used to get the theoretical upper leftmost corner of the window.
The titlebar and menubar are crated by the OS. It gets really confusing when running in a webpage (repl, trinket)
Thus, the values can appear top be "off" due to the sometimes unpredictable way the location is calculated.
```
current_location(more_accurate = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | more_accurate | If True, will use the window's geometry to get the topmost location with titlebar, menubar taken into account |
| Tuple[(int or None), (int or None)] | **RETURN** | The x and y location in tuple form (x,y)
### ding
Make a "bell" sound. A capability provided by tkinter. Your window needs to be finalized prior to calling.
Ring a display's bell is the tkinter description of the call.
```
ding(display_number = 0)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | display_number | Passed to tkinter's bell method as parameter "displayof". |
### disable
Disables window from taking any input from the user
```python
disable()
```
### disable_debugger
Disable the internal debugger. By default the debugger is ENABLED
```python
disable_debugger()
```
### disappear
Causes a window to "disappear" from the screen, but remain on the taskbar. It does this by turning the alpha
channel to 0. NOTE that on some platforms alpha is not supported. The window will remain showing on these
platforms. The Raspberry Pi for example does not have an alpha setting
```python
disappear()
```
### elem
### element
### element_list
Returns a list of all elements in the window
`element_list()`
|Type|Name|Meaning|
|---|---|---|
|List[Element]| **return** | List of all elements in the window and container elements in the window |
### enable
Re-enables window to take user input after having it be Disabled previously
```python
enable()
```
### enable_debugger
Enables the internal debugger. By default, the debugger IS enabled
```python
enable_debugger()
```
### extend_layout
Adds new rows to an existing container element inside of this window
If the container is a scrollable Column, you need to also call the contents_changed() method
```
extend_layout(container, rows)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Frame or Column or Tab | container | The container Element the layout will be placed inside of |
| (List[List[Element]]) | rows | The layout to be added |
| (Window) | **RETURN** | (Window) self so could be chained
### fill
Fill in elements that are input fields with data based on a 'values dictionary'
```
fill(values_dict)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (Dict[Any, Any]) - {Element_key : value} | values_dict | pairs |
| (Window) | **RETURN** | returns self so can be chained with other methods
### finalize
Use this method to cause your layout to built into a real tkinter window. In reality this method is like
Read(timeout=0). It doesn't block and uses your layout to create tkinter widgets to represent the elements.
Lots of action!
`finalize()`
|Type|Name|Meaning|
|---|---|---|
|(Window)| **return** | Returns 'self' so that method "Chaining" can happen (read up about it as it's very cool!) |
### find
### find_element
Find element object associated with the provided key.
THIS METHOD IS NO LONGER NEEDED to be called by the user
You can perform the same operation by writing this statement:
element = window[key]
You can drop the entire "find_element" function name and use [ ] instead.
However, if you wish to perform a lookup without error checking, and don't have error popups turned
off globally, you'll need to make this call so that you can disable error checks on this call.
find_element is yypically used in combination with a call to element's Update method (or any other element method!):
window[key].update(new_value)
Versus the "old way"
window.FindElement(key).Update(new_value)
This call can be abbreviated to any of these:
find_element = FindElement == Element == Find
With find_element being the PEP8 compliant call that should be used.
Rememeber that this call will return None if no match is found which may cause your code to crash if not
checked for.
```
find_element(key, silent_on_error = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element |
| bool | silent_on_error | If True do not display popup nor print warning of key errors |
| Element or Error Element or None | **RETURN** | Return value can be: the Element that matches the supplied key if found; an Error Element if silent_on_error is False; None if silent_on_error True;
### find_element_with_focus
Returns the Element that currently has focus as reported by tkinter. If no element is found None is returned!
`find_element_with_focus()`
|Type|Name|Meaning|
|---|---|---|
|Element | None| **return** | An Element if one has been found with focus or None if no element found |
### force_focus
Forces this window to take focus
```python
force_focus()
```
### get_screen_dimensions
Get the screen dimensions. NOTE - you must have a window already open for this to work (blame tkinter not me)
`get_screen_dimensions()`
|Type|Name|Meaning|
|---|---|---|
|Tuple[None, None] | Tuple[width, height]| **return** | Tuple containing width and height of screen in pixels |
### get_screen_size
This is a "Class Method" meaning you call it by writing: width, height = Window.get_screen_size()
Returns the size of the "screen" as determined by tkinter. This can vary depending on your operating system and the number of monitors installed on your system. For Windows, the primary monitor's size is returns. On some multi-monitored Linux systems, the monitors are combined and the total size is reported as if one screen.
```
get_screen_size()
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | **RETURN** | Size of the screen in pixels as determined by tkinter
### grab_any_where_off
Turns off Grab Anywhere functionality AFTER a window has been created. Don't try on a window that's not yet
been Finalized or Read.
```python
grab_any_where_off()
```
### grab_any_where_on
Turns on Grab Anywhere functionality AFTER a window has been created. Don't try on a window that's not yet
been Finalized or Read.
```python
grab_any_where_on()
```
### hide
Hides the window from the screen and the task bar
```python
hide()
```
### keep_on_top_clear
Clears keep_on_top after a window has been created. Effect is the same
as if the window was created with this set.
```python
keep_on_top_clear()
```
### keep_on_top_set
Sets keep_on_top after a window has been created. Effect is the same
as if the window was created with this set. The Window is also brought
to the front
```python
keep_on_top_set()
```
### key_dict
#### property: key_dict
Returns a dictionary with all keys and their corresponding elements
{ key : Element }
|Type|Name|Meaning|
|---|---|---|
|Dict[Any, Element]| **return** | Dictionary of keys and elements |
### layout
Second of two preferred ways of telling a Window what its layout is. The other way is to pass the layout as
a parameter to Window object. The parameter method is the currently preferred method. This call to Layout
has been removed from examples contained in documents and in the Demo Programs. Trying to remove this call
from history and replace with sending as a parameter to Window.
```
layout(rows)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Elements]] | rows | Your entire layout |
| (Window) | **RETURN** | self so that you can chain method calls
### load_from_disk
Restore values from a previous call to SaveToDisk which saves the returned values dictionary in Pickle format
```
load_from_disk(filename)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | filename | Pickle Filename to load |
### make_modal
Makes a window into a "Modal Window"
This means user will not be able to interact with other windows until this one is closed
NOTE - Sorry Mac users - you can't have modal windows.... lobby your tkinter Mac devs
```python
make_modal()
```
### maximize
Maximize the window. This is done differently on a windows system versus a linux or mac one. For non-Windows
the root attribute '-fullscreen' is set to True. For Windows the "root" state is changed to "zoomed"
The reason for the difference is the title bar is removed in some cases when using fullscreen option
```python
maximize()
```
### metadata
#### property: metadata
Metadata is available for all windows. You can set to any value.
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### minimize
Minimize this window to the task bar
```python
minimize()
```
### move
Move the upper left corner of this window to the x,y coordinates provided
```
move(x, y)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | x | x coordinate in pixels |
| int | y | y coordinate in pixels |
### normal
Restore a window to a non-maximized state. Does different things depending on platform. See Maximize for more.
```python
normal()
```
### perform_long_operation
Call your function that will take a long time to execute. When it's complete, send an event
specified by the end_key.
```
perform_long_operation(func, end_key)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | func | A lambda or a function name with no parms |
| Any | end_key | The key that will be generated when the function returns |
| threading.Thread | **RETURN** | The id of the thread
### read
THE biggest deal method in the Window class! This is how you get all of your data from your Window.
Pass in a timeout (in milliseconds) to wait for a maximum of timeout milliseconds. Will return timeout_key
if no other GUI events happen first.
```
read(timeout = None,
timeout_key = "__TIMEOUT__",
close = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | timeout | Milliseconds to wait until the Read will return IF no other GUI events happen first |
| Any | timeout_key | The value that will be returned from the call if the timer expired |
| bool | close | if True the window will be closed prior to returning |
| Tuple[(Any), Dict[Any, Any], List[Any], None] | **RETURN** | (event, values)
### reappear
Causes a window previously made to "Disappear" (using that method). Does this by restoring the alpha channel
```python
reappear()
```
### refresh
Refreshes the window by calling tkroot.update(). Can sometimes get away with a refresh instead of a Read.
Use this call when you want something to appear in your Window immediately (as soon as this function is called).
Without this call your changes to a Window will not be visible to the user until the next Read call
`refresh()`
|Type|Name|Meaning|
|---|---|---|
|(Window)| **return** | `self` so that method calls can be easily "chained" |
### save_to_disk
Saves the values contained in each of the input areas of the form. Basically saves what would be returned from a call to Read. It takes these results and saves them to disk using pickle.
Note that every element in your layout that is to be saved must have a key assigned to it.
```
save_to_disk(filename)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | filename | Filename to save the values to in pickled form |
### send_to_back
Pushes this window to the bottom of the stack of windows. It is the opposite of BringToFront
```python
send_to_back()
```
### set_alpha
Sets the Alpha Channel for a window. Values are between 0 and 1 where 0 is completely transparent
```
set_alpha(alpha)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| float | alpha | 0 to 1. 0 is completely transparent. 1 is completely visible and solid (can't see through) |
### set_cursor
Sets the cursor for the window.
If you do not want any mouse pointer, then use the string "none"
```
set_cursor(cursor)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | cursor | The tkinter cursor name |
### set_icon
Changes the icon that is shown on the title bar and on the task bar.
NOTE - The file type is IMPORTANT and depends on the OS!
Can pass in:
* filename which must be a .ICO icon file for windows, PNG file for Linux
* bytes object
* BASE64 encoded file held in a variable
```
set_icon(icon = None, pngbase64 = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | icon | Filename or bytes object |
| bytes | pngbase64 | Base64 encoded image |
### set_min_size
Changes the minimum size of the window. Note Window must be read or finalized first.
```
set_min_size(size)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | size | (width, height) tuple (int, int) of the desired window size in pixels |
### set_title
Change the title of the window
```
set_title(title)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | title | The string to set the title to |
### set_transparent_color
Set the color that will be transparent in your window. Areas with this color will be SEE THROUGH.
```
set_transparent_color(color)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | color | Color string that defines the transparent color |
### size
#### property: size
Return the current size of the window in pixels
|Type|Name|Meaning|
|---|---|---|
|Tuple[(int), (int)] or Tuple[None, None]| **return** | (width, height) of the window |
### un_hide
Used to bring back a window that was previously hidden using the Hide method
```python
un_hide()
```
### visibility_changed
When making an element in a column or someplace that has a scrollbar, then you'll want to call this function
prior to the column's contents_changed() method.
```python
visibility_changed()
```
### was_closed
Returns True if the window was closed
`was_closed()`
|Type|Name|Meaning|
|---|---|---|
|bool| **return** | True if the window is closed |
### write_event_value
Adds a key & value tuple to the queue that is used by threads to communicate with the window
```
write_event_value(key, value)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | key | The key that will be returned as the event when reading the window |
| Any | value | The value that will be in the values dictionary |
---------
### These are non-PEP8 Compliant Methods - do NOT use
***Do not use these***... they are here for your reference should you see them in old code.
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### AddRow
Adds a single row of elements to a window's self.Rows variables.
Generally speaking this is NOT how users should be building Window layouts.
Users, create a single layout (a list of lists) and pass as a parameter to Window object, or call Window.Layout(layout)
```
AddRow(args=*<1 or N object>)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| | *args | List[Elements] |
### AddRows
Loops through a list of lists of elements and adds each row, list, to the layout.
This is NOT the best way to go about creating a window. Sending the entire layout at one time and passing
it as a parameter to the Window call is better.
```
AddRows(rows)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Elements]] | rows | A list of a list of elements |
### AlphaChannel
#### property: AlphaChannel
A property that changes the current alpha channel value (internal value)
|Type|Name|Meaning|
|---|---|---|
|(float)| **return** | the current alpha channel setting according to self, not read directly from tkinter |
### BringToFront
Brings this window to the top of all other windows (perhaps may not be brought before a window made to "stay
on top")
```python
BringToFront()
```
### Close
Closes window. Users can safely call even if window has been destroyed. Should always call when done with
a window so that resources are properly freed up within your thread.
```python
Close()
```
### CurrentLocation
Get the current location of the window's top left corner.
Sometimes, depending on the environment, the value returned does not include the titlebar,etc
A new option, more_accurate, can be used to get the theoretical upper leftmost corner of the window.
The titlebar and menubar are crated by the OS. It gets really confusing when running in a webpage (repl, trinket)
Thus, the values can appear top be "off" due to the sometimes unpredictable way the location is calculated.
```
CurrentLocation(more_accurate = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | more_accurate | If True, will use the window's geometry to get the topmost location with titlebar, menubar taken into account |
| Tuple[(int or None), (int or None)] | **RETURN** | The x and y location in tuple form (x,y)
### Disable
Disables window from taking any input from the user
```python
Disable()
```
### DisableDebugger
Disable the internal debugger. By default the debugger is ENABLED
```python
DisableDebugger()
```
### Disappear
Causes a window to "disappear" from the screen, but remain on the taskbar. It does this by turning the alpha
channel to 0. NOTE that on some platforms alpha is not supported. The window will remain showing on these
platforms. The Raspberry Pi for example does not have an alpha setting
```python
Disappear()
```
### Elem
Find element object associated with the provided key.
THIS METHOD IS NO LONGER NEEDED to be called by the user
You can perform the same operation by writing this statement:
element = window[key]
You can drop the entire "find_element" function name and use [ ] instead.
However, if you wish to perform a lookup without error checking, and don't have error popups turned
off globally, you'll need to make this call so that you can disable error checks on this call.
find_element is yypically used in combination with a call to element's Update method (or any other element method!):
window[key].update(new_value)
Versus the "old way"
window.FindElement(key).Update(new_value)
This call can be abbreviated to any of these:
find_element = FindElement == Element == Find
With find_element being the PEP8 compliant call that should be used.
Rememeber that this call will return None if no match is found which may cause your code to crash if not
checked for.
```
Elem(key, silent_on_error = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element |
| bool | silent_on_error | If True do not display popup nor print warning of key errors |
| Element or Error Element or None | **RETURN** | Return value can be: the Element that matches the supplied key if found; an Error Element if silent_on_error is False; None if silent_on_error True;
### Element
Find element object associated with the provided key.
THIS METHOD IS NO LONGER NEEDED to be called by the user
You can perform the same operation by writing this statement:
element = window[key]
You can drop the entire "find_element" function name and use [ ] instead.
However, if you wish to perform a lookup without error checking, and don't have error popups turned
off globally, you'll need to make this call so that you can disable error checks on this call.
find_element is yypically used in combination with a call to element's Update method (or any other element method!):
window[key].update(new_value)
Versus the "old way"
window.FindElement(key).Update(new_value)
This call can be abbreviated to any of these:
find_element = FindElement == Element == Find
With find_element being the PEP8 compliant call that should be used.
Rememeber that this call will return None if no match is found which may cause your code to crash if not
checked for.
```
Element(key, silent_on_error = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element |
| bool | silent_on_error | If True do not display popup nor print warning of key errors |
| Element or Error Element or None | **RETURN** | Return value can be: the Element that matches the supplied key if found; an Error Element if silent_on_error is False; None if silent_on_error True;
### Enable
Re-enables window to take user input after having it be Disabled previously
```python
Enable()
```
### EnableDebugger
Enables the internal debugger. By default, the debugger IS enabled
```python
EnableDebugger()
```
### Fill
Fill in elements that are input fields with data based on a 'values dictionary'
```
Fill(values_dict)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (Dict[Any, Any]) - {Element_key : value} | values_dict | pairs |
| (Window) | **RETURN** | returns self so can be chained with other methods
### Finalize
Use this method to cause your layout to built into a real tkinter window. In reality this method is like
Read(timeout=0). It doesn't block and uses your layout to create tkinter widgets to represent the elements.
Lots of action!
`Finalize()`
|Type|Name|Meaning|
|---|---|---|
|(Window)| **return** | Returns 'self' so that method "Chaining" can happen (read up about it as it's very cool!) |
### Find
Find element object associated with the provided key.
THIS METHOD IS NO LONGER NEEDED to be called by the user
You can perform the same operation by writing this statement:
element = window[key]
You can drop the entire "find_element" function name and use [ ] instead.
However, if you wish to perform a lookup without error checking, and don't have error popups turned
off globally, you'll need to make this call so that you can disable error checks on this call.
find_element is yypically used in combination with a call to element's Update method (or any other element method!):
window[key].update(new_value)
Versus the "old way"
window.FindElement(key).Update(new_value)
This call can be abbreviated to any of these:
find_element = FindElement == Element == Find
With find_element being the PEP8 compliant call that should be used.
Rememeber that this call will return None if no match is found which may cause your code to crash if not
checked for.
```
Find(key, silent_on_error = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element |
| bool | silent_on_error | If True do not display popup nor print warning of key errors |
| Element or Error Element or None | **RETURN** | Return value can be: the Element that matches the supplied key if found; an Error Element if silent_on_error is False; None if silent_on_error True;
### FindElement
** Warning ** This call will eventually be depricated. **
It is suggested that you modify your code to use the recommended window[key] lookup or the PEP8 compliant window.find_element(key)
For now, you'll only see a message printed and the call will continue to funcation as before.
```
FindElement(key, silent_on_error = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element |
| bool | silent_on_error | If True do not display popup nor print warning of key errors |
| Element or Error Element or None | **RETURN** | Return value can be: the Element that matches the supplied key if found; an Error Element if silent_on_error is False; None if silent_on_error True;
### FindElementWithFocus
Returns the Element that currently has focus as reported by tkinter. If no element is found None is returned!
`FindElementWithFocus()`
|Type|Name|Meaning|
|---|---|---|
|Element | None| **return** | An Element if one has been found with focus or None if no element found |
### GetScreenDimensions
Get the screen dimensions. NOTE - you must have a window already open for this to work (blame tkinter not me)
`GetScreenDimensions()`
|Type|Name|Meaning|
|---|---|---|
|Tuple[None, None] | Tuple[width, height]| **return** | Tuple containing width and height of screen in pixels |
### GrabAnyWhereOff
Turns off Grab Anywhere functionality AFTER a window has been created. Don't try on a window that's not yet
been Finalized or Read.
```python
GrabAnyWhereOff()
```
### GrabAnyWhereOn
Turns on Grab Anywhere functionality AFTER a window has been created. Don't try on a window that's not yet
been Finalized or Read.
```python
GrabAnyWhereOn()
```
### Hide
Hides the window from the screen and the task bar
```python
Hide()
```
### Layout
Second of two preferred ways of telling a Window what its layout is. The other way is to pass the layout as
a parameter to Window object. The parameter method is the currently preferred method. This call to Layout
has been removed from examples contained in documents and in the Demo Programs. Trying to remove this call
from history and replace with sending as a parameter to Window.
```
Layout(rows)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[Elements]] | rows | Your entire layout |
| (Window) | **RETURN** | self so that you can chain method calls
### LoadFromDisk
Restore values from a previous call to SaveToDisk which saves the returned values dictionary in Pickle format
```
LoadFromDisk(filename)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | filename | Pickle Filename to load |
### Maximize
Maximize the window. This is done differently on a windows system versus a linux or mac one. For non-Windows
the root attribute '-fullscreen' is set to True. For Windows the "root" state is changed to "zoomed"
The reason for the difference is the title bar is removed in some cases when using fullscreen option
```python
Maximize()
```
### Minimize
Minimize this window to the task bar
```python
Minimize()
```
### Move
Move the upper left corner of this window to the x,y coordinates provided
```
Move(x, y)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | x | x coordinate in pixels |
| int | y | y coordinate in pixels |
### Normal
Restore a window to a non-maximized state. Does different things depending on platform. See Maximize for more.
```python
Normal()
```
### Read
THE biggest deal method in the Window class! This is how you get all of your data from your Window.
Pass in a timeout (in milliseconds) to wait for a maximum of timeout milliseconds. Will return timeout_key
if no other GUI events happen first.
```
Read(timeout = None,
timeout_key = "__TIMEOUT__",
close = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | timeout | Milliseconds to wait until the Read will return IF no other GUI events happen first |
| Any | timeout_key | The value that will be returned from the call if the timer expired |
| bool | close | if True the window will be closed prior to returning |
| Tuple[(Any), Dict[Any, Any], List[Any], None] | **RETURN** | (event, values)
### Reappear
Causes a window previously made to "Disappear" (using that method). Does this by restoring the alpha channel
```python
Reappear()
```
### Refresh
Refreshes the window by calling tkroot.update(). Can sometimes get away with a refresh instead of a Read.
Use this call when you want something to appear in your Window immediately (as soon as this function is called).
Without this call your changes to a Window will not be visible to the user until the next Read call
`Refresh()`
|Type|Name|Meaning|
|---|---|---|
|(Window)| **return** | `self` so that method calls can be easily "chained" |
### SaveToDisk
Saves the values contained in each of the input areas of the form. Basically saves what would be returned from a call to Read. It takes these results and saves them to disk using pickle.
Note that every element in your layout that is to be saved must have a key assigned to it.
```
SaveToDisk(filename)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | filename | Filename to save the values to in pickled form |
### SendToBack
Pushes this window to the bottom of the stack of windows. It is the opposite of BringToFront
```python
SendToBack()
```
### SetAlpha
Sets the Alpha Channel for a window. Values are between 0 and 1 where 0 is completely transparent
```
SetAlpha(alpha)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| float | alpha | 0 to 1. 0 is completely transparent. 1 is completely visible and solid (can't see through) |
### SetIcon
Changes the icon that is shown on the title bar and on the task bar.
NOTE - The file type is IMPORTANT and depends on the OS!
Can pass in:
* filename which must be a .ICO icon file for windows, PNG file for Linux
* bytes object
* BASE64 encoded file held in a variable
```
SetIcon(icon = None, pngbase64 = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | icon | Filename or bytes object |
| bytes | pngbase64 | Base64 encoded image |
### SetTransparentColor
Set the color that will be transparent in your window. Areas with this color will be SEE THROUGH.
```
SetTransparentColor(color)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | color | Color string that defines the transparent color |
### Size
#### property: Size
Return the current size of the window in pixels
|Type|Name|Meaning|
|---|---|---|
|Tuple[(int), (int)] or Tuple[None, None]| **return** | (width, height) of the window |
### UnHide
Used to bring back a window that was previously hidden using the Hide method
```python
UnHide()
```
### VisibilityChanged
When making an element in a column or someplace that has a scrollbar, then you'll want to call this function
prior to the column's contents_changed() method.
```python
VisibilityChanged()
```
---------
## SystemTray
A "Simulated System Tray" that duplicates the API calls available to PySimpleGUIWx and PySimpleGUIQt users.
All of the functionality works. The icon is displayed ABOVE the system tray rather than inside of it.
SystemTray - create an icon in the system tray
```
SystemTray(menu = None,
filename = None,
data = None,
data_base64 = None,
tooltip = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[List[List[str] or str]] | menu | Menu definition. Example - ['UNUSED', ['My', 'Simple', '---', 'Menu', 'Exit']] |
| str | filename | filename for icon |
| bytes | data | in-ram image for icon (same as data_base64 parm) |
| bytes | data_base64 | base-64 data for icon |
| str | tooltip | tooltip string |
| Any | metadata | User metadata that can be set to ANYTHING |
### close
Close the system tray window
```python
close()
```
### hide
Hides the icon
```python
hide()
```
### metadata
#### property: metadata
Metadata is an SystemTray property that you can use at any time to hold any value
|Type|Name|Meaning|
|---|---|---|
|(Any)| **return** | the current metadata value |
### notify
Displays a "notification window", usually in the bottom right corner of your display. Has an icon, a title, and a message
The window will slowly fade in and out if desired. Clicking on the window will cause it to move through the end the current "phase". For example, if the window was fading in and it was clicked, then it would immediately stop fading in and instead be fully visible. It's a way for the user to quickly dismiss the window.
```
notify(title,
message,
icon = ...,
display_duration_in_ms = 3000,
fade_in_duration = 1000,
alpha = 0.9,
location = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | title | Text to be shown at the top of the window in a larger font |
| str | message | Text message that makes up the majority of the window |
| bytes or str | icon | A base64 encoded PNG/GIF image or PNG/GIF filename that will be displayed in the window |
| int | display_duration_in_ms | Number of milliseconds to show the window |
| int | fade_in_duration | Number of milliseconds to fade window in and out |
| float | alpha | Alpha channel. 0 - invisible 1 - fully visible |
| (int, int) | location | Location on the screen to display the window |
| (int) | **RETURN** | (int) reason for returning
### read
Reads the context menu
```
read(timeout = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| | timeout | Optional. Any value other than None indicates a non-blocking read |
### show_message
Shows a balloon above icon in system tray
```
show_message(title,
message,
filename = None,
data = None,
data_base64 = None,
messageicon = None,
time = (1000, 3000))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | title | Title shown in balloon |
| str | message | Message to be displayed |
| str | filename | Optional icon filename |
| b'' | data | Optional in-ram icon |
| b'' | data_base64 | Optional base64 icon |
| int or (int, int) | time | Amount of time to display message in milliseconds. If tuple, first item is fade in/out duration |
| Any | **RETURN** | The event that happened during the display such as user clicked on message
### un_hide
Restores a previously hidden icon
```python
un_hide()
```
### update
Updates the menu, tooltip or icon
```
update(menu = None,
tooltip = None,
filename = None,
data = None,
data_base64 = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| ??? | menu | menu defintion |
| ??? | tooltip | string representing tooltip |
| ??? | filename | icon filename |
| ??? | data | icon raw image |
| ??? | data_base64 | icon base 64 image |
---------
### These are non-PEP8 Compliant Methods - do NOT use
The following methods are here for backwards compatibility reference. You will find there are PEP8 versions for each of these methods. The PEP8 versions will be all lower case and have underscores.
### Close
Close the system tray window
```python
Close()
```
### Hide
Hides the icon
```python
Hide()
```
### Read
Reads the context menu
```
Read(timeout = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| | timeout | Optional. Any value other than None indicates a non-blocking read |
### ShowMessage
Shows a balloon above icon in system tray
```
ShowMessage(title,
message,
filename = None,
data = None,
data_base64 = None,
messageicon = None,
time = (1000, 3000))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | title | Title shown in balloon |
| str | message | Message to be displayed |
| str | filename | Optional icon filename |
| b'' | data | Optional in-ram icon |
| b'' | data_base64 | Optional base64 icon |
| int or (int, int) | time | Amount of time to display message in milliseconds. If tuple, first item is fade in/out duration |
| Any | **RETURN** | The event that happened during the display such as user clicked on message
### UnHide
Restores a previously hidden icon
```python
UnHide()
```
### Update
Updates the menu, tooltip or icon
```
Update(menu = None,
tooltip = None,
filename = None,
data = None,
data_base64 = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| ??? | menu | menu defintion |
| ??? | tooltip | string representing tooltip |
| ??? | filename | icon filename |
| ??? | data | icon raw image |
| ??? | data_base64 | icon base 64 image |
## Function Reference
These are the functions available for you to call
## Version Info
Returns a human-readable string of version numbers for:
Python version
PySimpleGUI Port (tkinter in this case)
tkinter version
PySimpleGUI version
The location of the PySimpleGUI.py file
The format is a newline between each value and descriptive text for each line
```
get_versions()
```
## Multi-window Interface
Reads all windows that are "active" when the call is made. "Active" means that it's been finalized or read.
If a window has not been finalized then it will not be considered an "active window"
If any of the active windows returns a value then the window and its event and values
are returned.
If no windows are open, then the value (None, WIN_CLOSED, None) will be returned
Since WIN_CLOSED is None, it means (None, None, None) is what's returned when no windows remain opened
```
read_all_windows(timeout = None, timeout_key = "__TIMEOUT__")
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | timeout | Time in milliseconds to delay before a returning a timeout event |
| Any | timeout_key | Key to return when a timeout happens. Defaults to the standard TIMEOUT_KEY |
| Tuple[Window, Any, (Dict or List)] | **RETURN** | A tuple with the (Window, event, values dictionary/list)
## Button Related
Button that will show a calendar chooser window. Fills in the target element with result
```
CalendarButton(button_text,
target = (555666777, -1),
close_when_date_chosen = True,
default_date_m_d_y = (None, None, None),
image_filename = None,
image_data = None,
image_size = (None, None),
image_subsample = None,
tooltip = None,
border_width = None,
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
disabled = False,
font = None,
bind_return_key = False,
focus = False,
pad = None,
enable_events = None,
key = None,
k = None,
locale = None,
format = "%Y-%m-%d %H:%M:%S",
begin_at_sunday_plus = 0,
month_names = None,
day_abbreviations = None,
title = "Choose Date",
no_titlebar = True,
location = (None, None),
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button |
| (int, int) or Any | target | Key or "coordinate" (see docs) of target element |
| bool | close_when_date_chosen | (Default = True) |
| (int, int or None, int) | default_date_m_d_y | Beginning date to show |
| image filename if there is a button image | image_filename | image filename if there is a button image |
| in-RAM image to be displayed on button | image_data | in-RAM image to be displayed on button |
| (Default = (None)) | image_size | image size (O.K.) |
| amount to reduce the size of the image | image_subsample | amount to reduce the size of the image |
| str | tooltip | text, that will appear when mouse hovers over the element |
| width of border around element | border_width | width of border around element |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | disabled | set disable state for element (Default = False) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | bind_return_key | (Default = False) If True, then the return key will cause a the Listbox to generate an event |
| bool | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| str | locale | defines the locale used to get day names |
| str | format | formats result using this strftime format |
| List[str] | month_names | optional list of month names to use (should be 12 items) |
| List[str] | day_abbreviations | optional list of abbreviations to display as the day of week |
| str | title | Title shown on the date chooser window |
| bool | no_titlebar | if True no titlebar will be shown on the date chooser window |
| (int, int) | location | Location on the screen (x,y) to show the calendar popup window |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
Cancel(button_text = "Cancel",
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
disabled = False,
tooltip = None,
font = None,
bind_return_key = False,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'Cancel') |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | disabled | set disable state for element (Default = False) |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | bind_return_key | (Default = False) If True, then the return key will cause a the Listbox to generate an event |
| | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
ColorChooserButton(button_text,
target = (555666777, -1),
image_filename = None,
image_data = None,
image_size = (None, None),
image_subsample = None,
tooltip = None,
border_width = None,
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
disabled = False,
font = None,
bind_return_key = False,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button |
| str or (int, int) | target | key or (row,col) target for the button. Note that -1 for column means 1 element to the left of this one. The constant ThisRow is used to indicate the current row. The Button itself is a valid target for some types of button |
| str | image_filename | image filename if there is a button image. GIFs and PNGs only. |
| bytes or str | image_data | Raw or Base64 representation of the image to put on button. Choose either filename or data |
| (int, int) | image_size | Size of the image in pixels (width, height) |
| int | image_subsample | amount to reduce the size of the image. Divides the size by this number. 2=1/2, 3=1/3, 4=1/4, etc |
| str | tooltip | text, that will appear when mouse hovers over the element |
| int | border_width | width of border around element |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | disabled | set disable state for element (Default = False) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | bind_return_key | If True, then the return key will cause a the Listbox to generate an event |
| bool | focus | Determines if initial focus should go to this element. |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | User metadata that can be set to ANYTHING |
| (Button) | **RETURN** | returns a button
```
Debug(button_text = "",
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
disabled = False,
font = None,
tooltip = None,
bind_return_key = False,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = '') |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | disabled | set disable state for element (Default = False) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str | tooltip | text, that will appear when mouse hovers over the element |
| bool | bind_return_key | (Default = False) If True, then the return key will cause a the Listbox to generate an event |
| | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
DummyButton(button_text,
image_filename = None,
image_data = None,
image_size = (None, None),
image_subsample = None,
border_width = None,
tooltip = None,
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
font = None,
disabled = False,
bind_return_key = False,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button |
| image filename if there is a button image | image_filename | image filename if there is a button image |
| in-RAM image to be displayed on button | image_data | in-RAM image to be displayed on button |
| (Default = (None)) | image_size | image size (O.K.) |
| amount to reduce the size of the image | image_subsample | amount to reduce the size of the image |
| int | border_width | width of border around element |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | disabled | set disable state for element (Default = False) |
| bool | bind_return_key | (Default = False) If True, then the return key will cause a the Listbox to generate an event |
| bool | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
Exit(button_text = "Exit",
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
disabled = False,
tooltip = None,
font = None,
bind_return_key = False,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'Exit') |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | disabled | set disable state for element (Default = False) |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | bind_return_key | (Default = False) If True, then the return key will cause a the Listbox to generate an event |
| | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
FileBrowse(button_text = "Browse",
target = (555666777, -1),
file_types = (('ALL Files', '*.*'),),
initial_folder = None,
tooltip = None,
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
change_submits = False,
enable_events = False,
font = None,
disabled = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'Browse') |
| str or (int, int) | target | key or (row,col) target for the button (Default value = (ThisRow, -1)) |
| Tuple[(str, str), ...] | file_types | filter file types (Default value = (("ALL Files", "*.*"))) |
| | initial_folder | starting path for folders and files |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | change_submits | If True, pressing Enter key submits window (Default = False) |
| bool | enable_events | Turns on the element specific events.(Default = False) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | disabled | set disable state for element (Default = False) |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
FileSaveAs(button_text = "Save As...",
target = (555666777, -1),
file_types = (('ALL Files', '*.*'),),
initial_folder = None,
default_extension = "",
disabled = False,
tooltip = None,
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
change_submits = False,
enable_events = False,
font = None,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'Save As...') |
| str or (int, int) | target | key or (row,col) target for the button (Default value = (ThisRow, -1)) |
| Tuple[(str, str), ...] | file_types | (Default value = (("ALL Files", "*.*"))) |
| str | default_extension | If no extension entered by user, add this to filename (only used in saveas dialogs) |
| str | initial_folder | starting path for folders and files |
| bool | disabled | set disable state for element (Default = False) |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | change_submits | If True, pressing Enter key submits window (Default = False) |
| bool | enable_events | Turns on the element specific events.(Default = False) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
Allows browsing of multiple files. File list is returned as a single list with the delimiter defined using the files_delimiter parameter.
```
FilesBrowse(button_text = "Browse",
target = (555666777, -1),
file_types = (('ALL Files', '*.*'),),
disabled = False,
initial_folder = None,
tooltip = None,
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
change_submits = False,
enable_events = False,
font = None,
pad = None,
key = None,
k = None,
files_delimiter = ";",
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'Browse') |
| str or (int, int) | target | key or (row,col) target for the button (Default value = (ThisRow, -1)) |
| Tuple[(str, str), ...] | file_types | (Default value = (("ALL Files", "*.*"))) |
| bool | disabled | set disable state for element (Default = False) |
| str | initial_folder | starting path for folders and files |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | change_submits | If True, pressing Enter key submits window (Default = False) |
| bool | enable_events | Turns on the element specific events.(Default = False) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| str | files_delimiter | String to place between files when multiple files are selected. Normally a ; |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
FolderBrowse(button_text = "Browse",
target = (555666777, -1),
initial_folder = None,
tooltip = None,
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
disabled = False,
change_submits = False,
enable_events = False,
font = None,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'Browse') |
| str or (int, int) | target | target for the button (Default value = (ThisRow, -1)) |
| str | initial_folder | starting path for folders and files |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| | button_color | button color (foreground, background) |
| bool | disabled | set disable state for element (Default = False) |
| bool | change_submits | If True, pressing Enter key submits window (Default = False) |
| bool | enable_events | Turns on the element specific events.(Default = False) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | Used with window.find_element and with return values to uniquely identify this element |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | The Button created
```
Help(button_text = "Help",
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
disabled = False,
font = None,
tooltip = None,
bind_return_key = False,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'Help') |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | disabled | set disable state for element (Default = False) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str | tooltip | text, that will appear when mouse hovers over the element |
| bool | bind_return_key | (Default = False) If True, then the return key will cause a the Listbox to generate an event |
| | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
No(button_text = "No",
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
disabled = False,
tooltip = None,
font = None,
bind_return_key = False,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'No') |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | disabled | set disable state for element (Default = False) |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | bind_return_key | (Default = False) If True, then the return key will cause a the Listbox to generate an event |
| | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
OK(button_text = "OK",
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
disabled = False,
bind_return_key = True,
tooltip = None,
font = None,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'OK') |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | disabled | set disable state for element (Default = False) |
| bool | bind_return_key | (Default = True) If True, then the return key will cause a the Listbox to generate an event |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| idk_yetReally | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
Dumps an Object's values as a formatted string. Very nicely done. Great way to display an object's member variables in human form
```
ObjToString(obj, extra = " ")
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | obj | The object to display |
| str | extra | extra stuff (Default value = ' ') |
| (str) | **RETURN** | Formatted output of the object's values
Dumps an Object's values as a formatted string. Very nicely done. Great way to display an object's member variables in human form
Returns only the top-most object's variables instead of drilling down to dispolay more
```
ObjToStringSingleObj(obj)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | obj | The object to display |
| (str) | **RETURN** | Formatted output of the object's values
```
Ok(button_text = "Ok",
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
disabled = False,
bind_return_key = True,
tooltip = None,
font = None,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'Ok') |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | disabled | set disable state for element (Default = False) |
| bool | bind_return_key | (Default = True) If True, then the return key will cause a the Listbox to generate an event |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| idk_yetReally | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
Open(button_text = "Open",
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
disabled = False,
bind_return_key = True,
tooltip = None,
font = None,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'Open') |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | disabled | set disable state for element (Default = False) |
| bool | bind_return_key | (Default = True) If True, then the return key will cause a the Listbox to generate an event |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| idk_yetReally | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
Quit(button_text = "Quit",
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
disabled = False,
tooltip = None,
font = None,
bind_return_key = False,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'Quit') |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | disabled | set disable state for element (Default = False) |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | bind_return_key | (Default = False) If True, then the return key will cause a the Listbox to generate an event |
| bool | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
RealtimeButton(button_text,
image_filename = None,
image_data = None,
image_size = (None, None),
image_subsample = None,
border_width = None,
tooltip = None,
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
font = None,
disabled = False,
bind_return_key = False,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button |
| image filename if there is a button image | image_filename | image filename if there is a button image |
| in-RAM image to be displayed on button | image_data | in-RAM image to be displayed on button |
| (Default = (None)) | image_size | image size (O.K.) |
| amount to reduce the size of the image | image_subsample | amount to reduce the size of the image |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | disabled | set disable state for element (Default = False) |
| bool | bind_return_key | (Default = False) If True, then the return key will cause a the Listbox to generate an event |
| bool | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| int | border_width | width of border around element |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | Button created
```
Save(button_text = "Save",
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
bind_return_key = True,
disabled = False,
tooltip = None,
font = None,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'Save') |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | bind_return_key | (Default = True) If True, then the return key will cause a the Listbox to generate an event |
| bool | disabled | set disable state for element (Default = False) |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| idk_yetReally | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
SaveAs(button_text = "Save As...",
target = (555666777, -1),
file_types = (('ALL Files', '*.*'),),
initial_folder = None,
default_extension = "",
disabled = False,
tooltip = None,
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
change_submits = False,
enable_events = False,
font = None,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'Save As...') |
| str or (int, int) | target | key or (row,col) target for the button (Default value = (ThisRow, -1)) |
| Tuple[(str, str), ...] | file_types | (Default value = (("ALL Files", "*.*"))) |
| str | default_extension | If no extension entered by user, add this to filename (only used in saveas dialogs) |
| str | initial_folder | starting path for folders and files |
| bool | disabled | set disable state for element (Default = False) |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | change_submits | If True, pressing Enter key submits window (Default = False) |
| bool | enable_events | Turns on the element specific events.(Default = False) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
Submit(button_text = "Submit",
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
disabled = False,
bind_return_key = True,
tooltip = None,
font = None,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'Submit') |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | disabled | set disable state for element (Default = False) |
| bool | bind_return_key | (Default = True) If True, then the return key will cause a the Listbox to generate an event |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| idk_yetReally | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
Yes(button_text = "Yes",
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
disabled = False,
tooltip = None,
font = None,
bind_return_key = True,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button (Default value = 'Yes') |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | disabled | set disable state for element (Default = False) |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | bind_return_key | (Default = True) If True, then the return key will cause a the Listbox to generate an event |
| | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
## Button Functions No Longer Used (DO NOT USE)
Note - These are no longer recommended!
They are shown here in case you run into them in some old code.
```
RButton(button_text,
image_filename = None,
image_data = None,
image_size = (None, None),
image_subsample = None,
border_width = None,
tooltip = None,
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
font = None,
bind_return_key = False,
disabled = False,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button |
| image filename if there is a button image | image_filename | image filename if there is a button image |
| in-RAM image to be displayed on button | image_data | in-RAM image to be displayed on button |
| (Default = (None)) | image_size | image size (O.K.) |
| amount to reduce the size of the image | image_subsample | amount to reduce the size of the image |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | bind_return_key | (Default = False) If True, then the return key will cause a the Listbox to generate an event |
| bool | disabled | set disable state for element (Default = False) |
| idk_yetReally | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| int | border_width | width of border around element |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | Button created
```
ReadButton(button_text,
image_filename = None,
image_data = None,
image_size = (None, None),
image_subsample = None,
border_width = None,
tooltip = None,
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
font = None,
bind_return_key = False,
disabled = False,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button |
| image filename if there is a button image | image_filename | image filename if there is a button image |
| in-RAM image to be displayed on button | image_data | in-RAM image to be displayed on button |
| (Default = (None)) | image_size | image size (O.K.) |
| amount to reduce the size of the image | image_subsample | amount to reduce the size of the image |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | bind_return_key | (Default = False) If True, then the return key will cause a the Listbox to generate an event |
| bool | disabled | set disable state for element (Default = False) |
| idk_yetReally | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| int | border_width | width of border around element |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | Button created
```
CButton(button_text,
image_filename = None,
image_data = None,
image_size = (None, None),
image_subsample = None,
border_width = None,
tooltip = None,
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
font = None,
bind_return_key = False,
disabled = False,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button |
| image filename if there is a button image | image_filename | image filename if there is a button image |
| in-RAM image to be displayed on button | image_data | in-RAM image to be displayed on button |
| (Default = (None)) | image_size | image size (O.K.) |
| amount to reduce the size of the image | image_subsample | amount to reduce the size of the image |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | bind_return_key | (Default = False) If True, then the return key will cause a the Listbox to generate an event |
| bool | disabled | set disable state for element (Default = False) |
| idk_yetReally | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
```
CloseButton(button_text,
image_filename = None,
image_data = None,
image_size = (None, None),
image_subsample = None,
border_width = None,
tooltip = None,
size = (None, None),
s = (None, None),
auto_size_button = None,
button_color = None,
font = None,
bind_return_key = False,
disabled = False,
focus = False,
pad = None,
key = None,
k = None,
metadata = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | button_text | text in the button |
| image filename if there is a button image | image_filename | image filename if there is a button image |
| in-RAM image to be displayed on button | image_data | in-RAM image to be displayed on button |
| (Default = (None)) | image_size | image size (O.K.) |
| amount to reduce the size of the image | image_subsample | amount to reduce the size of the image |
| str | tooltip | text, that will appear when mouse hovers over the element |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) or (None, None) or int | s | Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used |
| bool | auto_size_button | True if button size is determined by button text |
| (str, str) or str | button_color | button color (foreground, background) |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | bind_return_key | (Default = False) If True, then the return key will cause a the Listbox to generate an event |
| bool | disabled | set disable state for element (Default = False) |
| idk_yetReally | focus | if focus should be set to this |
| (int, int or (int, int),(int,int) or int,(int,int)) or ((int, int),int) or int | pad | Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) |
| str or int or tuple or object | key | key for uniquely identify this element (for window.find_element) |
| str or int or tuple or object | k | Same as the Key. You can use either k or key. Which ever is set will be used. |
| Any | metadata | Anything you want to store along with this button |
| (Button) | **RETURN** | returns a button
## Debug Window Output
Works like a "print" statement but with windowing options. Routes output to the "Debug Window"
In addition to the normal text and background colors, you can use a "colors" tuple/string
The "colors" or "c" parameter defines both the text and background in a single parm.
It can be a tuple or a single single. Both text and background colors need to be specified
colors -(str, str) or str. A combined text/background color definition in a single parameter
c - (str, str) - Colors tuple has format (foreground, backgrouned)
c - str - can also be a string of the format "foreground on background" ("white on red")
```
easy_print(args=*<1 or N object>,
size = (None, None),
end = None,
sep = None,
location = (None, None),
font = None,
no_titlebar = False,
no_button = False,
grab_anywhere = False,
keep_on_top = False,
do_not_reroute_stdout = True,
echo_stdout = False,
text_color = None,
background_color = None,
colors = None,
c = None,
erase_all = False,
resizable = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | stuff to output |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| str | end | end character |
| str | sep | separator character |
| (int, int) | location | Location of upper left corner of the window |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | no_button | don't show button |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| bool | do_not_reroute_stdout | do not reroute stdout and stderr. If False, both stdout and stderr will reroute to here |
| bool | echo_stdout | If True stdout is sent to both the console and the debug window |
| str or str, str | colors | Either a tuple or a string that has both the text and background colors |
| str or str, str | c | Either a tuple or a string that has both the text and background colors |
| bool | resizable | if True, the user can resize the debug window. Default is True |
| bool | erase_all | If True when erase the output before printing |
Close a previously opened EasyPrint window
```
easy_print_close()
```
Works like a "print" statement but with windowing options. Routes output to the "Debug Window"
In addition to the normal text and background colors, you can use a "colors" tuple/string
The "colors" or "c" parameter defines both the text and background in a single parm.
It can be a tuple or a single single. Both text and background colors need to be specified
colors -(str, str) or str. A combined text/background color definition in a single parameter
c - (str, str) - Colors tuple has format (foreground, backgrouned)
c - str - can also be a string of the format "foreground on background" ("white on red")
```
eprint(args=*<1 or N object>,
size = (None, None),
end = None,
sep = None,
location = (None, None),
font = None,
no_titlebar = False,
no_button = False,
grab_anywhere = False,
keep_on_top = False,
do_not_reroute_stdout = True,
echo_stdout = False,
text_color = None,
background_color = None,
colors = None,
c = None,
erase_all = False,
resizable = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | stuff to output |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| str | end | end character |
| str | sep | separator character |
| (int, int) | location | Location of upper left corner of the window |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | no_button | don't show button |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| bool | do_not_reroute_stdout | do not reroute stdout and stderr. If False, both stdout and stderr will reroute to here |
| bool | echo_stdout | If True stdout is sent to both the console and the debug window |
| str or str, str | colors | Either a tuple or a string that has both the text and background colors |
| str or str, str | c | Either a tuple or a string that has both the text and background colors |
| bool | resizable | if True, the user can resize the debug window. Default is True |
| bool | erase_all | If True when erase the output before printing |
Works like a "print" statement but with windowing options. Routes output to the "Debug Window"
In addition to the normal text and background colors, you can use a "colors" tuple/string
The "colors" or "c" parameter defines both the text and background in a single parm.
It can be a tuple or a single single. Both text and background colors need to be specified
colors -(str, str) or str. A combined text/background color definition in a single parameter
c - (str, str) - Colors tuple has format (foreground, backgrouned)
c - str - can also be a string of the format "foreground on background" ("white on red")
```
sgprint(args=*<1 or N object>,
size = (None, None),
end = None,
sep = None,
location = (None, None),
font = None,
no_titlebar = False,
no_button = False,
grab_anywhere = False,
keep_on_top = False,
do_not_reroute_stdout = True,
echo_stdout = False,
text_color = None,
background_color = None,
colors = None,
c = None,
erase_all = False,
resizable = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | stuff to output |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| str | end | end character |
| str | sep | separator character |
| (int, int) | location | Location of upper left corner of the window |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | no_button | don't show button |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| bool | do_not_reroute_stdout | do not reroute stdout and stderr. If False, both stdout and stderr will reroute to here |
| bool | echo_stdout | If True stdout is sent to both the console and the debug window |
| str or str, str | colors | Either a tuple or a string that has both the text and background colors |
| str or str, str | c | Either a tuple or a string that has both the text and background colors |
| bool | resizable | if True, the user can resize the debug window. Default is True |
| bool | erase_all | If True when erase the output before printing |
Close a previously opened EasyPrint window
```
sgprint_close()
```
Works like a "print" statement but with windowing options. Routes output to the "Debug Window"
In addition to the normal text and background colors, you can use a "colors" tuple/string
The "colors" or "c" parameter defines both the text and background in a single parm.
It can be a tuple or a single single. Both text and background colors need to be specified
colors -(str, str) or str. A combined text/background color definition in a single parameter
c - (str, str) - Colors tuple has format (foreground, backgrouned)
c - str - can also be a string of the format "foreground on background" ("white on red")
```
EasyPrint(args=*<1 or N object>,
size = (None, None),
end = None,
sep = None,
location = (None, None),
font = None,
no_titlebar = False,
no_button = False,
grab_anywhere = False,
keep_on_top = False,
do_not_reroute_stdout = True,
echo_stdout = False,
text_color = None,
background_color = None,
colors = None,
c = None,
erase_all = False,
resizable = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | stuff to output |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| str | end | end character |
| str | sep | separator character |
| (int, int) | location | Location of upper left corner of the window |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | no_button | don't show button |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| bool | do_not_reroute_stdout | do not reroute stdout and stderr. If False, both stdout and stderr will reroute to here |
| bool | echo_stdout | If True stdout is sent to both the console and the debug window |
| str or str, str | colors | Either a tuple or a string that has both the text and background colors |
| str or str, str | c | Either a tuple or a string that has both the text and background colors |
| bool | resizable | if True, the user can resize the debug window. Default is True |
| bool | erase_all | If True when erase the output before printing |
Close a previously opened EasyPrint window
```
EasyPrintClose()
```
Works like a "print" statement but with windowing options. Routes output to the "Debug Window"
In addition to the normal text and background colors, you can use a "colors" tuple/string
The "colors" or "c" parameter defines both the text and background in a single parm.
It can be a tuple or a single single. Both text and background colors need to be specified
colors -(str, str) or str. A combined text/background color definition in a single parameter
c - (str, str) - Colors tuple has format (foreground, backgrouned)
c - str - can also be a string of the format "foreground on background" ("white on red")
```
Print(args=*<1 or N object>,
size = (None, None),
end = None,
sep = None,
location = (None, None),
font = None,
no_titlebar = False,
no_button = False,
grab_anywhere = False,
keep_on_top = False,
do_not_reroute_stdout = True,
echo_stdout = False,
text_color = None,
background_color = None,
colors = None,
c = None,
erase_all = False,
resizable = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | stuff to output |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| str | end | end character |
| str | sep | separator character |
| (int, int) | location | Location of upper left corner of the window |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | no_button | don't show button |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| bool | do_not_reroute_stdout | do not reroute stdout and stderr. If False, both stdout and stderr will reroute to here |
| bool | echo_stdout | If True stdout is sent to both the console and the debug window |
| str or str, str | colors | Either a tuple or a string that has both the text and background colors |
| str or str, str | c | Either a tuple or a string that has both the text and background colors |
| bool | resizable | if True, the user can resize the debug window. Default is True |
| bool | erase_all | If True when erase the output before printing |
Close a previously opened EasyPrint window
```
PrintClose()
```
## Color Printing to Multiline Element of a Window
Color print to a multiline element in a window of your choice.
Must have EITHER called cprint_set_output_destination prior to making this call so that the
window and element key can be saved and used here to route the output, OR used the window
and key parameters to the cprint function to specicy these items.
args is a variable number of things you want to print.
end - The end char to use just like print uses
sep - The separation character like print uses
text_color - The color of the text
key - overrides the previously defined Multiline key
window - overrides the previously defined window to output to
background_color - The color of the background
colors -(str, str) or str. A combined text/background color definition in a single parameter
There are also "aliases" for text_color, background_color and colors (t, b, c)
t - An alias for color of the text (makes for shorter calls)
b - An alias for the background_color parameter
c - (str, str) - "shorthand" way of specifying color. (foreground, backgrouned)
c - str - can also be a string of the format "foreground on background" ("white on red")
With the aliases it's possible to write the same print but in more compact ways:
cprint('This will print white text on red background', c=('white', 'red'))
cprint('This will print white text on red background', c='white on red')
cprint('This will print white text on red background', text_color='white', background_color='red')
cprint('This will print white text on red background', t='white', b='red')
```
cprint(args=*<1 or N object>,
end = None,
sep = " ",
text_color = None,
font = None,
t = None,
background_color = None,
b = None,
colors = None,
c = None,
window = None,
key = None,
justification = None,
autoscroll = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | stuff to output |
| str | text_color | Color of the text |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike for the value being updated |
| str | background_color | The background color of the line |
| str or str, str | colors | Either a tuple or a string that has both the text and background colors "text on background" or just the text color |
| str | t | Color of the text |
| str | b | The background color of the line |
| str or str, str | c | Either a tuple or a string. Same as the color parm |
| str | end | end character |
| str | sep | separator character |
| Any | key | key of multiline to output to (if you want to override the one previously set) |
| | window | Window containing the multiline to output to (if you want to override the one previously set) |
| str | justification | text justification. left, right, center. Can use single characters l, r, c. Sets only for this value, not entire element |
| bool | autoscroll | If True the contents of the element will automatically scroll as more data added to the end |
Sets up the color print (cprint) output destination
```
cprint_set_output_destination(window, multiline_key)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Window | window | The window that the cprint call will route the output to |
| Any | multiline_key | Key for the Multiline Element where output will be sent |
| None | **RETURN** | None
## OneLineProgressMeter
```
OneLineProgressMeter(title,
current_value,
max_value,
args=*<1 or N object>,
key = "OK for 1 meter",
orientation = "v",
bar_color = (None, None),
button_color = None,
size = (20, 20),
border_width = None,
grab_anywhere = False,
no_titlebar = False,
keep_on_top = False,
no_button = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | title | text to display in eleemnt |
| int | current_value | current value |
| int | max_value | max value of QuickMeter |
| Any | *args | stuff to output |
| str or int or tuple or object | key | Used to differentiate between mutliple meters. Used to cancel meter early. Now optional as there is a default value for single meters |
| str | orientation | 'horizontal' or 'vertical' ('h' or 'v' work) (Default value = 'vertical' / 'v') |
| Tuple(str, str) | bar_color | color of a bar line |
| (str, str) or str | button_color | button color (foreground, background) |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high (Default value = DEFAULT_PROGRESS_BAR_SIZE) |
| int | border_width | width of border around element |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | no_titlebar | If True: no titlebar will be shown on the window |
| bool | keep_on_top | If True the window will remain above all current windows |
| bool | no_button | If True: window will be created without a cancel button |
| (bool) | **RETURN** | True if updated successfully. False if user closed the meter with the X or Cancel button
Cancels and closes a previously created One Line Progress Meter window
```
OneLineProgressMeterCancel(key = "OK for 1 meter")
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | key | Key used when meter was created |
| None | **RETURN** | None
```
one_line_progress_meter(title,
current_value,
max_value,
args=*<1 or N object>,
key = "OK for 1 meter",
orientation = "v",
bar_color = (None, None),
button_color = None,
size = (20, 20),
border_width = None,
grab_anywhere = False,
no_titlebar = False,
keep_on_top = False,
no_button = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | title | text to display in eleemnt |
| int | current_value | current value |
| int | max_value | max value of QuickMeter |
| Any | *args | stuff to output |
| str or int or tuple or object | key | Used to differentiate between mutliple meters. Used to cancel meter early. Now optional as there is a default value for single meters |
| str | orientation | 'horizontal' or 'vertical' ('h' or 'v' work) (Default value = 'vertical' / 'v') |
| Tuple(str, str) | bar_color | color of a bar line |
| (str, str) or str | button_color | button color (foreground, background) |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high (Default value = DEFAULT_PROGRESS_BAR_SIZE) |
| int | border_width | width of border around element |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | no_titlebar | If True: no titlebar will be shown on the window |
| bool | keep_on_top | If True the window will remain above all current windows |
| bool | no_button | If True: window will be created without a cancel button |
| (bool) | **RETURN** | True if updated successfully. False if user closed the meter with the X or Cancel button
Cancels and closes a previously created One Line Progress Meter window
```
one_line_progress_meter_cancel(key = "OK for 1 meter")
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | key | Key used when meter was created |
| None | **RETURN** | None
## Popups PEP8 Versions
Popup - Display a popup Window with as many parms as you wish to include. This is the GUI equivalent of the
"print" statement. It's also great for "pausing" your program's flow until the user can read some error messages.
```
popup(args=*<1 or N object>,
title = None,
button_color = None,
background_color = None,
text_color = None,
button_type = 0,
auto_close = False,
auto_close_duration = None,
custom_text = (None, None),
non_blocking = False,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
any_key_closes = False,
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of your arguments. Load up the call with stuff to see! |
| str | title | Optional title for the window. If none provided, the first arg will be used instead. |
| (str, str) or None | button_color | Color of the buttons shown (text color, button color) |
| str | background_color | Window's background color |
| str | text_color | text color |
| int | button_type | NOT USER SET! Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). There are many Popup functions and they call Popup, changing this parameter to get the desired effect. |
| bool | auto_close | If True the window will automatically close |
| int | auto_close_duration | time in seconds to keep window open before closing it automatically |
| (str, str) or str | custom_text | A string or pair of strings that contain the text to display on the buttons |
| bool | non_blocking | If True then will immediately return from the function without waiting for the user's input. |
| str or bytes | icon | icon to display on the window. Same format as a Window call |
| int | line_width | Width of lines in characters. Defaults to MESSAGE_BOX_LINE_WIDTH |
| str or Tuple[font_name, size, modifiers] | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True will not show the frame around the window and the titlebar across the top |
| bool | grab_anywhere | If True can grab anywhere to move the window. If no_titlebar is True, grab_anywhere should likely be enabled too |
| (int, int) | location | Location on screen to display the top left corner of window. Defaults to window centered on screen |
| bool | keep_on_top | If True the window will remain above all current windows |
| bool | any_key_closes | If True then will turn on return_keyboard_events for the window which will cause window to close as soon as any key is pressed. Normally the return key only will close the window. Default is false. |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Show animation one frame at a time. This function has its own internal clocking meaning you can call it at any frequency
and the rate the frames of video is shown remains constant. Maybe your frames update every 30 ms but your
event loop is running every 10 ms. You don't have to worry about delaying, just call it every time through the
loop.
```
popup_animated(image_source,
message = None,
background_color = None,
text_color = None,
font = None,
no_titlebar = True,
grab_anywhere = True,
keep_on_top = True,
location = (None, None),
alpha_channel = None,
time_between_frames = 0,
transparent_color = None,
title = "",
icon = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str or bytes or None | image_source | Either a filename or a base64 string. Use None to close the window. |
| str | message | An optional message to be shown with the animation |
| str | background_color | color of background |
| str | text_color | color of the text |
| str or tuple | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True then the titlebar and window frame will not be shown |
| bool | grab_anywhere | If True then you can move the window just clicking anywhere on window, hold and drag |
| bool | keep_on_top | If True then Window will remain on top of all other windows currently shownn |
| (int, int) | location | (x,y) location on the screen to place the top left corner of your window. Default is to center on screen |
| float | alpha_channel | Window transparency 0 = invisible 1 = completely visible. Values between are see through |
| int | time_between_frames | Amount of time in milliseconds between each frame |
| str | transparent_color | This color will be completely see-through in your window. Can even click through |
| str | title | Title that will be shown on the window |
| str or bytes | icon | Same as Window icon parameter. Can be either a filename or Base64 byte string. For Windows if filename, it MUST be ICO format. For Linux, must NOT be ICO |
| bool | **RETURN** | True if the window updated OK. False if the window was closed
Popup that closes itself after some time period
```
popup_auto_close(args=*<1 or N object>,
title = None,
button_type = 0,
button_color = None,
background_color = None,
text_color = None,
auto_close = True,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| int | button_type | Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Display Popup with "cancelled" button text
```
popup_cancel(args=*<1 or N object>,
title = None,
button_color = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Popup with colored button and 'Error' as button text
```
popup_error(args=*<1 or N object>,
title = None,
button_color = (None, None),
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Display a calendar window, get the user's choice, return as a tuple (mon, day, year)
```
popup_get_date(start_mon = None,
start_day = None,
start_year = None,
begin_at_sunday_plus = 0,
no_titlebar = True,
title = "Choose Date",
keep_on_top = True,
location = (None, None),
close_when_chosen = False,
icon = None,
locale = None,
month_names = None,
day_abbreviations = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | start_mon | The starting month |
| int or None | start_day | The starting day - optional. Set to None or 0 if no date to be chosen at start |
| int | start_year | The starting year |
| int | begin_at_sunday_plus | Determines the left-most day in the display. 0=sunday, 1=monday, etc |
| (str or bytes) | icon | Same as Window icon parameter. Can be either a filename or Base64 value. For Windows if filename, it MUST be ICO format. For Linux, must NOT be ICO |
| (int, int) | location | (x,y) location on the screen to place the top left corner of your window. Default is to center on screen |
| str | title | Title that will be shown on the window |
| bool | close_when_chosen | If True, the window will close and function return when a day is clicked |
| str | locale | locale used to get the day names |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | keep_on_top | If True the window will remain above all current windows |
| List[str] | month_names | optional list of month names to use (should be 12 items) |
| List[str] | day_abbreviations | optional list of abbreviations to display as the day of week |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| None or (int, int, int) | **RETURN** | Tuple containing (month, day, year) of chosen date or None if was cancelled
Display popup window with text entry field and browse button so that a file can be chosen by user.
```
popup_get_file(message,
title = None,
default_path = "",
default_extension = "",
save_as = False,
multiple_files = False,
file_types = (('ALL Files', '*.*'),),
no_window = False,
size = (None, None),
button_color = None,
background_color = None,
text_color = None,
icon = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
initial_folder = None,
image = None,
files_delimiter = ";",
modal = True,
history = False,
history_setting_filename = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | message | message displayed to user |
| str | title | Window title |
| str | default_path | path to display to user as starting point (filled into the input field) |
| str | default_extension | If no extension entered by user, add this to filename (only used in saveas dialogs) |
| bool | save_as | if True, the "save as" dialog is shown which will verify before overwriting |
| bool | multiple_files | if True, then allows multiple files to be selected that are returned with ';' between each filename |
| Tuple[Tuple[str,str]] | file_types | List of extensions to show using wildcards. All files (the default) = (("ALL Files", "*.*"),) |
| bool | no_window | if True, no PySimpleGUI window will be shown. Instead just the tkinter dialog is shown |
| (int, int) | size | (width, height) of the InputText Element or Combo element if using history feature |
| (str, str) or str | button_color | Color of the button (text, background) |
| str | background_color | background color of the entire window |
| str | text_color | color of the text |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str | initial_folder | location in filesystem to begin browsing |
| str or bytes | image | Image to include at the top of the popup window |
| str | files_delimiter | String to place between files when multiple files are selected. Normally a ; |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| bool | history | If True then enable a "history" feature that will display previous entries used. Uses settings filename provided or default if none provided |
| str | history_setting_filename | Filename to use for the User Settings. Will store list of previous entries in this settings file |
| str or None | **RETURN** | string representing the file(s) chosen, None if cancelled or window closed with X
Display popup with text entry field and browse button so that a folder can be chosen.
```
popup_get_folder(message,
title = None,
default_path = "",
no_window = False,
size = (None, None),
button_color = None,
background_color = None,
text_color = None,
icon = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
initial_folder = None,
image = None,
modal = True,
history = False,
history_setting_filename = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | message | message displayed to user |
| str | title | Window title |
| str | default_path | path to display to user as starting point (filled into the input field) |
| bool | no_window | if True, no PySimpleGUI window will be shown. Instead just the tkinter dialog is shown |
| (int, int) | size | (width, height) of the InputText Element |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str | initial_folder | location in filesystem to begin browsing |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| bool | history | If True then enable a "history" feature that will display previous entries used. Uses settings filename provided or default if none provided |
| str | history_setting_filename | Filename to use for the User Settings. Will store list of previous entries in this settings file |
| str or None | **RETURN** | string representing the path chosen, None if cancelled or window closed with X
Display Popup with text entry field. Returns the text entered or None if closed / cancelled
```
popup_get_text(message,
title = None,
default_text = "",
password_char = "",
size = (None, None),
button_color = None,
background_color = None,
text_color = None,
icon = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | message | message displayed to user |
| str | title | Window title |
| str | default_text | default value to put into input area |
| str | password_char | character to be shown instead of actually typed characters |
| (int, int) | size | (width, height) of the InputText Element |
| (str, str) or str | button_color | Color of the button (text, background) |
| str | background_color | background color of the entire window |
| str | text_color | color of the message text |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True can click and drag anywhere in the window to move the window |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | (x,y) Location on screen to display the upper left corner of window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None | **RETURN** | Text entered or None if window was closed or cancel button clicked
Makes a "popup menu"
This type of menu is what you get when a normal menu or a right click menu is torn off
The settings for the menu are obtained from the window parameter's Window
```
popup_menu(window,
element,
menu_def,
title = None,
location = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Window | window | The window associated with the popup menu. The theme and right click menu settings for this window will be used |
| Element | element | An element in your window to associate the menu to. It can be any element |
| List[List[ List[str] or str ]] | menu_def | A menu definition. This will be the same format as used for Right Click Menus1 |
| str | title | The title that will be shown on the torn off menu window. Defaults to window titlr |
| (int, int) or (None, None) | location | The location on the screen to place the window |
Show a Popup but without any buttons
```
popup_no_buttons(args=*<1 or N object>,
title = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | If True then will immediately return from the function without waiting for the user's input. (Default = False) |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True, than can grab anywhere to move the window (Default = False) |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Display a Popup without a titlebar. Enables grab anywhere so you can move it
```
popup_no_titlebar(args=*<1 or N object>,
title = None,
button_type = 0,
button_color = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
grab_anywhere = True,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| int | button_type | Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Show Popup window and immediately return (does not block)
```
popup_non_blocking(args=*<1 or N object>,
title = None,
button_type = 0,
button_color = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = True,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| int | button_type | Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = False |
| str or None | **RETURN** | Reason for popup closing
Displays a "notification window", usually in the bottom right corner of your display. Has an icon, a title, and a message. It is more like a "toaster" window than the normal popups.
The window will slowly fade in and out if desired. Clicking on the window will cause it to move through the end the current "phase". For example, if the window was fading in and it was clicked, then it would immediately stop fading in and instead be fully visible. It's a way for the user to quickly dismiss the window.
The return code specifies why the call is returning (e.g. did the user click the message to dismiss it)
```
popup_notify(args=*<1 or N object>,
title = "",
icon = ...,
display_duration_in_ms = 3000,
fade_in_duration = 1000,
alpha = 0.9,
location = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | title | Text to be shown at the top of the window in a larger font |
| str | message | Text message that makes up the majority of the window |
| bytes or str | icon | A base64 encoded PNG/GIF image or PNG/GIF filename that will be displayed in the window |
| int | display_duration_in_ms | Number of milliseconds to show the window |
| int | fade_in_duration | Number of milliseconds to fade window in and out |
| float | alpha | Alpha channel. 0 - invisible 1 - fully visible |
| (int, int) | location | Location on the screen to display the window |
| (int) | **RETURN** | reason for returning
Display Popup with OK button only
```
popup_ok(args=*<1 or N object>,
title = None,
button_color = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Display popup with OK and Cancel buttons
```
popup_ok_cancel(args=*<1 or N object>,
title = None,
button_color = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = ...,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| "OK" or "Cancel" or None | **RETURN** | clicked button
Show Popup box that doesn't block and closes itself
```
popup_quick(args=*<1 or N object>,
title = None,
button_type = 0,
button_color = None,
background_color = None,
text_color = None,
auto_close = True,
auto_close_duration = 2,
non_blocking = True,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| int | button_type | Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = False |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Show Popup window with no titlebar, doesn't block, and auto closes itself.
```
popup_quick_message(args=*<1 or N object>,
title = None,
button_type = 5,
button_color = None,
background_color = None,
text_color = None,
auto_close = True,
auto_close_duration = 2,
non_blocking = True,
icon = None,
line_width = None,
font = None,
no_titlebar = True,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| int | button_type | Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | keep_on_top | If True the window will remain above all current windows |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = False |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Show a scrolled Popup window containing the user's text that was supplied. Use with as many items to print as you
want, just like a print statement.
```
popup_scrolled(args=*<1 or N object>,
title = None,
button_color = None,
background_color = None,
text_color = None,
yes_no = False,
auto_close = False,
auto_close_duration = None,
size = (None, None),
location = (None, None),
non_blocking = False,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
font = None,
image = None,
icon = None,
modal = True,
no_sizegrip = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | yes_no | If True, displays Yes and No buttons instead of Ok |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) | location | Location on the screen to place the upper left corner of the window |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True, than can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str or bytes | image | Image to include at the top of the popup window |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| bool | no_sizegrip | If True no Sizegrip will be shown when there is no titlebar. It's only shown if there is no titlebar |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Display Popup with Yes and No buttons
```
popup_yes_no(args=*<1 or N object>,
title = None,
button_color = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| "Yes" or "No" or None | **RETURN** | clicked button
### Popup Alias - Same as popup_scrolled
Show a scrolled Popup window containing the user's text that was supplied. Use with as many items to print as you
want, just like a print statement.
```
sprint(args=*<1 or N object>,
title = None,
button_color = None,
background_color = None,
text_color = None,
yes_no = False,
auto_close = False,
auto_close_duration = None,
size = (None, None),
location = (None, None),
non_blocking = False,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
font = None,
image = None,
icon = None,
modal = True,
no_sizegrip = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | yes_no | If True, displays Yes and No buttons instead of Ok |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) | location | Location on the screen to place the upper left corner of the window |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True, than can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str or bytes | image | Image to include at the top of the popup window |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| bool | no_sizegrip | If True no Sizegrip will be shown when there is no titlebar. It's only shown if there is no titlebar |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Show a scrolled Popup window containing the user's text that was supplied. Use with as many items to print as you
want, just like a print statement.
```
ScrolledTextBox(args=*<1 or N object>,
title = None,
button_color = None,
background_color = None,
text_color = None,
yes_no = False,
auto_close = False,
auto_close_duration = None,
size = (None, None),
location = (None, None),
non_blocking = False,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
font = None,
image = None,
icon = None,
modal = True,
no_sizegrip = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | yes_no | If True, displays Yes and No buttons instead of Ok |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) | location | Location on the screen to place the upper left corner of the window |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True, than can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str or bytes | image | Image to include at the top of the popup window |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| bool | no_sizegrip | If True no Sizegrip will be shown when there is no titlebar. It's only shown if there is no titlebar |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
## Popup Not PEP8 Compliant names
*** You should not use these function names! ***
These versions of the popup functions are here only for backwards compatibility. Instead use the popup functions that have snake_case rather than CamelCase.
Popup - Display a popup Window with as many parms as you wish to include. This is the GUI equivalent of the
"print" statement. It's also great for "pausing" your program's flow until the user can read some error messages.
```
Popup(args=*<1 or N object>,
title = None,
button_color = None,
background_color = None,
text_color = None,
button_type = 0,
auto_close = False,
auto_close_duration = None,
custom_text = (None, None),
non_blocking = False,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
any_key_closes = False,
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of your arguments. Load up the call with stuff to see! |
| str | title | Optional title for the window. If none provided, the first arg will be used instead. |
| (str, str) or None | button_color | Color of the buttons shown (text color, button color) |
| str | background_color | Window's background color |
| str | text_color | text color |
| int | button_type | NOT USER SET! Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). There are many Popup functions and they call Popup, changing this parameter to get the desired effect. |
| bool | auto_close | If True the window will automatically close |
| int | auto_close_duration | time in seconds to keep window open before closing it automatically |
| (str, str) or str | custom_text | A string or pair of strings that contain the text to display on the buttons |
| bool | non_blocking | If True then will immediately return from the function without waiting for the user's input. |
| str or bytes | icon | icon to display on the window. Same format as a Window call |
| int | line_width | Width of lines in characters. Defaults to MESSAGE_BOX_LINE_WIDTH |
| str or Tuple[font_name, size, modifiers] | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True will not show the frame around the window and the titlebar across the top |
| bool | grab_anywhere | If True can grab anywhere to move the window. If no_titlebar is True, grab_anywhere should likely be enabled too |
| (int, int) | location | Location on screen to display the top left corner of window. Defaults to window centered on screen |
| bool | keep_on_top | If True the window will remain above all current windows |
| bool | any_key_closes | If True then will turn on return_keyboard_events for the window which will cause window to close as soon as any key is pressed. Normally the return key only will close the window. Default is false. |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Show animation one frame at a time. This function has its own internal clocking meaning you can call it at any frequency
and the rate the frames of video is shown remains constant. Maybe your frames update every 30 ms but your
event loop is running every 10 ms. You don't have to worry about delaying, just call it every time through the
loop.
```
PopupAnimated(image_source,
message = None,
background_color = None,
text_color = None,
font = None,
no_titlebar = True,
grab_anywhere = True,
keep_on_top = True,
location = (None, None),
alpha_channel = None,
time_between_frames = 0,
transparent_color = None,
title = "",
icon = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str or bytes or None | image_source | Either a filename or a base64 string. Use None to close the window. |
| str | message | An optional message to be shown with the animation |
| str | background_color | color of background |
| str | text_color | color of the text |
| str or tuple | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True then the titlebar and window frame will not be shown |
| bool | grab_anywhere | If True then you can move the window just clicking anywhere on window, hold and drag |
| bool | keep_on_top | If True then Window will remain on top of all other windows currently shownn |
| (int, int) | location | (x,y) location on the screen to place the top left corner of your window. Default is to center on screen |
| float | alpha_channel | Window transparency 0 = invisible 1 = completely visible. Values between are see through |
| int | time_between_frames | Amount of time in milliseconds between each frame |
| str | transparent_color | This color will be completely see-through in your window. Can even click through |
| str | title | Title that will be shown on the window |
| str or bytes | icon | Same as Window icon parameter. Can be either a filename or Base64 byte string. For Windows if filename, it MUST be ICO format. For Linux, must NOT be ICO |
| bool | **RETURN** | True if the window updated OK. False if the window was closed
Display a Popup without a titlebar. Enables grab anywhere so you can move it
```
PopupAnnoying(args=*<1 or N object>,
title = None,
button_type = 0,
button_color = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
grab_anywhere = True,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| int | button_type | Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Popup that closes itself after some time period
```
PopupAutoClose(args=*<1 or N object>,
title = None,
button_type = 0,
button_color = None,
background_color = None,
text_color = None,
auto_close = True,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| int | button_type | Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Display Popup with "cancelled" button text
```
PopupCancel(args=*<1 or N object>,
title = None,
button_color = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Popup with colored button and 'Error' as button text
```
PopupError(args=*<1 or N object>,
title = None,
button_color = (None, None),
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Display popup window with text entry field and browse button so that a file can be chosen by user.
```
PopupGetFile(message,
title = None,
default_path = "",
default_extension = "",
save_as = False,
multiple_files = False,
file_types = (('ALL Files', '*.*'),),
no_window = False,
size = (None, None),
button_color = None,
background_color = None,
text_color = None,
icon = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
initial_folder = None,
image = None,
files_delimiter = ";",
modal = True,
history = False,
history_setting_filename = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | message | message displayed to user |
| str | title | Window title |
| str | default_path | path to display to user as starting point (filled into the input field) |
| str | default_extension | If no extension entered by user, add this to filename (only used in saveas dialogs) |
| bool | save_as | if True, the "save as" dialog is shown which will verify before overwriting |
| bool | multiple_files | if True, then allows multiple files to be selected that are returned with ';' between each filename |
| Tuple[Tuple[str,str]] | file_types | List of extensions to show using wildcards. All files (the default) = (("ALL Files", "*.*"),) |
| bool | no_window | if True, no PySimpleGUI window will be shown. Instead just the tkinter dialog is shown |
| (int, int) | size | (width, height) of the InputText Element or Combo element if using history feature |
| (str, str) or str | button_color | Color of the button (text, background) |
| str | background_color | background color of the entire window |
| str | text_color | color of the text |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str | initial_folder | location in filesystem to begin browsing |
| str or bytes | image | Image to include at the top of the popup window |
| str | files_delimiter | String to place between files when multiple files are selected. Normally a ; |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| bool | history | If True then enable a "history" feature that will display previous entries used. Uses settings filename provided or default if none provided |
| str | history_setting_filename | Filename to use for the User Settings. Will store list of previous entries in this settings file |
| str or None | **RETURN** | string representing the file(s) chosen, None if cancelled or window closed with X
Display popup with text entry field and browse button so that a folder can be chosen.
```
PopupGetFolder(message,
title = None,
default_path = "",
no_window = False,
size = (None, None),
button_color = None,
background_color = None,
text_color = None,
icon = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
initial_folder = None,
image = None,
modal = True,
history = False,
history_setting_filename = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | message | message displayed to user |
| str | title | Window title |
| str | default_path | path to display to user as starting point (filled into the input field) |
| bool | no_window | if True, no PySimpleGUI window will be shown. Instead just the tkinter dialog is shown |
| (int, int) | size | (width, height) of the InputText Element |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str | initial_folder | location in filesystem to begin browsing |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| bool | history | If True then enable a "history" feature that will display previous entries used. Uses settings filename provided or default if none provided |
| str | history_setting_filename | Filename to use for the User Settings. Will store list of previous entries in this settings file |
| str or None | **RETURN** | string representing the path chosen, None if cancelled or window closed with X
Display Popup with text entry field. Returns the text entered or None if closed / cancelled
```
PopupGetText(message,
title = None,
default_text = "",
password_char = "",
size = (None, None),
button_color = None,
background_color = None,
text_color = None,
icon = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | message | message displayed to user |
| str | title | Window title |
| str | default_text | default value to put into input area |
| str | password_char | character to be shown instead of actually typed characters |
| (int, int) | size | (width, height) of the InputText Element |
| (str, str) or str | button_color | Color of the button (text, background) |
| str | background_color | background color of the entire window |
| str | text_color | color of the message text |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True can click and drag anywhere in the window to move the window |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | (x,y) Location on screen to display the upper left corner of window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None | **RETURN** | Text entered or None if window was closed or cancel button clicked
Display a Popup without a titlebar. Enables grab anywhere so you can move it
```
PopupNoBorder(args=*<1 or N object>,
title = None,
button_type = 0,
button_color = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
grab_anywhere = True,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| int | button_type | Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Show a Popup but without any buttons
```
PopupNoButtons(args=*<1 or N object>,
title = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | If True then will immediately return from the function without waiting for the user's input. (Default = False) |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True, than can grab anywhere to move the window (Default = False) |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Display a Popup without a titlebar. Enables grab anywhere so you can move it
```
PopupNoFrame(args=*<1 or N object>,
title = None,
button_type = 0,
button_color = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
grab_anywhere = True,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| int | button_type | Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Display a Popup without a titlebar. Enables grab anywhere so you can move it
```
PopupNoTitlebar(args=*<1 or N object>,
title = None,
button_type = 0,
button_color = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
grab_anywhere = True,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| int | button_type | Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Show Popup window and immediately return (does not block)
```
PopupNonBlocking(args=*<1 or N object>,
title = None,
button_type = 0,
button_color = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = True,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| int | button_type | Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = False |
| str or None | **RETURN** | Reason for popup closing
Display Popup with OK button only
```
PopupOK(args=*<1 or N object>,
title = None,
button_color = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Display popup with OK and Cancel buttons
```
PopupOKCancel(args=*<1 or N object>,
title = None,
button_color = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = ...,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| "OK" or "Cancel" or None | **RETURN** | clicked button
Show Popup box that doesn't block and closes itself
```
PopupQuick(args=*<1 or N object>,
title = None,
button_type = 0,
button_color = None,
background_color = None,
text_color = None,
auto_close = True,
auto_close_duration = 2,
non_blocking = True,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| int | button_type | Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = False |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Show Popup window with no titlebar, doesn't block, and auto closes itself.
```
PopupQuickMessage(args=*<1 or N object>,
title = None,
button_type = 5,
button_color = None,
background_color = None,
text_color = None,
auto_close = True,
auto_close_duration = 2,
non_blocking = True,
icon = None,
line_width = None,
font = None,
no_titlebar = True,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| int | button_type | Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | keep_on_top | If True the window will remain above all current windows |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = False |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Show a scrolled Popup window containing the user's text that was supplied. Use with as many items to print as you
want, just like a print statement.
```
PopupScrolled(args=*<1 or N object>,
title = None,
button_color = None,
background_color = None,
text_color = None,
yes_no = False,
auto_close = False,
auto_close_duration = None,
size = (None, None),
location = (None, None),
non_blocking = False,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
font = None,
image = None,
icon = None,
modal = True,
no_sizegrip = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| (str, str) or str | button_color | button color (foreground, background) |
| bool | yes_no | If True, displays Yes and No buttons instead of Ok |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| (int, int) | size | (w,h) w=characters-wide, h=rows-high |
| (int, int) | location | Location on the screen to place the upper left corner of the window |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True, than can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| str or bytes | image | Image to include at the top of the popup window |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| bool | no_sizegrip | If True no Sizegrip will be shown when there is no titlebar. It's only shown if there is no titlebar |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Popup that closes itself after some time period
```
PopupTimed(args=*<1 or N object>,
title = None,
button_type = 0,
button_color = None,
background_color = None,
text_color = None,
auto_close = True,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| int | button_type | Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| str or None or TIMEOUT_KEY | **RETURN** | Returns text of the button that was pressed. None will be returned if user closed window with X
Display Popup with Yes and No buttons
```
PopupYesNo(args=*<1 or N object>,
title = None,
button_color = None,
background_color = None,
text_color = None,
auto_close = False,
auto_close_duration = None,
non_blocking = False,
icon = None,
line_width = None,
font = None,
no_titlebar = False,
grab_anywhere = False,
keep_on_top = False,
location = (None, None),
image = None,
modal = True)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | *args | Variable number of items to display |
| str | title | Title to display in the window. |
| (str, str) or str | button_color | button color (foreground, background) |
| str | background_color | color of background |
| str | text_color | color of the text |
| bool | auto_close | if True window will close itself |
| int or float | auto_close_duration | Older versions only accept int. Time in seconds until window will close |
| bool | non_blocking | if True the call will immediately return rather than waiting on user input |
| bytes or str | icon | filename or base64 string to be used for the window's icon |
| int | line_width | Width of lines in characters |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| bool | no_titlebar | If True no titlebar will be shown |
| bool | grab_anywhere | If True: can grab anywhere to move the window (Default = False) |
| bool | keep_on_top | If True the window will remain above all current windows |
| (int, int) | location | Location of upper left corner of the window |
| str or bytes | image | Image to include at the top of the popup window |
| bool | modal | If True then makes the popup will behave like a Modal window... all other windows are non-operational until this one is closed. Default = True |
| "Yes" or "No" or None | **RETURN** | clicked button
## PEP8 Function Bindings
## Display Objects In a Friendly Way
These functions will return an object as a string that shows each of the object's member variables. They're nice to use if you want to print any Python object, not just PySimpleGUI ones.
Dumps an Object's values as a formatted string. Very nicely done. Great way to display an object's member variables in human form
```
obj_to_string(obj, extra = " ")
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | obj | The object to display |
| str | extra | extra stuff (Default value = ' ') |
| (str) | **RETURN** | Formatted output of the object's values
Dumps an Object's values as a formatted string. Very nicely done. Great way to display an object's member variables in human form
Returns only the top-most object's variables instead of drilling down to dispolay more
```
obj_to_string_single_obj(obj)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | obj | The object to display |
| (str) | **RETURN** | Formatted output of the object's values
## The Main Program - Test Harness, Global Settings, Debug Information, Upgrade from GitHub
A convention that PySimpleGUI uses is that standalone entry points start with "main_". These calls are essentially a mini-program within the PySimpleGUI.py file.
Used to get SDK help, test the installation, get information about the versions, upgrade from GitHub.
You can call main() from your code and then access these other features such as the global settings. You can also directly call these functions.
The PySimpleGUI "Test Harness". This is meant to be a super-quick test of the Elements.
```
main()
```
Collect up and display the data needed to file GitHub issues.
This function will place the information on the clipboard.
You MUST paste the information from the clipboard prior to existing your application (except on Windows).
```
main_get_debug_data(suppress_popup = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | suppress_popup | If True no popup window will be shown. The string will be only returned, not displayed |
Window to set settings that will be used across all PySimpleGUI programs that choose to use them.
Use set_options to set the path to the folder for all PySimpleGUI settings.
```
main_global_pysimplegui_settings()
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (bool) | **RETURN** | True if settings were changed
Display a window that will display the docstrings for each PySimpleGUI Element and the Window object
```
main_sdk_help()
```
The PySimpleGUI "Test Harness". This is meant to be a super-quick test of the Elements.
```
test()
```
## Debugger
Shows the smaller "popout" window. Default location is the upper right corner of your screen
```
show_debugger_popout_window(location = (None, None), args=*<1 or N object>)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | location | Locations (x,y) on the screen to place upper left corner of the window |
| None | **RETURN** | None
Shows the large main debugger window
```
show_debugger_window(location = (None, None), args=*<1 or N object>)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int, int) | location | Locations (x,y) on the screen to place upper left corner of the window |
| None | **RETURN** | None
## Themes
Sets / Gets the current Theme. If none is specified then returns the current theme.
This call replaces the ChangeLookAndFeel / change_look_and_feel call which only sets the theme.
```
theme(new_theme = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | new_theme | the new theme name to use |
| (str) | **RETURN** | the currently selected theme
Add a new theme to the dictionary of themes
```
theme_add_new(new_theme_name, new_theme_dict)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | new_theme_name | text to display in element |
| dict | new_theme_dict | text to display in element |
Sets/Returns the background color currently in use
Used for Windows and containers (Column, Frame, Tab) and tables
```
theme_background_color(color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | color | new background color to use (optional) |
| (str) | **RETURN** | color string of the background color currently in use
Sets/Returns the border width currently in use
Used by non ttk elements at the moment
```
theme_border_width(border_width = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int) | **RETURN** | border width currently in use
Sets/Returns the button color currently in use
```
theme_button_color(color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str, str) | **RETURN** | (str, str) - TUPLE with color strings of the button color currently in use (button text color, button background color)
Sets/Returns the background color currently in use for all elements except containers
```
theme_element_background_color(color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str) | **RETURN** | (str) - color string of the element background color currently in use
Sets/Returns the text color used by elements that have text as part of their display (Tables, Trees and Sliders)
```
theme_element_text_color(color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str) | **RETURN** | color string currently in use
Sets / Gets the global PySimpleGUI Theme. If none is specified then returns the global theme from user settings
```
theme_global(new_theme = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | new_theme | the new theme name to use |
| (str) | **RETURN** | the currently selected theme
Sets/Returns the input element background color currently in use
```
theme_input_background_color(color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str) | **RETURN** | (str) - color string of the input element background color currently in use
Sets/Returns the input element entry color (not the text but the thing that's displaying the text)
```
theme_input_text_color(color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str) | **RETURN** | (str) - color string of the input element color currently in use
Returns a sorted list of the currently available color themes
```
theme_list()
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[str] | **RETURN** | A sorted list of the currently available color themes
Displays a "Quick Reference Window" showing all of the different Look and Feel settings that are available.
They are sorted alphabetically. The legacy color names are mixed in, but otherwise they are sorted into Dark and Light halves
```
theme_previewer(columns = 12,
scrollable = False,
scroll_area_size = (None, None),
search_string = None,
location = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | columns | The number of themes to display per row |
| bool | scrollable | If True then scrollbars will be added |
| (int, int) | scroll_area_size | Size of the scrollable area (The Column Element used to make scrollable) |
| str | search_string | If specified then only themes containing this string will be shown |
| (int, int) | location | Location on the screen to place the window. Defaults to the center like all windows |
Display themes in a window as color swatches.
Click on a color swatch to see the hex value printed on the console.
If you hover over a color or right click it you'll also see the hext value.
```
theme_previewer_swatches()
```
Sets/Returns the progress meter border width currently in use
```
theme_progress_bar_border_width(border_width = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int) | **RETURN** | border width currently in use for progress meters
Sets/Returns the progress bar colors by the current color theme
```
theme_progress_bar_color(color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str, str) | **RETURN** | (str, str) - TUPLE with color strings of the ProgressBar color currently in use(button text color, button background color)
Sets/Returns the slider border width currently in use
```
theme_slider_border_width(border_width = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (int) | **RETURN** | border width currently in use for sliders
Sets/Returns the slider color (used for sliders)
```
theme_slider_color(color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str) | **RETURN** | color string of the slider color currently in use
Sets/Returns the text color currently in use
```
theme_text_color(color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str) | **RETURN** | (str) - color string of the text color currently in use
Sets/Returns the background color for text elements
```
theme_text_element_background_color(color = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str) | **RETURN** | (str) - color string of the text background color currently in use
## Platform Checks
These are simple functions you can use that return a boolean True if sys.platform matches the platform. Saves you the trouble of importing sys and then looking up the values for sys.platform.
Determines the OS is Linux by using sys.platform
Returns True if Linux
```
running_linux()
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (bool) | **RETURN** | True if sys.platform indicates running Linux
Determines the OS is Mac by using sys.platform
Returns True if Mac
```
running_mac()
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (bool) | **RETURN** | True if sys.platform indicates running Mac
A special case for Trinket. Checks both the OS and the number of environment variables
Currently, Trinket only has ONE environment variable. This fact is used to figure out if Trinket is being used.
Returns True if "Trinket" (in theory)
```
running_trinket()
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (bool) | **RETURN** | True if sys.platform indicates Linux and the number of environment variables is 1
Determines the OS is Windows by using sys.platform
Returns True if Windows
```
running_windows()
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (bool) | **RETURN** | True if sys.platform indicates running Windows
## User Settings
In addition to user settings files, there is also a global PySimpleGUI settings file.
You can directly access the global settings through the UserSettings object: `pysimplegui_user_settings`
Returns the current settings dictionary. If you've not setup the filename for the
settings, a default one will be used and then read.
```
user_settings()
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (dict) | **RETURN** | The current settings dictionary
Deletes an individual entry. If no filename has been specified up to this point,
then a default filename will be used.
After value has been deleted, the settings file is written to disk.
```
user_settings_delete_entry(key)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | key | Setting to be saved. Can be any valid dictionary key type (hashable) |
Deltes the filename and path for your settings file. Either paramter can be optional.
If you don't choose a path, one is provided for you that is OS specific
Windows path default = users/name/AppData/Local/PySimpleGUI/settings.
If you don't choose a filename, your application's filename + '.json' will be used
Also sets your current dictionary to a blank one.
```
user_settings_delete_filename(filename = None, path = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | filename | The name of the file to use. Can be a full path and filename or just filename |
| str | path | The folder that the settings file will be stored in. Do not include the filename. |
Determines if a settings file exists. If so a boolean True is returned.
If either a filename or a path is not included, then the appropriate default
will be used.
```
user_settings_file_exists(filename = None, path = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | filename | Filename to check |
| str | path | Path to the file. Defaults to a specific folder depending on the operating system |
| (bool) | **RETURN** | True if the file exists
Sets the filename and path for your settings file. Either paramter can be optional.
If you don't choose a path, one is provided for you that is OS specific
Windows path default = users/name/AppData/Local/PySimpleGUI/settings.
If you don't choose a filename, your application's filename + '.json' will be used.
Normally the filename and path are split in the user_settings calls. However for this call they
can be combined so that the filename contains both the path and filename.
```
user_settings_filename(filename = None, path = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | filename | The name of the file to use. Can be a full path and filename or just filename |
| str | path | The folder that the settings file will be stored in. Do not include the filename. |
| (str) | **RETURN** | The full pathname of the settings file that has both the path and filename combined.
Returns the value of a specified setting. If the setting is not found in the settings dictionary, then
the user specified default value will be returned. It no default is specified and nothing is found, then
None is returned. If the key isn't in the dictionary, then it will be added and the settings file saved.
If no filename has been specified up to this point, then a default filename will be assigned and used.
The settings are SAVED prior to returning.
```
user_settings_get_entry(key, default = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | key | Key used to lookup the setting in the settings dictionary |
| Any | default | Value to use should the key not be found in the dictionary |
| (Any) | **RETURN** | Value of specified settings
Specifies the path and filename to use for the settings and reads the contents of the file.
The filename can be a full filename including a path, or the path can be specified separately.
If no filename is specified, then the caller's filename will be used with the extension ".json"
```
user_settings_load(filename = None, path = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | filename | Filename to load settings from (and save to in the future) |
| str | path | Path to the file. Defaults to a specific folder depending on the operating system |
| (dict) | **RETURN** | The settings dictionary (i.e. all settings)
Saves the current settings dictionary. If a filename or path is specified in the call, then it will override any
previously specitfied filename to create a new settings file. The settings dictionary is then saved to the newly defined file.
```
user_settings_save(filename = None, path = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | filename | The fFilename to save to. Can specify a path or just the filename. If no filename specified, then the caller's filename will be used. |
| str | path | The (optional) path to use to save the file. |
| (str) | **RETURN** | The full path and filename used to save the settings
Sets an individual setting to the specified value. If no filename has been specified up to this point,
then a default filename will be used.
After value has been modified, the settings file is written to disk.
```
user_settings_set_entry(key, value)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Any | key | Setting to be saved. Can be any valid dictionary key type |
| Any | value | Value to save as the setting's value. Can be anything |
Used to control the display of error messages. By default, error messages are displayed to stdout.
```
user_settings_silent_on_error(silent_on_error = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bool | silent_on_error | If True then all error messages are silenced (not displayed on the console) |
Writes a specified dictionary to the currently defined settings filename.
```
user_settings_write_new_dictionary(settings_dict)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| dict | settings_dict | The dictionary to be written to the currently defined settings file |
## Exec APIs
These API calls are used to launch subprocesses.
Runs the specified command as a subprocess.
By default the call is non-blocking.
The function will immediately return without waiting for the process to complete running. You can use the returned Popen object to communicate with the subprocess and get the results.
Returns a subprocess Popen object.
```
execute_command_subprocess(command,
args=*<1 or N object>,
wait = False,
cwd = None,
pipe_output = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | command | Filename to load settings from (and save to in the future) |
| Any | *args | Variable number of arguments that are passed to the program being started as command line parms |
| bool | wait | If True then wait for the subprocess to finish |
| str | cwd | Working directory to use when executing the subprocess |
| bool | pipe_output | If True then output from the subprocess will be piped. You MUST empty the pipe by calling execute_get_results or your subprocess will block until no longer full |
| (subprocess.Popen) | **RETURN** | Popen object
Runs the editor that was configured in the global settings and opens the file to a specific line number.
Two global settings keys are used.
'-editor program-' the command line used to startup your editor. It's set
in the global settings window or by directly manipulating the PySimpleGUI settings object
'-editor format string-' a string containing 3 "tokens" that describes the command that is executed
```
execute_editor(file_to_edit, line_number = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | file_to_edit | the full path to the file to edit |
| int | line_number | optional line number to place the cursor |
| (subprocess.Popen) or None | **RETURN** | Popen object
The global settings has a setting called - "-explorer program-"
It defines the program to run when this function is called.
The optional folder paramter specified which path should be opened.
```
execute_file_explorer(folder_to_open = "")
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | folder_to_open | The path to open in the explorer program |
| (subprocess.Popen) or None | **RETURN** | Popen object
Returns the first filename found in a traceback that is not the nsame of this file (__file__)
Used internally with the debugger for example.
```
execute_find_callers_filename()
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | **RETURN** | filename of the caller, asseumed to be the first non PySimpleGUI file
Get the text results of a previously executed execute call
Returns a tuple of the strings (stdout, stderr)
```
execute_get_results(subprocess_id, timeout = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (subprocess.Popen) | subprocess_id | a Popen subprocess ID returned from a previous execute call |
| (None or float) | timeout | Time in fractions of a second to wait. Returns '','' if timeout. Default of None means wait forever |
Executes a Python file.
The interpreter to use is chosen based on this priority order:
1. interpreter_command paramter
2. global setting "-python command-"
3. the interpreter running running PySimpleGUI
```
execute_py_file(pyfile,
parms = None,
cwd = None,
interpreter_command = None,
wait = False,
pipe_output = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | pyfile | the file to run |
| str | parms | parameters to pass on the command line |
| str | cwd | the working directory to use |
| str | interpreter_command | the command used to invoke the Python interpreter |
| bool | wait | the working directory to use |
| bool | pipe_output | If True then output from the subprocess will be piped. You MUST empty the pipe by calling execute_get_results or your subprocess will block until no longer full |
| (subprocess.Popen) or None | **RETURN** | Popen object
Returns True is the subprocess ID provided is for a process that is still running
```
execute_subprocess_still_running(subprocess_id)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (subprocess.Popen) | subprocess_id | ID previously returned from Exec API calls that indicate this value is returned |
| bool | **RETURN** | True if the subproces is running
## Clipboard APIs
Note that this clipboard uses tkinter's clipboard. There is a known limitation that your application needs to remain running until you've pasted the contents. Managed to get around this limitation so that the clipboard stays set after you exit your application, but only have it working for Windows systems.
Gets the clipboard current value.
```
clipboard_get()
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| (str) | **RETURN** | The current value of the clipboard
Sets the clipboard to a specific value.
IMPORTANT NOTE - Your PySimpleGUI application needs to remain running until you've pasted
your clipboard. This is a tkinter limitation. A workaround was found for Windows, but you still
need to stay running for Linux systems.
```
clipboard_set(new_value)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | new_value | value to set the clipboard to. Will be converted to a string |
## Misc
Fills a window with values provided in a values dictionary { element_key : new_value }
```
fill_form_with_values(window, values_dict)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Window | window | The window object to fill |
| (Dict[Any, Any]) | values_dict | A dictionary with element keys as key and value is values parm for Update call |
| None | **RETURN** | None
Fills a window with values provided in a values dictionary { element_key : new_value }
```
FillFormWithValues(window, values_dict)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Window | window | The window object to fill |
| (Dict[Any, Any]) | values_dict | A dictionary with element keys as key and value is values parm for Update call |
| None | **RETURN** | None
## Layout Helper Funcs
Pin's an element provided into a layout so that when it's made invisible and visible again, it will
be in the correct place. Otherwise it will be placed at the end of its containing window/column.
```
pin(elem,
vertical_alignment = None,
shrink = True,
expand_x = None,
expand_y = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Element | elem | the element to put into the layout |
| str or None | vertical_alignment | Aligns elements vertically. 'top', 'center', 'bottom'. Can be shortened to 't', 'c', 'b' |
| bool | shrink | If True, then the space will shrink down to a single pixel when hidden. False leaves the area large and blank |
| bool | expand_x | If True/False the value will be passed to the Column Elements used to make this feature |
| bool | expand_y | If True/False the value will be passed to the Column Elements used to make this feature |
| Column | **RETURN** | A column element containing the provided element
Align an element or a row of elements to the bottom of the row that contains it
```
vbottom(elem_or_row,
expand_x = None,
expand_y = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Element or List[Element] or Tuple[Element] | elem_or_row | the element or row of elements |
| bool | expand_x | If True/False the value will be passed to the Column Elements used to make this feature |
| bool | expand_y | If True/False the value will be passed to the Column Elements used to make this feature |
| Column or List[Column] | **RETURN** | A column element containing the provided element aligned to the bottom or list of elements (a row)
Align an element or a row of elements to the center of the row that contains it
```
vcenter(elem_or_row,
expand_x = None,
expand_y = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Element or List[Element] or Tuple[Element] | elem_or_row | the element or row of elements |
| bool | expand_x | If True/False the value will be passed to the Column Elements used to make this feature |
| bool | expand_y | If True/False the value will be passed to the Column Elements used to make this feature |
| Column or List[Column] | **RETURN** | A column element containing the provided element aligned to the center or list of elements (a row)
Align an element or a row of elements to the top of the row that contains it
```
vtop(elem_or_row,
expand_x = None,
expand_y = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| Element or List[Element] or Tuple[Element] | elem_or_row | the element or row of elements |
| bool | expand_x | If True/False the value will be passed to the Column Elements used to make this feature |
| bool | expand_y | If True/False the value will be passed to the Column Elements used to make this feature |
| Column or List[Column] | **RETURN** | A column element containing the provided element aligned to the top or list of elements (a row)
## Configuration / Settings / Extensions
Sets the icon which will be used any time a window is created if an icon is not provided when the
window is created.
```
set_global_icon(icon)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bytes or str | icon | Either a Base64 byte string or a filename |
```
set_options(icon = None,
button_color = None,
element_size = (None, None),
button_element_size = (None, None),
margins = (None, None),
element_padding = (None, None),
auto_size_text = None,
auto_size_buttons = None,
font = None,
border_width = None,
slider_border_width = None,
slider_relief = None,
slider_orientation = None,
autoclose_time = None,
message_box_line_width = None,
progress_meter_border_depth = None,
progress_meter_style = None,
progress_meter_relief = None,
progress_meter_color = None,
progress_meter_size = None,
text_justification = None,
background_color = None,
element_background_color = None,
text_element_background_color = None,
input_elements_background_color = None,
input_text_color = None,
scrollbar_color = None,
text_color = None,
element_text_color = None,
debug_win_size = (None, None),
window_location = (None, None),
error_button_color = (None, None),
tooltip_time = None,
tooltip_font = None,
use_ttk_buttons = None,
ttk_theme = None,
suppress_error_popups = None,
suppress_raise_key_errors = None,
suppress_key_guessing = None,
enable_treeview_869_patch = None,
enable_mac_notitlebar_patch = None,
use_custom_titlebar = None,
titlebar_background_color = None,
titlebar_text_color = None,
titlebar_font = None,
titlebar_icon = None,
user_settings_path = None,
pysimplegui_settings_path = None,
pysimplegui_settings_filename = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bytes or str | icon | Can be either a filename or Base64 value. For Windows if filename, it MUST be ICO format. For Linux, must NOT be ICO. Most portable is to use a Base64 of a PNG file. This works universally across all OS's |
| (str, str) or str | button_color | Color of the button (text, background) |
| (int, int) | element_size | element size (width, height) in characters |
| (int, int) | button_element_size | Size of button |
| (int, int) | margins | (left/right, top/bottom) tkinter margins around outsize. Amount of pixels to leave inside the window's frame around the edges before your elements are shown. |
| (int, int or (int, int),(int,int)) | element_padding | Default amount of padding to put around elements in window (left/right, top/bottom) or ((left, right), (top, bottom)) |
| bool | auto_size_text | True if the Widget should be shrunk to exactly fit the number of chars to show |
| bool | auto_size_buttons | True if Buttons in this Window should be sized to exactly fit the text on this. |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| int | border_width | width of border around element |
| int | slider_border_width | Width of the border around sliders |
| str | slider_relief | Type of relief to use for sliders |
| ??? | slider_orientation | ??? |
| ??? | autoclose_time | ??? |
| ??? | message_box_line_width | ??? |
| ??? | progress_meter_border_depth | ??? |
| ??? | progress_meter_style | You can no longer set a progress bar style. All ttk styles must be the same for the window |
| ??? | progress_meter_relief | |
| ??? | progress_meter_color | ??? |
| ??? | progress_meter_size | ??? |
| 'left' or 'right' or 'center' | text_justification | Default text justification for all Text Elements in window |
| str | background_color | color of background |
| str | element_background_color | element background color |
| str | text_element_background_color | text element background color |
| str | input_elements_background_color | Default color to use for the background of input elements |
| str | input_text_color | Default color to use for the text for Input elements |
| str | scrollbar_color | Default color to use for the slider trough |
| str | text_color | color of the text |
| str | element_text_color | Default color to use for Text elements |
| (int, int) | debug_win_size | window size |
| (int, int) or None | window_location | Default location to place windows. Not setting will center windows on the display |
| ??? | error_button_color | (Default = (None)) |
| int | tooltip_time | time in milliseconds to wait before showing a tooltip. Default is 400ms |
| str or Tuple[str, int] or Tuple[str, int, str] | tooltip_font | font to use for all tooltips |
| bool | use_ttk_buttons | if True will cause all buttons to be ttk buttons |
| str | ttk_theme | Theme to use with ttk widgets. Choices (on Windows) include - 'default', 'winnative', 'clam', 'alt', 'classic', 'vista', 'xpnative' |
| bool | suppress_error_popups | If True then error popups will not be shown if generated internally to PySimpleGUI |
| bool | suppress_raise_key_errors | If True then key errors won't be raised (you'll still get popup error) |
| bool | suppress_key_guessing | If True then key errors won't try and find closest matches for you |
| bool | enable_treeview_869_patch | If True, then will use the treeview color patch for tk 8.6.9 |
| bool | enable_mac_notitlebar_patch | If True then Windows with no titlebar use an alternative technique when tkinter version < 8.6.10 |
| bool | use_custom_titlebar | If True then a custom titlebar is used instead of the normal system titlebar |
| str or None | titlebar_background_color | If custom titlebar indicated by use_custom_titlebar, then use this as background color |
| str or None | titlebar_text_color | If custom titlebar indicated by use_custom_titlebar, then use this as text color |
| (str or (str, int[, str]) or None) or None | titlebar_font | If custom titlebar indicated by use_custom_titlebar, then use this as title font |
| bytes or str | titlebar_icon | If custom titlebar indicated by use_custom_titlebar, then use this as the icon (file or base64 bytes) |
| str | user_settings_path | default path for user_settings API calls. Expanded with os.path.expanduser so can contain ~ to represent user |
| str | pysimplegui_settings_path | default path for the global PySimpleGUI user_settings |
| str | pysimplegui_settings_filename | default filename for the global PySimpleGUI user_settings |
| None | **RETURN** | None
### Non PEP8 versions
Sets the icon which will be used any time a window is created if an icon is not provided when the
window is created.
```
SetGlobalIcon(icon)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bytes or str | icon | Either a Base64 byte string or a filename |
```
SetOptions(icon = None,
button_color = None,
element_size = (None, None),
button_element_size = (None, None),
margins = (None, None),
element_padding = (None, None),
auto_size_text = None,
auto_size_buttons = None,
font = None,
border_width = None,
slider_border_width = None,
slider_relief = None,
slider_orientation = None,
autoclose_time = None,
message_box_line_width = None,
progress_meter_border_depth = None,
progress_meter_style = None,
progress_meter_relief = None,
progress_meter_color = None,
progress_meter_size = None,
text_justification = None,
background_color = None,
element_background_color = None,
text_element_background_color = None,
input_elements_background_color = None,
input_text_color = None,
scrollbar_color = None,
text_color = None,
element_text_color = None,
debug_win_size = (None, None),
window_location = (None, None),
error_button_color = (None, None),
tooltip_time = None,
tooltip_font = None,
use_ttk_buttons = None,
ttk_theme = None,
suppress_error_popups = None,
suppress_raise_key_errors = None,
suppress_key_guessing = None,
enable_treeview_869_patch = None,
enable_mac_notitlebar_patch = None,
use_custom_titlebar = None,
titlebar_background_color = None,
titlebar_text_color = None,
titlebar_font = None,
titlebar_icon = None,
user_settings_path = None,
pysimplegui_settings_path = None,
pysimplegui_settings_filename = None)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| bytes or str | icon | Can be either a filename or Base64 value. For Windows if filename, it MUST be ICO format. For Linux, must NOT be ICO. Most portable is to use a Base64 of a PNG file. This works universally across all OS's |
| (str, str) or str | button_color | Color of the button (text, background) |
| (int, int) | element_size | element size (width, height) in characters |
| (int, int) | button_element_size | Size of button |
| (int, int) | margins | (left/right, top/bottom) tkinter margins around outsize. Amount of pixels to leave inside the window's frame around the edges before your elements are shown. |
| (int, int or (int, int),(int,int)) | element_padding | Default amount of padding to put around elements in window (left/right, top/bottom) or ((left, right), (top, bottom)) |
| bool | auto_size_text | True if the Widget should be shrunk to exactly fit the number of chars to show |
| bool | auto_size_buttons | True if Buttons in this Window should be sized to exactly fit the text on this. |
| (str or (str, int[, str]) or None) | font | specifies the font family, size, etc. Tuple or Single string format 'name size styles'. Styles: italic * roman bold normal underline overstrike |
| int | border_width | width of border around element |
| int | slider_border_width | Width of the border around sliders |
| str | slider_relief | Type of relief to use for sliders |
| ??? | slider_orientation | ??? |
| ??? | autoclose_time | ??? |
| ??? | message_box_line_width | ??? |
| ??? | progress_meter_border_depth | ??? |
| ??? | progress_meter_style | You can no longer set a progress bar style. All ttk styles must be the same for the window |
| ??? | progress_meter_relief | |
| ??? | progress_meter_color | ??? |
| ??? | progress_meter_size | ??? |
| 'left' or 'right' or 'center' | text_justification | Default text justification for all Text Elements in window |
| str | background_color | color of background |
| str | element_background_color | element background color |
| str | text_element_background_color | text element background color |
| str | input_elements_background_color | Default color to use for the background of input elements |
| str | input_text_color | Default color to use for the text for Input elements |
| str | scrollbar_color | Default color to use for the slider trough |
| str | text_color | color of the text |
| str | element_text_color | Default color to use for Text elements |
| (int, int) | debug_win_size | window size |
| (int, int) or None | window_location | Default location to place windows. Not setting will center windows on the display |
| ??? | error_button_color | (Default = (None)) |
| int | tooltip_time | time in milliseconds to wait before showing a tooltip. Default is 400ms |
| str or Tuple[str, int] or Tuple[str, int, str] | tooltip_font | font to use for all tooltips |
| bool | use_ttk_buttons | if True will cause all buttons to be ttk buttons |
| str | ttk_theme | Theme to use with ttk widgets. Choices (on Windows) include - 'default', 'winnative', 'clam', 'alt', 'classic', 'vista', 'xpnative' |
| bool | suppress_error_popups | If True then error popups will not be shown if generated internally to PySimpleGUI |
| bool | suppress_raise_key_errors | If True then key errors won't be raised (you'll still get popup error) |
| bool | suppress_key_guessing | If True then key errors won't try and find closest matches for you |
| bool | enable_treeview_869_patch | If True, then will use the treeview color patch for tk 8.6.9 |
| bool | enable_mac_notitlebar_patch | If True then Windows with no titlebar use an alternative technique when tkinter version < 8.6.10 |
| bool | use_custom_titlebar | If True then a custom titlebar is used instead of the normal system titlebar |
| str or None | titlebar_background_color | If custom titlebar indicated by use_custom_titlebar, then use this as background color |
| str or None | titlebar_text_color | If custom titlebar indicated by use_custom_titlebar, then use this as text color |
| (str or (str, int[, str]) or None) or None | titlebar_font | If custom titlebar indicated by use_custom_titlebar, then use this as title font |
| bytes or str | titlebar_icon | If custom titlebar indicated by use_custom_titlebar, then use this as the icon (file or base64 bytes) |
| str | user_settings_path | default path for user_settings API calls. Expanded with os.path.expanduser so can contain ~ to represent user |
| str | pysimplegui_settings_path | default path for the global PySimpleGUI user_settings |
| str | pysimplegui_settings_filename | default filename for the global PySimpleGUI user_settings |
| None | **RETURN** | None
## Old Themes (Look and Feel) - Replaced by theme()
You should NOT use these calls. They are here for your reference should you run into them in existing code.
Change the "color scheme" of all future PySimpleGUI Windows.
The scheme are string names that specify a group of colors. Background colors, text colors, button colors.
There are 13 different color settings that are changed at one time using a single call to ChangeLookAndFeel
The look and feel table itself has these indexes into the dictionary LOOK_AND_FEEL_TABLE.
The original list was (prior to a major rework and renaming)... these names still work...
In Nov 2019 a new Theme Formula was devised to make choosing a theme easier:
The "Formula" is:
["Dark" or "Light"] Color Number
Colors can be Blue Brown Grey Green Purple Red Teal Yellow Black
The number will vary for each pair. There are more DarkGrey entries than there are LightYellow for example.
Default = The default settings (only button color is different than system default)
Default1 = The full system default including the button (everything's gray... how sad... don't be all gray... please....)
```
ChangeLookAndFeel(index, force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | index | the name of the index into the Look and Feel table (does not have to be exact, can be "fuzzy") |
| bool | force | no longer used |
| None | **RETURN** | None
Get a list of the valid values to pass into your call to change_look_and_feel
```
ListOfLookAndFeelValues()
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[str] | **RETURN** | list of valid string values
Displays a "Quick Reference Window" showing all of the different Look and Feel settings that are available.
They are sorted alphabetically. The legacy color names are mixed in, but otherwise they are sorted into Dark and Light halves
```
preview_all_look_and_feel_themes(columns = 12,
scrollable = False,
scroll_area_size = (None, None),
search_string = None,
location = (None, None))
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| int | columns | The number of themes to display per row |
| bool | scrollable | If True then scrollbars will be added |
| (int, int) | scroll_area_size | Size of the scrollable area (The Column Element used to make scrollable) |
| str | search_string | If specified then only themes containing this string will be shown |
| (int, int) | location | Location on the screen to place the window. Defaults to the center like all windows |
Get a list of the valid values to pass into your call to change_look_and_feel
```
list_of_look_and_feel_values()
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| List[str] | **RETURN** | list of valid string values
Change the "color scheme" of all future PySimpleGUI Windows.
The scheme are string names that specify a group of colors. Background colors, text colors, button colors.
There are 13 different color settings that are changed at one time using a single call to ChangeLookAndFeel
The look and feel table itself has these indexes into the dictionary LOOK_AND_FEEL_TABLE.
The original list was (prior to a major rework and renaming)... these names still work...
In Nov 2019 a new Theme Formula was devised to make choosing a theme easier:
The "Formula" is:
["Dark" or "Light"] Color Number
Colors can be Blue Brown Grey Green Purple Red Teal Yellow Black
The number will vary for each pair. There are more DarkGrey entries than there are LightYellow for example.
Default = The default settings (only button color is different than system default)
Default1 = The full system default including the button (everything's gray... how sad... don't be all gray... please....)
```
change_look_and_feel(index, force = False)
```
Parameter Descriptions:
|Type|Name|Meaning|
|--|--|--|
| str | index | the name of the index into the Look and Feel table (does not have to be exact, can be "fuzzy") |
| bool | force | no longer used |
| None | **RETURN** | None
-------------
This documentation is copyright 2021 by PySimpleGUI Inc
Republishing the copyrighted PySimpleGUI documentation and selling it are not allowed.
When in doubt, ask.