commit
						0dd6f3c990
					
				
					 9 changed files with 381 additions and 117 deletions
				
			
		|  | @ -1,6 +1,6 @@ | ||||||
| #!/usr/bin/python3 | #!/usr/bin/python3 | ||||||
| 
 | 
 | ||||||
| version = __version__ = "4.37.0.5 Unreleased\nMultiline scrollbar parameter renamed to no_scrollbar to match the listbox (sorry! but at least I caught it quickly), more debugger work, addition of constant MENU_SHORTCUT_CHARACTER (&), added execute_find_callers_filename, icon added to popup_scrolled, better error reporting for duplicate keys" | version = __version__ = "4.38.0 Released 21-Mar-2021" | ||||||
| 
 | 
 | ||||||
| __version__ = version.split()[0]    # For PEP 396 and PEP 345 | __version__ = version.split()[0]    # For PEP 396 and PEP 345 | ||||||
| 
 | 
 | ||||||
|  | @ -17968,6 +17968,13 @@ def execute_file_explorer(folder_to_open=''): | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def execute_find_callers_filename(): | def execute_find_callers_filename(): | ||||||
|  |     """ | ||||||
|  |     Returns the first filename found in a traceback that is not the nsame of this file (__file__) | ||||||
|  |     Used internally with the debugger for example. | ||||||
|  | 
 | ||||||
|  |     :return: filename of the caller, asseumed to be the first non PySimpleGUI file | ||||||
|  |     :rtype: str | ||||||
|  |     """ | ||||||
|     try:    # lots can go wrong so wrapping the entire thing |     try:    # lots can go wrong so wrapping the entire thing | ||||||
|         trace_details = traceback.format_stack() |         trace_details = traceback.format_stack() | ||||||
|         file_info_pysimplegui, error_message = None, '' |         file_info_pysimplegui, error_message = None, '' | ||||||
|  |  | ||||||
|  | @ -1,4 +1,4 @@ | ||||||
|    |  | ||||||
| 
 | 
 | ||||||
| # ELEMENT AND FUNCTION CALL REFERENCE | # ELEMENT AND FUNCTION CALL REFERENCE | ||||||
| 
 | 
 | ||||||
|  | @ -10481,6 +10481,8 @@ Parameter Descriptions: | ||||||
| 
 | 
 | ||||||
| ### These are non-PEP8 Compliant Methods - do NOT use | ### 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. | 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 | ### AddRow | ||||||
|  | @ -13468,6 +13470,7 @@ popup_scrolled(args=*<1 or N object>, | ||||||
|     keep_on_top = False, |     keep_on_top = False, | ||||||
|     font = None, |     font = None, | ||||||
|     image = None, |     image = None, | ||||||
|  |     icon = None, | ||||||
|     modal = True) |     modal = True) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -13491,6 +13494,7 @@ Parameter Descriptions: | ||||||
| |          bool          |     keep_on_top     | If True the window will remain above all current windows | | |          bool          |     keep_on_top     | If True the window will remain above all current windows | | ||||||
| | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | ||||||
| |      str or bytes      |        image        | Image to include at the top of the popup window | | |      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          |        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 | | 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 | ||||||
| 
 | 
 | ||||||
|  | @ -13561,6 +13565,7 @@ sprint(args=*<1 or N object>, | ||||||
|     keep_on_top = False, |     keep_on_top = False, | ||||||
|     font = None, |     font = None, | ||||||
|     image = None, |     image = None, | ||||||
|  |     icon = None, | ||||||
|     modal = True) |     modal = True) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -13584,6 +13589,7 @@ Parameter Descriptions: | ||||||
| |          bool          |     keep_on_top     | If True the window will remain above all current windows | | |          bool          |     keep_on_top     | If True the window will remain above all current windows | | ||||||
| | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | ||||||
| |      str or bytes      |        image        | Image to include at the top of the popup window | | |      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          |        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 | | 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 | ||||||
| 
 | 
 | ||||||
|  | @ -13607,6 +13613,7 @@ ScrolledTextBox(args=*<1 or N object>, | ||||||
|     keep_on_top = False, |     keep_on_top = False, | ||||||
|     font = None, |     font = None, | ||||||
|     image = None, |     image = None, | ||||||
|  |     icon = None, | ||||||
|     modal = True) |     modal = True) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -13630,12 +13637,15 @@ Parameter Descriptions: | ||||||
| |          bool          |     keep_on_top     | If True the window will remain above all current windows | | |          bool          |     keep_on_top     | If True the window will remain above all current windows | | ||||||
| | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | ||||||
| |      str or bytes      |        image        | Image to include at the top of the popup window | | |      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          |        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 | | 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 | ## Popup Not PEP8 Compliant names | ||||||
| 
 | 
 | ||||||
| These versions of the popup functions are here only for backwards compatibility.  You should not use these function names.  Instead use the popup functions that have snake_case rather than CamelCase. | *** 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 | 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. | "print" statement.  It's also great for "pausing" your program's flow until the user can read some error messages. | ||||||
|  | @ -14235,52 +14245,6 @@ Parameter Descriptions: | ||||||
| 
 | 
 | ||||||
| Show Popup window and immediately return (does not block) | Show Popup window and immediately return (does not block) | ||||||
| 
 | 
 | ||||||
| ``` |  | ||||||
| PopupNoWait(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). | |  | ||||||
| | Tuple[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 Tuple[str, int] |        font         | specifies the font family, size, etc | |  | ||||||
| |          bool          |     no_titlebar     | If True no titlebar will be shown | |  | ||||||
| |          bool          |    grab_anywhere    | If True: can grab anywhere to move the window (Default = False) | |  | ||||||
| |    Tuple[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 |  | ||||||
| 
 |  | ||||||
| Show Popup window and immediately return (does not block) |  | ||||||
| 
 |  | ||||||
| ``` | ``` | ||||||
| PopupNonBlocking(args=*<1 or N object>, | PopupNonBlocking(args=*<1 or N object>, | ||||||
|     title = None, |     title = None, | ||||||
|  | @ -14529,6 +14493,7 @@ PopupScrolled(args=*<1 or N object>, | ||||||
|     keep_on_top = False, |     keep_on_top = False, | ||||||
|     font = None, |     font = None, | ||||||
|     image = None, |     image = None, | ||||||
|  |     icon = None, | ||||||
|     modal = True) |     modal = True) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -14552,6 +14517,7 @@ Parameter Descriptions: | ||||||
| |          bool          |     keep_on_top     | If True the window will remain above all current windows | | |          bool          |     keep_on_top     | If True the window will remain above all current windows | | ||||||
| | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | ||||||
| |      str or bytes      |        image        | Image to include at the top of the popup window | | |      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          |        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 | | 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 | ||||||
| 
 | 
 | ||||||
|  | @ -14649,6 +14615,10 @@ Parameter Descriptions: | ||||||
| 
 | 
 | ||||||
| ## PEP8 Function Bindings | ## 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 | Dumps an Object's values as a formatted string.  Very nicely done. Great way to display an object's member variables in human form | ||||||
| 
 | 
 | ||||||
| ``` | ``` | ||||||
|  | @ -14679,6 +14649,8 @@ Parameter Descriptions: | ||||||
| 
 | 
 | ||||||
| ## The Main Program - Test Harness, Global Settings, Debug Information, Upgrade from GitHub | ## 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. | 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. | 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. | ||||||
|  | @ -14998,6 +14970,67 @@ Parameter Descriptions: | ||||||
| |--|--|--| | |--|--|--| | ||||||
| | (str) | **RETURN** | (str) - color string of the text background color currently in use | | (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 | ## User Settings | ||||||
| 
 | 
 | ||||||
| In addition to user settings files, there is also a global PySimpleGUI settings file. | In addition to user settings files, there is also a global PySimpleGUI settings file. | ||||||
|  | @ -15236,6 +15269,19 @@ Parameter Descriptions: | ||||||
| | str | folder_to_open | The path to open in the explorer program | | | str | folder_to_open | The path to open in the explorer program | | ||||||
| | (subprocess.Popen) or None | **RETURN** | Popen object | | (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 | Get the text results of a previously executed execute call | ||||||
| Returns a tuple of the strings (stdout, stderr) | Returns a tuple of the strings (stdout, stderr) | ||||||
| 
 | 
 | ||||||
|  | @ -15277,6 +15323,19 @@ Parameter Descriptions: | ||||||
| | 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 | | | 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 | | (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 | ||||||
|  | 
 | ||||||
| ## Misc | ## Misc | ||||||
| 
 | 
 | ||||||
| Fills a window with values provided in a values dictionary { element_key : new_value } | Fills a window with values provided in a values dictionary { element_key : new_value } | ||||||
|  | @ -15616,6 +15675,8 @@ Parameter Descriptions: | ||||||
| 
 | 
 | ||||||
| ## Old Themes (Look and Feel) - Replaced by theme() | ## 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. | 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. | 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 | There are 13 different color settings that are changed at one time using a single call to ChangeLookAndFeel | ||||||
|  | @ -15710,3 +15771,11 @@ Parameter Descriptions: | ||||||
| | str  | index | the name of the index into the Look and Feel table (does not have to be exact, can be "fuzzy") | | | 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 | | | bool | force | no longer used | | ||||||
| | None | **RETURN** | None | | 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. | ||||||
|  | @ -1,6 +1,4 @@ | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|    |  | ||||||
| 
 | 
 | ||||||
|       |       | ||||||
| # The PySimpleGUI Cookbook       | # The PySimpleGUI Cookbook       | ||||||
|  |  | ||||||
|  | @ -1519,6 +1519,7 @@ popup_scrolled(args=*<1 or N object>, | ||||||
|     keep_on_top = False, |     keep_on_top = False, | ||||||
|     font = None, |     font = None, | ||||||
|     image = None, |     image = None, | ||||||
|  |     icon = None, | ||||||
|     modal = True) |     modal = True) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -1542,6 +1543,7 @@ Parameter Descriptions: | ||||||
| |          bool          |     keep_on_top     | If True the window will remain above all current windows | | |          bool          |     keep_on_top     | If True the window will remain above all current windows | | ||||||
| | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | ||||||
| |      str or bytes      |        image        | Image to include at the top of the popup window | | |      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          |        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 | | 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 | ||||||
| 
 | 
 | ||||||
|  | @ -8541,6 +8543,26 @@ I'll eventually figure out this subprocess thing... honest... | ||||||
| 	* Makes it one less import and the code already existed.  All that needed to happen is the _ removed from the front of function name | 	* Makes it one less import and the code already existed.  All that needed to happen is the _ removed from the front of function name | ||||||
| 	 | 	 | ||||||
| 
 | 
 | ||||||
|  | 	 | ||||||
|  | ## 4.38.0 PySimpleGUI 21-Mar-2021 | ||||||
|  | 
 | ||||||
|  | The "so much for no new releases for a while" release | ||||||
|  | 
 | ||||||
|  | * Changed name of the NEW parm in Multiline element from scrollbar to no_scrollbar | ||||||
|  | 	* This matches the other elements that also have this same parameter (Listbox) | ||||||
|  | 	* Wanted to get this release posted prior to users writing code that uses it (it's only been 1 week) | ||||||
|  | 	* This is the actual purpose for the release... so that it doesn't linger to the point it breaks being backwards compatible | ||||||
|  | * Some additional debugger stuff... nothing to see here... keep moving.... will let you know when there's more | ||||||
|  | * Added icon parameter to popup_scrolled | ||||||
|  | * New Exec API call - execute_find_callers_filename | ||||||
|  | 	* It basically looks backwards until PySimpleGUI isn't found | ||||||
|  | 	* Hopefully will help in error messages to determine who is calling PySimpleGUI | ||||||
|  | * Made a constant variable for the & char used by Menus in PySimpleGUI for shortcuts | ||||||
|  | 	* Also fixed a couple of places where they were being erroneously stripped from the normal menu text | ||||||
|  | * Better error reporting for duplicatea keys | ||||||
|  | 	* Found a problem with using print for errors - rerouted stdout/stderr can cause MORE errors | ||||||
|  | 	* Interestingly, popups work great for these errors as they do not havea cascading error effect | ||||||
|  | 
 | ||||||
| ## Upcoming | ## Upcoming | ||||||
| 
 | 
 | ||||||
| The future for PySimpleGUI looks bright!   | The future for PySimpleGUI looks bright!   | ||||||
|  | @ -8590,16 +8612,18 @@ From the start of the PSG project, tkinter was not meant to be the only underlyi | ||||||
| 
 | 
 | ||||||
| # Author & Owner | # Author & Owner | ||||||
| 
 | 
 | ||||||
| Written and owned by The PySimpleGUI Organization | Written and owned by PySimpleGUI Inc | ||||||
| 
 | 
 | ||||||
| This documentation as well as all PySimpleGUI documentation and  code is Copyright 2018, 2019, 2020 by PySimpleGUI.org | This documentation as well as all PySimpleGUI documentation and  code is Copyright 2018, 2019, 2020, 2021 by PySimpleGUI | ||||||
| 
 | 
 | ||||||
| Send correspondence to PySimpleGUI@PySimpleGUI.com | Send business correspondence to PySimpleGUI@PySimpleGUI.com | ||||||
| 
 | 
 | ||||||
| ## License | ## License | ||||||
| 
 | 
 | ||||||
| GNU Lesser General Public License (LGPL 3) + | GNU Lesser General Public License (LGPL 3) + | ||||||
| 
 | 
 | ||||||
|  | Please note that this license does **not** allow you to break copyright laws.  You are licensing the software. | ||||||
|  | 
 | ||||||
| ## Acknowledgments | ## Acknowledgments | ||||||
| 
 | 
 | ||||||
| There are a number of people that have been key contributors to this project both directly and indirectly.  Paid professional help has been deployed a number of critical times in the project's history.  This happens in the life of software development from time to time. | There are a number of people that have been key contributors to this project both directly and indirectly.  Paid professional help has been deployed a number of critical times in the project's history.  This happens in the life of software development from time to time. | ||||||
|  | @ -8611,3 +8635,10 @@ If you've helped, I sure hope that you feel like you've been properly thanked. | ||||||
| In response to a number of email contacts from individuals and corporations that are using PySimpleGUI that wanted to financially support the project a "Support" Button was added to the GitHub site.  This support button is connected with a PayPal account.  If you wish to help support this currently freely supplied software and free technical support, then follow this link: www.paypal.me/psgui .  | In response to a number of email contacts from individuals and corporations that are using PySimpleGUI that wanted to financially support the project a "Support" Button was added to the GitHub site.  This support button is connected with a PayPal account.  If you wish to help support this currently freely supplied software and free technical support, then follow this link: www.paypal.me/psgui .  | ||||||
| 
 | 
 | ||||||
| To be clear, this is not a solicitation for your money.  No one is being directly asked to support / contribute.  The project is self-funded and there are ongoing costs just to offer the software (URLs, ReadTheDocs, etc). If you're a corporate user and find that PySimpleGUI is helping you financially, that's awesome.  If you want to help ensure PySimpleGUI has a future, you now have that option to help.  It's likely that at some point the costs will become too high for the project to continue to be free, but until then we'll all enjoy the successes we're having. | To be clear, this is not a solicitation for your money.  No one is being directly asked to support / contribute.  The project is self-funded and there are ongoing costs just to offer the software (URLs, ReadTheDocs, etc). If you're a corporate user and find that PySimpleGUI is helping you financially, that's awesome.  If you want to help ensure PySimpleGUI has a future, you now have that option to help.  It's likely that at some point the costs will become too high for the project to continue to be free, but until then we'll all enjoy the successes we're having. | ||||||
|  | 
 | ||||||
|  | ## Legal | ||||||
|  | 
 | ||||||
|  | All documentation in this file and in the PySimpleGUI GitHub account are copyright 2021 by PySimpleGUI Inc.  The PySimpleGUI code, the demo programs and other source code in the PySimpleGUI account also have a copyright owned by PySimpleGUI Inc. | ||||||
|  | 
 | ||||||
|  | The name "PySimpleGUI" and the PySimpleGUI logo are Trademarked | ||||||
|  | 
 | ||||||
|  |  | ||||||
|  | @ -316,3 +316,4 @@ It's understood that this way of development of a Python package is unorthodox. | ||||||
| ## GitHub Repos | ## GitHub Repos | ||||||
| 
 | 
 | ||||||
| If you've created a GitHub for your project that uses PySimpleGUI then please post screenshots in in the "User's Screenshots" Issue on the PySimpleGUI GitHub.  Say a little something about it and I'll also add it to the announcements. People *love* success stories and showing your GUI's screen visually communicates your success.  | If you've created a GitHub for your project that uses PySimpleGUI then please post screenshots in in the "User's Screenshots" Issue on the PySimpleGUI GitHub.  Say a little something about it and I'll also add it to the announcements. People *love* success stories and showing your GUI's screen visually communicates your success.  | ||||||
|  | 
 | ||||||
|  |  | ||||||
|  | @ -1794,6 +1794,26 @@ I'll eventually figure out this subprocess thing... honest... | ||||||
| 	 | 	 | ||||||
| 
 | 
 | ||||||
| 	 | 	 | ||||||
|  | ## 4.38.0 PySimpleGUI 21-Mar-2021 | ||||||
|  | 
 | ||||||
|  | The "so much for no new releases for a while" release | ||||||
|  | 
 | ||||||
|  | * Changed name of the NEW parm in Multiline element from scrollbar to no_scrollbar | ||||||
|  | 	* This matches the other elements that also have this same parameter (Listbox) | ||||||
|  | 	* Wanted to get this release posted prior to users writing code that uses it (it's only been 1 week) | ||||||
|  | 	* This is the actual purpose for the release... so that it doesn't linger to the point it breaks being backwards compatible | ||||||
|  | * Some additional debugger stuff... nothing to see here... keep moving.... will let you know when there's more | ||||||
|  | * Added icon parameter to popup_scrolled | ||||||
|  | * New Exec API call - execute_find_callers_filename | ||||||
|  | 	* It basically looks backwards until PySimpleGUI isn't found | ||||||
|  | 	* Hopefully will help in error messages to determine who is calling PySimpleGUI | ||||||
|  | * Made a constant variable for the & char used by Menus in PySimpleGUI for shortcuts | ||||||
|  | 	* Also fixed a couple of places where they were being erroneously stripped from the normal menu text | ||||||
|  | * Better error reporting for duplicatea keys | ||||||
|  | 	* Found a problem with using print for errors - rerouted stdout/stderr can cause MORE errors | ||||||
|  | 	* Interestingly, popups work great for these errors as they do not havea cascading error effect | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| ## Upcoming | ## Upcoming | ||||||
| 
 | 
 | ||||||
| The future for PySimpleGUI looks bright!   | The future for PySimpleGUI looks bright!   | ||||||
|  | @ -1846,16 +1866,18 @@ From the start of the PSG project, tkinter was not meant to be the only underlyi | ||||||
| 
 | 
 | ||||||
| # Author & Owner | # Author & Owner | ||||||
| 
 | 
 | ||||||
| Written and owned by The PySimpleGUI Organization | Written and owned by PySimpleGUI Inc | ||||||
| 
 | 
 | ||||||
| This documentation as well as all PySimpleGUI documentation and  code is Copyright 2018, 2019, 2020 by PySimpleGUI.org | This documentation as well as all PySimpleGUI documentation and  code is Copyright 2018, 2019, 2020, 2021 by PySimpleGUI | ||||||
| 
 | 
 | ||||||
| Send correspondence to PySimpleGUI@PySimpleGUI.com | Send business correspondence to PySimpleGUI@PySimpleGUI.com | ||||||
| 
 | 
 | ||||||
| ## License | ## License | ||||||
| 
 | 
 | ||||||
| GNU Lesser General Public License (LGPL 3) + | GNU Lesser General Public License (LGPL 3) + | ||||||
| 
 | 
 | ||||||
|  | Please note that this license does **not** allow you to break copyright laws.  You are licensing the software. | ||||||
|  | 
 | ||||||
| ## Acknowledgments | ## Acknowledgments | ||||||
| 
 | 
 | ||||||
| There are a number of people that have been key contributors to this project both directly and indirectly.  Paid professional help has been deployed a number of critical times in the project's history.  This happens in the life of software development from time to time. | There are a number of people that have been key contributors to this project both directly and indirectly.  Paid professional help has been deployed a number of critical times in the project's history.  This happens in the life of software development from time to time. | ||||||
|  | @ -1867,3 +1889,9 @@ If you've helped, I sure hope that you feel like you've been properly thanked. | ||||||
| In response to a number of email contacts from individuals and corporations that are using PySimpleGUI that wanted to financially support the project a "Support" Button was added to the GitHub site.  This support button is connected with a PayPal account.  If you wish to help support this currently freely supplied software and free technical support, then follow this link: www.paypal.me/psgui .  | In response to a number of email contacts from individuals and corporations that are using PySimpleGUI that wanted to financially support the project a "Support" Button was added to the GitHub site.  This support button is connected with a PayPal account.  If you wish to help support this currently freely supplied software and free technical support, then follow this link: www.paypal.me/psgui .  | ||||||
| 
 | 
 | ||||||
| To be clear, this is not a solicitation for your money.  No one is being directly asked to support / contribute.  The project is self-funded and there are ongoing costs just to offer the software (URLs, ReadTheDocs, etc). If you're a corporate user and find that PySimpleGUI is helping you financially, that's awesome.  If you want to help ensure PySimpleGUI has a future, you now have that option to help.  It's likely that at some point the costs will become too high for the project to continue to be free, but until then we'll all enjoy the successes we're having. | To be clear, this is not a solicitation for your money.  No one is being directly asked to support / contribute.  The project is self-funded and there are ongoing costs just to offer the software (URLs, ReadTheDocs, etc). If you're a corporate user and find that PySimpleGUI is helping you financially, that's awesome.  If you want to help ensure PySimpleGUI has a future, you now have that option to help.  It's likely that at some point the costs will become too high for the project to continue to be free, but until then we'll all enjoy the successes we're having. | ||||||
|  | 
 | ||||||
|  | ## Legal | ||||||
|  | 
 | ||||||
|  | All documentation in this file and in the PySimpleGUI GitHub account are copyright 2021 by PySimpleGUI Inc.  The PySimpleGUI code, the demo programs and other source code in the PySimpleGUI account also have a copyright owned by PySimpleGUI Inc. | ||||||
|  | 
 | ||||||
|  | The name "PySimpleGUI" and the PySimpleGUI logo are Trademarked | ||||||
|  | @ -1,4 +1,5 @@ | ||||||
|    |  | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| # ELEMENT AND FUNCTION CALL REFERENCE | # ELEMENT AND FUNCTION CALL REFERENCE | ||||||
| 
 | 
 | ||||||
|  | @ -2339,6 +2340,8 @@ The following methods are here for backwards compatibility reference.  You will | ||||||
| 
 | 
 | ||||||
| ### These are non-PEP8 Compliant Methods - do NOT use | ### 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. | 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. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -2621,7 +2624,9 @@ They are shown here in case you run into them in some old code. | ||||||
| 
 | 
 | ||||||
| ## Popup Not PEP8 Compliant names | ## Popup Not PEP8 Compliant names | ||||||
| 
 | 
 | ||||||
| These versions of the popup functions are here only for backwards compatibility.  You should not use these function names.  Instead use the popup functions that have snake_case rather than CamelCase. | *** 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. | ||||||
| 
 | 
 | ||||||
| <!-- <+func.Popup+> --> | <!-- <+func.Popup+> --> | ||||||
| <!-- <+func.PopupAnimated+> --> | <!-- <+func.PopupAnimated+> --> | ||||||
|  | @ -2636,7 +2641,6 @@ These versions of the popup functions are here only for backwards compatibility. | ||||||
| <!-- <+func.PopupNoButtons+> --> | <!-- <+func.PopupNoButtons+> --> | ||||||
| <!-- <+func.PopupNoFrame+> --> | <!-- <+func.PopupNoFrame+> --> | ||||||
| <!-- <+func.PopupNoTitlebar+> --> | <!-- <+func.PopupNoTitlebar+> --> | ||||||
| <!-- <+func.PopupNoWait+> --> |  | ||||||
| <!-- <+func.PopupNonBlocking+> --> | <!-- <+func.PopupNonBlocking+> --> | ||||||
| <!-- <+func.PopupOK+> --> | <!-- <+func.PopupOK+> --> | ||||||
| <!-- <+func.PopupOKCancel+> --> | <!-- <+func.PopupOKCancel+> --> | ||||||
|  | @ -2651,13 +2655,18 @@ These versions of the popup functions are here only for backwards compatibility. | ||||||
| 
 | 
 | ||||||
| ## PEP8 Function Bindings | ## 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. | ||||||
|  | 
 | ||||||
| <!-- <+func.obj_to_string+> --> | <!-- <+func.obj_to_string+> --> | ||||||
| <!-- <+func.obj_to_string_single_obj+> --> | <!-- <+func.obj_to_string_single_obj+> --> | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| ## The Main Program - Test Harness, Global Settings, Debug Information, Upgrade from GitHub | ## 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. | 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. | 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. | ||||||
|  | @ -2699,6 +2708,17 @@ You can call main() from your code and then access these other features such as | ||||||
| <!-- <+func.theme_text_element_background_color+> --> | <!-- <+func.theme_text_element_background_color+> --> | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | ## 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. | ||||||
|  | 
 | ||||||
|  | <!-- <+func.running_linux+> --> | ||||||
|  | <!-- <+func.running_mac+> --> | ||||||
|  | <!-- <+func.running_trinket+> --> | ||||||
|  | <!-- <+func.running_windows+> --> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| ## User Settings | ## User Settings | ||||||
| 
 | 
 | ||||||
| In addition to user settings files, there is also a global PySimpleGUI settings file. | In addition to user settings files, there is also a global PySimpleGUI settings file. | ||||||
|  | @ -2724,9 +2744,10 @@ These API calls are used to launch subprocesses. | ||||||
| <!-- <+func.execute_command_subprocess+> --> | <!-- <+func.execute_command_subprocess+> --> | ||||||
| <!-- <+func.execute_editor+> --> | <!-- <+func.execute_editor+> --> | ||||||
| <!-- <+func.execute_file_explorer+> --> | <!-- <+func.execute_file_explorer+> --> | ||||||
|  | <!-- <+func.execute_find_callers_filename+> --> | ||||||
| <!-- <+func.execute_get_results+> --> | <!-- <+func.execute_get_results+> --> | ||||||
| <!-- <+func.execute_py_file+> --> | <!-- <+func.execute_py_file+> --> | ||||||
| 
 | <!-- <+func.execute_subprocess_still_running+> --> | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ## Misc | ## Misc | ||||||
|  | @ -2749,6 +2770,7 @@ These API calls are used to launch subprocesses. | ||||||
| <!-- <+func.set_global_icon+> --> | <!-- <+func.set_global_icon+> --> | ||||||
| <!-- <+func.set_options+> --> | <!-- <+func.set_options+> --> | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| ### Non PEP8 versions | ### Non PEP8 versions | ||||||
| 
 | 
 | ||||||
| <!-- <+func.SetGlobalIcon+> --> | <!-- <+func.SetGlobalIcon+> --> | ||||||
|  | @ -2758,9 +2780,18 @@ These API calls are used to launch subprocesses. | ||||||
| 
 | 
 | ||||||
| ## Old Themes (Look and Feel) - Replaced by theme() | ## 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. | ||||||
|  | 
 | ||||||
| <!-- <+func.ChangeLookAndFeel+> --> | <!-- <+func.ChangeLookAndFeel+> --> | ||||||
| <!-- <+func.ListOfLookAndFeelValues+> --> | <!-- <+func.ListOfLookAndFeelValues+> --> | ||||||
| <!-- <+func.preview_all_look_and_feel_themes+> --> | <!-- <+func.preview_all_look_and_feel_themes+> --> | ||||||
| <!-- <+func.list_of_look_and_feel_values+> --> | <!-- <+func.list_of_look_and_feel_values+> --> | ||||||
| <!-- <+func.change_look_and_feel+> --> | <!-- <+func.change_look_and_feel+> --> | ||||||
| 
 | 
 | ||||||
|  | ------------- | ||||||
|  | 
 | ||||||
|  | This documentation is copyright 2021 by PySimpleGUI Inc | ||||||
|  | 
 | ||||||
|  | Republishing the copyrighted PySimpleGUI documentation and selling it are not allowed. | ||||||
|  | 
 | ||||||
|  | When in doubt, ask. | ||||||
|  | @ -1,4 +1,4 @@ | ||||||
|    |  | ||||||
| 
 | 
 | ||||||
| # ELEMENT AND FUNCTION CALL REFERENCE | # ELEMENT AND FUNCTION CALL REFERENCE | ||||||
| 
 | 
 | ||||||
|  | @ -10481,6 +10481,8 @@ Parameter Descriptions: | ||||||
| 
 | 
 | ||||||
| ### These are non-PEP8 Compliant Methods - do NOT use | ### 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. | 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 | ### AddRow | ||||||
|  | @ -13468,6 +13470,7 @@ popup_scrolled(args=*<1 or N object>, | ||||||
|     keep_on_top = False, |     keep_on_top = False, | ||||||
|     font = None, |     font = None, | ||||||
|     image = None, |     image = None, | ||||||
|  |     icon = None, | ||||||
|     modal = True) |     modal = True) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -13491,6 +13494,7 @@ Parameter Descriptions: | ||||||
| |          bool          |     keep_on_top     | If True the window will remain above all current windows | | |          bool          |     keep_on_top     | If True the window will remain above all current windows | | ||||||
| | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | ||||||
| |      str or bytes      |        image        | Image to include at the top of the popup window | | |      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          |        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 | | 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 | ||||||
| 
 | 
 | ||||||
|  | @ -13561,6 +13565,7 @@ sprint(args=*<1 or N object>, | ||||||
|     keep_on_top = False, |     keep_on_top = False, | ||||||
|     font = None, |     font = None, | ||||||
|     image = None, |     image = None, | ||||||
|  |     icon = None, | ||||||
|     modal = True) |     modal = True) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -13584,6 +13589,7 @@ Parameter Descriptions: | ||||||
| |          bool          |     keep_on_top     | If True the window will remain above all current windows | | |          bool          |     keep_on_top     | If True the window will remain above all current windows | | ||||||
| | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | ||||||
| |      str or bytes      |        image        | Image to include at the top of the popup window | | |      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          |        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 | | 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 | ||||||
| 
 | 
 | ||||||
|  | @ -13607,6 +13613,7 @@ ScrolledTextBox(args=*<1 or N object>, | ||||||
|     keep_on_top = False, |     keep_on_top = False, | ||||||
|     font = None, |     font = None, | ||||||
|     image = None, |     image = None, | ||||||
|  |     icon = None, | ||||||
|     modal = True) |     modal = True) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -13630,12 +13637,15 @@ Parameter Descriptions: | ||||||
| |          bool          |     keep_on_top     | If True the window will remain above all current windows | | |          bool          |     keep_on_top     | If True the window will remain above all current windows | | ||||||
| | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | ||||||
| |      str or bytes      |        image        | Image to include at the top of the popup window | | |      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          |        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 | | 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 | ## Popup Not PEP8 Compliant names | ||||||
| 
 | 
 | ||||||
| These versions of the popup functions are here only for backwards compatibility.  You should not use these function names.  Instead use the popup functions that have snake_case rather than CamelCase. | *** 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 | 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. | "print" statement.  It's also great for "pausing" your program's flow until the user can read some error messages. | ||||||
|  | @ -14235,52 +14245,6 @@ Parameter Descriptions: | ||||||
| 
 | 
 | ||||||
| Show Popup window and immediately return (does not block) | Show Popup window and immediately return (does not block) | ||||||
| 
 | 
 | ||||||
| ``` |  | ||||||
| PopupNoWait(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). | |  | ||||||
| | Tuple[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 Tuple[str, int] |        font         | specifies the font family, size, etc | |  | ||||||
| |          bool          |     no_titlebar     | If True no titlebar will be shown | |  | ||||||
| |          bool          |    grab_anywhere    | If True: can grab anywhere to move the window (Default = False) | |  | ||||||
| |    Tuple[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 |  | ||||||
| 
 |  | ||||||
| Show Popup window and immediately return (does not block) |  | ||||||
| 
 |  | ||||||
| ``` | ``` | ||||||
| PopupNonBlocking(args=*<1 or N object>, | PopupNonBlocking(args=*<1 or N object>, | ||||||
|     title = None, |     title = None, | ||||||
|  | @ -14529,6 +14493,7 @@ PopupScrolled(args=*<1 or N object>, | ||||||
|     keep_on_top = False, |     keep_on_top = False, | ||||||
|     font = None, |     font = None, | ||||||
|     image = None, |     image = None, | ||||||
|  |     icon = None, | ||||||
|     modal = True) |     modal = True) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -14552,6 +14517,7 @@ Parameter Descriptions: | ||||||
| |          bool          |     keep_on_top     | If True the window will remain above all current windows | | |          bool          |     keep_on_top     | If True the window will remain above all current windows | | ||||||
| | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | ||||||
| |      str or bytes      |        image        | Image to include at the top of the popup window | | |      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          |        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 | | 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 | ||||||
| 
 | 
 | ||||||
|  | @ -14649,6 +14615,10 @@ Parameter Descriptions: | ||||||
| 
 | 
 | ||||||
| ## PEP8 Function Bindings | ## 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 | Dumps an Object's values as a formatted string.  Very nicely done. Great way to display an object's member variables in human form | ||||||
| 
 | 
 | ||||||
| ``` | ``` | ||||||
|  | @ -14679,6 +14649,8 @@ Parameter Descriptions: | ||||||
| 
 | 
 | ||||||
| ## The Main Program - Test Harness, Global Settings, Debug Information, Upgrade from GitHub | ## 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. | 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. | 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. | ||||||
|  | @ -14998,6 +14970,67 @@ Parameter Descriptions: | ||||||
| |--|--|--| | |--|--|--| | ||||||
| | (str) | **RETURN** | (str) - color string of the text background color currently in use | | (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 | ## User Settings | ||||||
| 
 | 
 | ||||||
| In addition to user settings files, there is also a global PySimpleGUI settings file. | In addition to user settings files, there is also a global PySimpleGUI settings file. | ||||||
|  | @ -15236,6 +15269,19 @@ Parameter Descriptions: | ||||||
| | str | folder_to_open | The path to open in the explorer program | | | str | folder_to_open | The path to open in the explorer program | | ||||||
| | (subprocess.Popen) or None | **RETURN** | Popen object | | (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 | Get the text results of a previously executed execute call | ||||||
| Returns a tuple of the strings (stdout, stderr) | Returns a tuple of the strings (stdout, stderr) | ||||||
| 
 | 
 | ||||||
|  | @ -15277,6 +15323,19 @@ Parameter Descriptions: | ||||||
| | 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 | | | 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 | | (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 | ||||||
|  | 
 | ||||||
| ## Misc | ## Misc | ||||||
| 
 | 
 | ||||||
| Fills a window with values provided in a values dictionary { element_key : new_value } | Fills a window with values provided in a values dictionary { element_key : new_value } | ||||||
|  | @ -15616,6 +15675,8 @@ Parameter Descriptions: | ||||||
| 
 | 
 | ||||||
| ## Old Themes (Look and Feel) - Replaced by theme() | ## 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. | 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. | 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 | There are 13 different color settings that are changed at one time using a single call to ChangeLookAndFeel | ||||||
|  | @ -15710,3 +15771,11 @@ Parameter Descriptions: | ||||||
| | str  | index | the name of the index into the Look and Feel table (does not have to be exact, can be "fuzzy") | | | 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 | | | bool | force | no longer used | | ||||||
| | None | **RETURN** | None | | 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. | ||||||
|  | @ -1519,6 +1519,7 @@ popup_scrolled(args=*<1 or N object>, | ||||||
|     keep_on_top = False, |     keep_on_top = False, | ||||||
|     font = None, |     font = None, | ||||||
|     image = None, |     image = None, | ||||||
|  |     icon = None, | ||||||
|     modal = True) |     modal = True) | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -1542,6 +1543,7 @@ Parameter Descriptions: | ||||||
| |          bool          |     keep_on_top     | If True the window will remain above all current windows | | |          bool          |     keep_on_top     | If True the window will remain above all current windows | | ||||||
| | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | | str or Tuple[str, int] |        font         | specifies the font family, size, etc | | ||||||
| |      str or bytes      |        image        | Image to include at the top of the popup window | | |      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          |        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 | | 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 | ||||||
| 
 | 
 | ||||||
|  | @ -8541,6 +8543,26 @@ I'll eventually figure out this subprocess thing... honest... | ||||||
| 	* Makes it one less import and the code already existed.  All that needed to happen is the _ removed from the front of function name | 	* Makes it one less import and the code already existed.  All that needed to happen is the _ removed from the front of function name | ||||||
| 	 | 	 | ||||||
| 
 | 
 | ||||||
|  | 	 | ||||||
|  | ## 4.38.0 PySimpleGUI 21-Mar-2021 | ||||||
|  | 
 | ||||||
|  | The "so much for no new releases for a while" release | ||||||
|  | 
 | ||||||
|  | * Changed name of the NEW parm in Multiline element from scrollbar to no_scrollbar | ||||||
|  | 	* This matches the other elements that also have this same parameter (Listbox) | ||||||
|  | 	* Wanted to get this release posted prior to users writing code that uses it (it's only been 1 week) | ||||||
|  | 	* This is the actual purpose for the release... so that it doesn't linger to the point it breaks being backwards compatible | ||||||
|  | * Some additional debugger stuff... nothing to see here... keep moving.... will let you know when there's more | ||||||
|  | * Added icon parameter to popup_scrolled | ||||||
|  | * New Exec API call - execute_find_callers_filename | ||||||
|  | 	* It basically looks backwards until PySimpleGUI isn't found | ||||||
|  | 	* Hopefully will help in error messages to determine who is calling PySimpleGUI | ||||||
|  | * Made a constant variable for the & char used by Menus in PySimpleGUI for shortcuts | ||||||
|  | 	* Also fixed a couple of places where they were being erroneously stripped from the normal menu text | ||||||
|  | * Better error reporting for duplicatea keys | ||||||
|  | 	* Found a problem with using print for errors - rerouted stdout/stderr can cause MORE errors | ||||||
|  | 	* Interestingly, popups work great for these errors as they do not havea cascading error effect | ||||||
|  | 
 | ||||||
| ## Upcoming | ## Upcoming | ||||||
| 
 | 
 | ||||||
| The future for PySimpleGUI looks bright!   | The future for PySimpleGUI looks bright!   | ||||||
|  | @ -8590,16 +8612,18 @@ From the start of the PSG project, tkinter was not meant to be the only underlyi | ||||||
| 
 | 
 | ||||||
| # Author & Owner | # Author & Owner | ||||||
| 
 | 
 | ||||||
| Written and owned by The PySimpleGUI Organization | Written and owned by PySimpleGUI Inc | ||||||
| 
 | 
 | ||||||
| This documentation as well as all PySimpleGUI documentation and  code is Copyright 2018, 2019, 2020 by PySimpleGUI.org | This documentation as well as all PySimpleGUI documentation and  code is Copyright 2018, 2019, 2020, 2021 by PySimpleGUI | ||||||
| 
 | 
 | ||||||
| Send correspondence to PySimpleGUI@PySimpleGUI.com | Send business correspondence to PySimpleGUI@PySimpleGUI.com | ||||||
| 
 | 
 | ||||||
| ## License | ## License | ||||||
| 
 | 
 | ||||||
| GNU Lesser General Public License (LGPL 3) + | GNU Lesser General Public License (LGPL 3) + | ||||||
| 
 | 
 | ||||||
|  | Please note that this license does **not** allow you to break copyright laws.  You are licensing the software. | ||||||
|  | 
 | ||||||
| ## Acknowledgments | ## Acknowledgments | ||||||
| 
 | 
 | ||||||
| There are a number of people that have been key contributors to this project both directly and indirectly.  Paid professional help has been deployed a number of critical times in the project's history.  This happens in the life of software development from time to time. | There are a number of people that have been key contributors to this project both directly and indirectly.  Paid professional help has been deployed a number of critical times in the project's history.  This happens in the life of software development from time to time. | ||||||
|  | @ -8611,3 +8635,9 @@ If you've helped, I sure hope that you feel like you've been properly thanked. | ||||||
| In response to a number of email contacts from individuals and corporations that are using PySimpleGUI that wanted to financially support the project a "Support" Button was added to the GitHub site.  This support button is connected with a PayPal account.  If you wish to help support this currently freely supplied software and free technical support, then follow this link: www.paypal.me/psgui .  | In response to a number of email contacts from individuals and corporations that are using PySimpleGUI that wanted to financially support the project a "Support" Button was added to the GitHub site.  This support button is connected with a PayPal account.  If you wish to help support this currently freely supplied software and free technical support, then follow this link: www.paypal.me/psgui .  | ||||||
| 
 | 
 | ||||||
| To be clear, this is not a solicitation for your money.  No one is being directly asked to support / contribute.  The project is self-funded and there are ongoing costs just to offer the software (URLs, ReadTheDocs, etc). If you're a corporate user and find that PySimpleGUI is helping you financially, that's awesome.  If you want to help ensure PySimpleGUI has a future, you now have that option to help.  It's likely that at some point the costs will become too high for the project to continue to be free, but until then we'll all enjoy the successes we're having. | To be clear, this is not a solicitation for your money.  No one is being directly asked to support / contribute.  The project is self-funded and there are ongoing costs just to offer the software (URLs, ReadTheDocs, etc). If you're a corporate user and find that PySimpleGUI is helping you financially, that's awesome.  If you want to help ensure PySimpleGUI has a future, you now have that option to help.  It's likely that at some point the costs will become too high for the project to continue to be free, but until then we'll all enjoy the successes we're having. | ||||||
|  | 
 | ||||||
|  | ## Legal | ||||||
|  | 
 | ||||||
|  | All documentation in this file and in the PySimpleGUI GitHub account are copyright 2021 by PySimpleGUI Inc.  The PySimpleGUI code, the demo programs and other source code in the PySimpleGUI account also have a copyright owned by PySimpleGUI Inc. | ||||||
|  | 
 | ||||||
|  | The name "PySimpleGUI" and the PySimpleGUI logo are Trademarked | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue