commit
0bcd985997
|
@ -1,48 +1,12 @@
|
||||||
#!/usr/bin/python3
|
#!/usr/bin/python3
|
||||||
|
|
||||||
|
|
||||||
version = __version__ = "4.51.7.11 Unreleased"
|
version = __version__ = "4.53.0 Released 24-Oct-2021"
|
||||||
|
|
||||||
_change_log = """
|
_change_log = """
|
||||||
|
|
||||||
Changelog since 4.51.6 released to PyPI on 21-Oct-2021
|
Changelog since 4.53.0 released to PyPI on 24-Oct-2021
|
||||||
|
|
||||||
4.51.4.1
|
|
||||||
Support for making the command-line tools available after upgrade from GitHub.
|
|
||||||
4.51.4.2
|
|
||||||
Removed popup_scrolled from the upgrade from github code. Looks like setup.py file is fine
|
|
||||||
4.51.4.3
|
|
||||||
Fix in the upgrade from GitHub code.
|
|
||||||
4.51.6.1
|
|
||||||
Bumped version to match the pypi release
|
|
||||||
4.51.6.2
|
|
||||||
Fix bug for grab anywhere enabled with grab anywhere using control key
|
|
||||||
Wasn't ignoring the widgets that shouldn't move winow using grab anywhere
|
|
||||||
4.51.6.3
|
|
||||||
New BLANK_BASE64 definition that's shorter. Should still be 1 x 1 pixel and clear
|
|
||||||
New logic in the Image.update() when no paramters passed. This is how an image is "erased"
|
|
||||||
Now the image is rewsized to 1x1 pixel prior to deleting.
|
|
||||||
Setting the border depth = 0 on the Label holding image for Image element. Leaves a lot LESS space when no image is present
|
|
||||||
FIXED setting a size on Frame Elements. It's not worked previously, but THINK it does now! (insert fingers crossed emoji here)
|
|
||||||
4.51.6.4
|
|
||||||
Added dpi_awareness option to set_options as an experiment
|
|
||||||
Added scaling parameter to Window and to set_options for global scaling
|
|
||||||
4.51.6.5
|
|
||||||
Changed how the GitHub upgrades happen when using the psgupgrade.exe command.
|
|
||||||
4.51.7.5
|
|
||||||
Version number bump so that the pip install from github will be greater than the current pypi 4.51.7
|
|
||||||
4.51.7.6
|
|
||||||
Subprocess import changed for 3.4 compatibility... yes, PySimpleGUI is STILL 3.4 compatible
|
|
||||||
4.51.7.7
|
|
||||||
Changed "main" entry point for the psgmain command so that if an upgrade is attempted it will work correctly (the psgmain.exe will have exited)
|
|
||||||
4.51.7.8
|
|
||||||
Version bump to get pip to install yet again from GitHub
|
|
||||||
4.51.7.9
|
|
||||||
MAIN instea of MEIN (oy! When am I going to get this release out???)
|
|
||||||
4.51.7.10
|
|
||||||
Better description of the main restart as to not be alarming...
|
|
||||||
4.51.7.11
|
|
||||||
Refresh the PySimpleGUI settings in all exec calls in case settings changed in another program
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
__version__ = version.split()[0] # For PEP 396 and PEP 345
|
__version__ = version.split()[0] # For PEP 396 and PEP 345
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -9267,6 +9267,58 @@ Column Element allow None for 1 size direction
|
||||||
* Very useful for multi-window applications
|
* Very useful for multi-window applications
|
||||||
* Also works when you've set a default window location using the `set_options` call.
|
* Also works when you've set a default window location using the `set_options` call.
|
||||||
|
|
||||||
|
## 4.51.2 - 4.41.7
|
||||||
|
|
||||||
|
A series of dot releases to make the psg commands operational for upgrading, etc. Was a bit of a mess for a week
|
||||||
|
|
||||||
|
## 4.52.0 - A deleted release that instead fell back to 4.51.* dot releases
|
||||||
|
|
||||||
|
## 4.53.0 PySimpleGUI 24-Oct-2021
|
||||||
|
|
||||||
|
The "Mike's really excited about this release!" release
|
||||||
|
|
||||||
|
psg commands!
|
||||||
|
psgmain
|
||||||
|
psgupgrade
|
||||||
|
psghelp
|
||||||
|
psgver
|
||||||
|
psgsettings
|
||||||
|
Control Click window movement
|
||||||
|
Frame Elements with `size` parameter
|
||||||
|
|
||||||
|
I really like this release. It pulls together a ***lot*** of work over the past week. It fixes some things that have bothered me for a long time and adds support for some things that have bothered users for a long time.... so here we go....
|
||||||
|
|
||||||
|
* Added Commands that you can type or make shortcuts to
|
||||||
|
* psgmain - Runs the sg.main() test harness. Your gateway to settings, version info, etc
|
||||||
|
* psgupgrade - Upgrades PySimpleGUI to the latest version on ***GitHub***
|
||||||
|
* psghelp - view the SDK help window
|
||||||
|
* psgver - view the version numbers
|
||||||
|
* psgsettings - access the settings window (usually done via the main window)
|
||||||
|
* Don't forget to use `sudo` if you're upgrading on Linux!
|
||||||
|
* Control Key Dragging - move ***any*** PySimpleGUI window by holding down control key while holding the left mouse button down. Ignores the usual Grab Anywhere restrictions and allows dragging over Multiline elements for example
|
||||||
|
* A new, shorter, version of the 1x1 pixel BLANK_BASE64 image
|
||||||
|
* Image Element
|
||||||
|
* New logic for the `Image.update()` (with no parms). This will delete an image and now will also shrink down to 1 pixel
|
||||||
|
* Set border width to 0 so that takes up even less space when empty
|
||||||
|
* Frame Element
|
||||||
|
* Can now use the `size` parameter to create a fixed size Frame
|
||||||
|
* `element_justification` behaves properly - consider using a `Frame` with border width=0 and no text instead of a `Column` element if you need both a hard coded size and to justify the elements inside
|
||||||
|
* `set_options`
|
||||||
|
* Added `dpi_awareness` setting to turn on DPI Awareness (currently only on Windows)
|
||||||
|
* Added `scaling` parameter for system-wide Window scaling
|
||||||
|
* `Window`
|
||||||
|
* Added `scaling` parameter - will scale the contents of the window. Takes a float value
|
||||||
|
* If need scaling for **all windows** then set using the `set_options` call
|
||||||
|
* Better 3.4 compatibility
|
||||||
|
* Previously has issues with subprocesses
|
||||||
|
* Upgrade to GitHub version now works
|
||||||
|
* The new psgcommands to work too so all you 3.4, 3.5 users out there aren't left behind!
|
||||||
|
* The PySimpleGUI Tent was built to be big and has plans on staying that way
|
||||||
|
* Exec APIs - improved ability to modify interpreter to use in other programs so that your program will then pick up the latest changes
|
||||||
|
* Testing more thoroughly 3.4, 3.6, 3.7, 3.8, 3.9, 3.10 and tkinter 8.6.2 through 8.6.10
|
||||||
|
* Doc updates to the Call Reference doc - Added `Sizer` element and reorganizing a bit.
|
||||||
|
* Special thanks to Jason for providing amazing support to the PySimpleGUI users. If you think PySimpleGUI is great... if you really want to see something impressive, try logging an issue on the GitHub and watch Jason do his thing.
|
||||||
|
|
||||||
## Code Condition
|
## Code Condition
|
||||||
|
|
||||||
Make it run
|
Make it run
|
||||||
|
|
|
@ -2234,6 +2234,60 @@ Column Element allow None for 1 size direction
|
||||||
* Very useful for multi-window applications
|
* Very useful for multi-window applications
|
||||||
* Also works when you've set a default window location using the `set_options` call.
|
* Also works when you've set a default window location using the `set_options` call.
|
||||||
|
|
||||||
|
## 4.51.2 - 4.41.7
|
||||||
|
|
||||||
|
A series of dot releases to make the psg commands operational for upgrading, etc. Was a bit of a mess for a week
|
||||||
|
|
||||||
|
## 4.52.0 - A deleted release that instead fell back to 4.51.* dot releases
|
||||||
|
|
||||||
|
## 4.53.0 PySimpleGUI 24-Oct-2021
|
||||||
|
|
||||||
|
The "Mike's really excited about this release!" release
|
||||||
|
|
||||||
|
psg commands!
|
||||||
|
psgmain
|
||||||
|
psgupgrade
|
||||||
|
psghelp
|
||||||
|
psgver
|
||||||
|
psgsettings
|
||||||
|
Control Click window movement
|
||||||
|
Frame Elements with `size` parameter
|
||||||
|
|
||||||
|
I really like this release. It pulls together a ***lot*** of work over the past week. It fixes some things that have bothered me for a long time and adds support for some things that have bothered users for a long time.... so here we go....
|
||||||
|
|
||||||
|
|
||||||
|
* Added Commands that you can type or make shortcuts to
|
||||||
|
* psgmain - Runs the sg.main() test harness. Your gateway to settings, version info, etc
|
||||||
|
* psgupgrade - Upgrades PySimpleGUI to the latest version on ***GitHub***
|
||||||
|
* psghelp - view the SDK help window
|
||||||
|
* psgver - view the version numbers
|
||||||
|
* psgsettings - access the settings window (usually done via the main window)
|
||||||
|
* Don't forget to use `sudo` if you're upgrading on Linux!
|
||||||
|
* Control Key Dragging - move ***any*** PySimpleGUI window by holding down control key while holding the left mouse button down. Ignores the usual Grab Anywhere restrictions and allows dragging over Multiline elements for example
|
||||||
|
* A new, shorter, version of the 1x1 pixel BLANK_BASE64 image
|
||||||
|
* Image Element
|
||||||
|
* New logic for the `Image.update()` (with no parms). This will delete an image and now will also shrink down to 1 pixel
|
||||||
|
* Set border width to 0 so that takes up even less space when empty
|
||||||
|
* Frame Element
|
||||||
|
* Can now use the `size` parameter to create a fixed size Frame
|
||||||
|
* `element_justification` behaves properly - consider using a `Frame` with border width=0 and no text instead of a `Column` element if you need both a hard coded size and to justify the elements inside
|
||||||
|
* `set_options`
|
||||||
|
* Added `dpi_awareness` setting to turn on DPI Awareness (currently only on Windows)
|
||||||
|
* Added `scaling` parameter for system-wide Window scaling
|
||||||
|
* `Window`
|
||||||
|
* Added `scaling` parameter - will scale the contents of the window. Takes a float value
|
||||||
|
* If need scaling for **all windows** then set using the `set_options` call
|
||||||
|
* Better 3.4 compatibility
|
||||||
|
* Previously has issues with subprocesses
|
||||||
|
* Upgrade to GitHub version now works
|
||||||
|
* The new psgcommands to work too so all you 3.4, 3.5 users out there aren't left behind!
|
||||||
|
* The PySimpleGUI Tent was built to be big and has plans on staying that way
|
||||||
|
* Exec APIs - improved ability to modify interpreter to use in other programs so that your program will then pick up the latest changes
|
||||||
|
* Testing more thoroughly 3.4, 3.6, 3.7, 3.8, 3.9, 3.10 and tkinter 8.6.2 through 8.6.10
|
||||||
|
* Doc updates to the Call Reference doc - Added `Sizer` element and reorganizing a bit.
|
||||||
|
* Special thanks to Jason for providing amazing support to the PySimpleGUI users. If you think PySimpleGUI is great... if you really want to see something impressive, try logging an issue on the GitHub and watch Jason do his thing.
|
||||||
|
|
||||||
|
|
||||||
## Code Condition
|
## Code Condition
|
||||||
|
|
||||||
Make it run
|
Make it run
|
||||||
|
|
|
@ -32,8 +32,7 @@ The PySimpleGUIQt call reference is located in another location.
|
||||||
|
|
||||||
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.
|
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 class, and all functions
|
# The Elements
|
||||||
|
|
||||||
---------
|
---------
|
||||||
|
|
||||||
## Button Element
|
## Button Element
|
||||||
|
@ -1596,6 +1595,18 @@ The following methods are here for backwards compatibility reference. You will
|
||||||
### UpdateBar
|
### UpdateBar
|
||||||
<!-- <+ProgressBar.UpdateBar+> -->
|
<!-- <+ProgressBar.UpdateBar+> -->
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
------------------
|
||||||
|
|
||||||
|
## Push Element (alias include `P` and `Stretch`)
|
||||||
|
|
||||||
|
Not a true element, but a function acting like an element.
|
||||||
|
|
||||||
|
A `Push` element will "push" elements on the row away from it. If you have 1 `Push` as the start of a row, then the row will be right-justified. If you have two `Push` elements, one as the first element and one as the last element on a row, then the row will be centered.
|
||||||
|
|
||||||
|
<!-- <+func.Push+> -->
|
||||||
|
|
||||||
---------
|
---------
|
||||||
|
|
||||||
|
|
||||||
|
@ -1684,6 +1695,15 @@ The following methods are here for backwards compatibility reference. You will
|
||||||
|
|
||||||
---------
|
---------
|
||||||
|
|
||||||
|
## Sizer Element
|
||||||
|
|
||||||
|
Note that while the Sizer is an element, it is implemented using a function and doesn't have the normal set of element methods.
|
||||||
|
|
||||||
|
This element is used to add more space.... more size...to a Container Element or a Window. They are often better to use than hard-coded sizes on the containers typically.
|
||||||
|
|
||||||
|
<!-- <+func.Sizer+> -->
|
||||||
|
|
||||||
|
-------
|
||||||
|
|
||||||
## Sizegrip Element
|
## Sizegrip Element
|
||||||
<!-- <+Sizegrip.doc+> -->
|
<!-- <+Sizegrip.doc+> -->
|
||||||
|
@ -2292,8 +2312,9 @@ The following methods are here for backwards compatibility reference. You will
|
||||||
## Titlebar Element
|
## Titlebar Element
|
||||||
|
|
||||||
Note that while the Titlebar is an element, it is implemented using a function.
|
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.
|
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.
|
See the Column element to get a list of method calls available. The function returns a Column element. This type of construct is referred to as "User Defined Elements" in the documentation and tutorials.
|
||||||
|
|
||||||
<!-- <+func.Titlebar+> -->
|
<!-- <+func.Titlebar+> -->
|
||||||
|
|
||||||
|
@ -2441,99 +2462,23 @@ The following methods are here for backwards compatibility reference. You will
|
||||||
### visible
|
### visible
|
||||||
<!-- <+VerticalSeparator.visible+> -->
|
<!-- <+VerticalSeparator.visible+> -->
|
||||||
|
|
||||||
|
------------------------------
|
||||||
--------------------------------------
|
|
||||||
# The `Push` / `Stretch` Elements
|
|
||||||
|
|
||||||
These elements `Push` and `VPush` as aliases for `Stretch` and `VStretch` and are implemented using a function rather than a class. They're not meant to be manipulated like other elements. They have a functional role in a layout that is much like the "Layout Helper Functions" (pin, vtop, etc).
|
|
||||||
|
|
||||||
The name `Stretch` originally appeared in the PySimpleGUI APIs when the PySimpleGUIQt port was added.
|
|
||||||
|
|
||||||
In the Sept 2021 timeframe, a functioning version of this element appeared in the tkinter port, along with some aliases and a vertical addition.
|
|
||||||
|
|
||||||
The PySimpleGUI documentation, demos, etc, will be using the names `Push` and `VPush`.
|
|
||||||
|
|
||||||
## Push-style Elements Use
|
|
||||||
|
|
||||||
These elements modify the placement of other elements inside of containers. As the name implies, these elements `Push` and `VPush` will "push" other elements around. `Push` works in the horizontal direction, `VPush` in the vertical.
|
|
||||||
|
|
||||||
## Push Element (alias include `P` and `Stretch`)
|
|
||||||
|
|
||||||
<!-- <+func.Push+> -->
|
|
||||||
|
|
||||||
## VPush Element (aliases include `VP` and `VStretch`)
|
## VPush Element (aliases include `VP` and `VStretch`)
|
||||||
|
|
||||||
|
Like the `Push` element, this is not a true element but rather a function acting like an element. It will "Push" all elements above and below away from it.
|
||||||
|
|
||||||
|
Example: If first row has a `VPush`, then your layout will be At the bottom of the container it is in. If one is on the last row, then the layout will be at the top of the container. If you use TWO `VPush`, one on the first row and one on the last row, then your layout will be centered vertically.
|
||||||
|
|
||||||
|
|
||||||
<!-- <+func.VPush+> -->
|
<!-- <+func.VPush+> -->
|
||||||
|
|
||||||
### 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
|
|
||||||
<!-- <+VerticalSeparator.SetFocus+> -->
|
|
||||||
|
|
||||||
### SetTooltip
|
|
||||||
<!-- <+VerticalSeparator.SetTooltip+> -->
|
|
||||||
|
|
||||||
|
|
||||||
---------
|
|
||||||
|
|
||||||
|
|
||||||
## UserSettings (Class interface to User Settings APIs... can also use the function call interface)
|
|
||||||
<!-- <+UserSettings.doc+> -->
|
|
||||||
<!-- <+UserSettings.__init__+> -->
|
|
||||||
|
|
||||||
### delete_entry
|
|
||||||
<!-- <+UserSettings.delete_entry+> -->
|
|
||||||
|
|
||||||
### delete_file
|
|
||||||
<!-- <+UserSettings.delete_file+> -->
|
|
||||||
|
|
||||||
|
|
||||||
### delete_section
|
|
||||||
<!-- <+UserSettings.delete_section+> -->
|
|
||||||
|
|
||||||
|
|
||||||
### exists
|
|
||||||
<!-- <+UserSettings.exists+> -->
|
|
||||||
|
|
||||||
### get
|
|
||||||
<!-- <+UserSettings.get+> -->
|
|
||||||
|
|
||||||
### get_dict
|
|
||||||
<!-- <+UserSettings.get_dict+> -->
|
|
||||||
|
|
||||||
### get_filename
|
|
||||||
<!-- <+UserSettings.get_filename+> -->
|
|
||||||
|
|
||||||
### load
|
|
||||||
<!-- <+UserSettings.load+> -->
|
|
||||||
|
|
||||||
### read
|
|
||||||
<!-- <+UserSettings.read+> -->
|
|
||||||
|
|
||||||
### save
|
|
||||||
<!-- <+UserSettings.save+> -->
|
|
||||||
|
|
||||||
### set
|
|
||||||
<!-- <+UserSettings.set+> -->
|
|
||||||
|
|
||||||
### set_default_value
|
|
||||||
<!-- <+UserSettings.set_default_value+> -->
|
|
||||||
|
|
||||||
### set_location
|
|
||||||
<!-- <+UserSettings.set_location+> -->
|
|
||||||
|
|
||||||
### write_new_dictionary
|
|
||||||
<!-- <+UserSettings.write_new_dictionary+> -->
|
|
||||||
|
|
||||||
|
|
||||||
---------
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## Window
|
# Window - The `Window` Object
|
||||||
<!-- <+Window.doc+> -->
|
<!-- <+Window.doc+> -->
|
||||||
<!-- <+Window.__init__+> -->
|
<!-- <+Window.__init__+> -->
|
||||||
|
|
||||||
|
@ -2835,10 +2780,39 @@ The following methods are here for backwards compatibility reference. You will
|
||||||
<!-- <+Window.VisibilityChanged+> -->
|
<!-- <+Window.VisibilityChanged+> -->
|
||||||
|
|
||||||
|
|
||||||
|
--------------------------------------
|
||||||
|
|
||||||
|
## The `Push` / `Stretch` Elements
|
||||||
|
|
||||||
|
These elements `Push` and `VPush` as aliases for `Stretch` and `VStretch` and are implemented using a function rather than a class. They're not meant to be manipulated like other elements. They have a functional role in a layout that is much like the "Layout Helper Functions" (pin, vtop, etc).
|
||||||
|
|
||||||
|
The name `Stretch` originally appeared in the PySimpleGUI APIs when the PySimpleGUIQt port was added.
|
||||||
|
|
||||||
|
In the Sept 2021 timeframe, a functioning version of this element appeared in the tkinter port, along with some aliases and a vertical addition.
|
||||||
|
|
||||||
|
The PySimpleGUI documentation, demos, etc, will be using the names `Push` and `VPush`.
|
||||||
|
|
||||||
|
|
||||||
|
## Push-style Elements Use
|
||||||
|
|
||||||
|
These elements modify the placement of other elements inside of containers. As the name implies, these elements `Push` and `VPush` will "push" other elements around. `Push` works in the horizontal direction, `VPush` in the vertical.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
---------
|
---------
|
||||||
|
|
||||||
|
## Layout Helper Funcs
|
||||||
|
|
||||||
## SystemTray
|
<!-- <+func.pin+> -->
|
||||||
|
<!-- <+func.vbottom+> -->
|
||||||
|
<!-- <+func.vcenter+> -->
|
||||||
|
<!-- <+func.vtop+> -->
|
||||||
|
|
||||||
|
-----------------
|
||||||
|
|
||||||
|
|
||||||
|
## SystemTray - Only for Qt and Wx ports. Use `psgtray` package for the tkinter port
|
||||||
<!-- <+SystemTray.doc+> -->
|
<!-- <+SystemTray.doc+> -->
|
||||||
<!-- <+SystemTray.__init__+> -->
|
<!-- <+SystemTray.__init__+> -->
|
||||||
|
|
||||||
|
@ -2894,10 +2868,7 @@ The following methods are here for backwards compatibility reference. You will
|
||||||
<!-- <+SystemTray.Update+> -->
|
<!-- <+SystemTray.Update+> -->
|
||||||
|
|
||||||
|
|
||||||
## Function Reference
|
-----------
|
||||||
|
|
||||||
These are the functions available for you to call
|
|
||||||
|
|
||||||
|
|
||||||
## Version Info
|
## Version Info
|
||||||
|
|
||||||
|
@ -2909,7 +2880,7 @@ These are the functions available for you to call
|
||||||
<!-- <+func.read_all_windows+> -->
|
<!-- <+func.read_all_windows+> -->
|
||||||
|
|
||||||
|
|
||||||
## Button Related
|
## Pre-Defined Buttons (use in your layout)
|
||||||
|
|
||||||
<!-- <+func.CalendarButton+> -->
|
<!-- <+func.CalendarButton+> -->
|
||||||
<!-- <+func.Cancel+> -->
|
<!-- <+func.Cancel+> -->
|
||||||
|
@ -2924,8 +2895,6 @@ These are the functions available for you to call
|
||||||
<!-- <+func.Help+> -->
|
<!-- <+func.Help+> -->
|
||||||
<!-- <+func.No+> -->
|
<!-- <+func.No+> -->
|
||||||
<!-- <+func.OK+> -->
|
<!-- <+func.OK+> -->
|
||||||
<!-- <+func.ObjToString+> -->
|
|
||||||
<!-- <+func.ObjToStringSingleObj+> -->
|
|
||||||
<!-- <+func.Ok+> -->
|
<!-- <+func.Ok+> -->
|
||||||
<!-- <+func.Open+> -->
|
<!-- <+func.Open+> -->
|
||||||
<!-- <+func.Quit+> -->
|
<!-- <+func.Quit+> -->
|
||||||
|
@ -2945,6 +2914,7 @@ They are shown here in case you run into them in some old code.
|
||||||
<!-- <+func.CButton+> -->
|
<!-- <+func.CButton+> -->
|
||||||
<!-- <+func.CloseButton+> -->
|
<!-- <+func.CloseButton+> -->
|
||||||
|
|
||||||
|
-----------
|
||||||
|
|
||||||
## Debug Window Output
|
## Debug Window Output
|
||||||
|
|
||||||
|
@ -2964,13 +2934,22 @@ They are shown here in case you run into them in some old code.
|
||||||
<!-- <+func.cprint+> -->
|
<!-- <+func.cprint+> -->
|
||||||
<!-- <+func.cprint_set_output_destination+> -->
|
<!-- <+func.cprint_set_output_destination+> -->
|
||||||
|
|
||||||
|
-----------
|
||||||
|
|
||||||
|
|
||||||
## One Line Progress Meter
|
## One Line Progress Meter
|
||||||
|
|
||||||
<!-- <+func.OneLineProgressMeter+> -->
|
Add a progress meter to your application by adding 1 line of code.
|
||||||
<!-- <+func.OneLineProgressMeterCancel+> -->
|
|
||||||
<!-- <+func.one_line_progress_meter+> -->
|
<!-- <+func.one_line_progress_meter+> -->
|
||||||
<!-- <+func.one_line_progress_meter_cancel+> -->
|
<!-- <+func.one_line_progress_meter_cancel+> -->
|
||||||
|
|
||||||
|
### NON-PEP8 Versions
|
||||||
|
|
||||||
|
Don't use these. They are here in case you're searching for them. Instead use the PEP8 version `one_line_progress_meter`.
|
||||||
|
|
||||||
|
<!-- <+func.OneLineProgressMeter+> -->
|
||||||
|
<!-- <+func.OneLineProgressMeterCancel+> -->
|
||||||
|
|
||||||
## Popups PEP8 Versions
|
## Popups PEP8 Versions
|
||||||
|
|
||||||
|
@ -2996,7 +2975,7 @@ They are shown here in case you run into them in some old code.
|
||||||
<!-- <+func.popup_yes_no+> -->
|
<!-- <+func.popup_yes_no+> -->
|
||||||
|
|
||||||
|
|
||||||
### Popup Alias - Same as popup_scrolled
|
### `sprint` Popup Alias - Same as popup_scrolled
|
||||||
|
|
||||||
<!-- <+func.sprint+> -->
|
<!-- <+func.sprint+> -->
|
||||||
<!-- <+func.ScrolledTextBox+> -->
|
<!-- <+func.ScrolledTextBox+> -->
|
||||||
|
@ -3033,9 +3012,7 @@ These versions of the popup functions are here only for backwards compatibility.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## PEP8 Function Bindings
|
## Display Objects as Strings
|
||||||
|
|
||||||
## 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.
|
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.
|
||||||
|
|
||||||
|
@ -3043,7 +3020,7 @@ These functions will return an object as a string that shows each of the object'
|
||||||
<!-- <+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 PySimpleGUI 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.
|
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.
|
||||||
|
|
||||||
|
@ -3051,6 +3028,8 @@ Used to get SDK help, test the installation, get information about the versions,
|
||||||
|
|
||||||
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.
|
||||||
|
|
||||||
|
You can also type `psgmain` from the command line to access it if you have pip installed your copy of PySimpleGUI.
|
||||||
|
|
||||||
<!-- <+func.main+> -->
|
<!-- <+func.main+> -->
|
||||||
<!-- <+func.main_get_debug_data+> -->
|
<!-- <+func.main_get_debug_data+> -->
|
||||||
<!-- <+func.main_global_pysimplegui_settings+> -->
|
<!-- <+func.main_global_pysimplegui_settings+> -->
|
||||||
|
@ -3063,10 +3042,12 @@ You can call main() from your code and then access these other features such as
|
||||||
<!-- <+func.show_debugger_popout_window+> -->
|
<!-- <+func.show_debugger_popout_window+> -->
|
||||||
<!-- <+func.show_debugger_window+> -->
|
<!-- <+func.show_debugger_window+> -->
|
||||||
|
|
||||||
|
-------------
|
||||||
|
|
||||||
## Themes
|
## Themes
|
||||||
|
|
||||||
|
The way to get Windows that have elements that have matching colors.
|
||||||
|
|
||||||
<!-- <+func.theme+> -->
|
<!-- <+func.theme+> -->
|
||||||
<!-- <+func.theme_add_new+> -->
|
<!-- <+func.theme_add_new+> -->
|
||||||
<!-- <+func.theme_background_color+> -->
|
<!-- <+func.theme_background_color+> -->
|
||||||
|
@ -3087,6 +3068,7 @@ You can call main() from your code and then access these other features such as
|
||||||
<!-- <+func.theme_text_color+> -->
|
<!-- <+func.theme_text_color+> -->
|
||||||
<!-- <+func.theme_text_element_background_color+> -->
|
<!-- <+func.theme_text_element_background_color+> -->
|
||||||
|
|
||||||
|
--------------------
|
||||||
|
|
||||||
## Platform Checks
|
## Platform Checks
|
||||||
|
|
||||||
|
@ -3098,12 +3080,68 @@ These are simple functions you can use that return a boolean True if sys.platfo
|
||||||
<!-- <+func.running_windows+> -->
|
<!-- <+func.running_windows+> -->
|
||||||
|
|
||||||
|
|
||||||
|
------------------------
|
||||||
|
|
||||||
## User Settings
|
|
||||||
|
|
||||||
In addition to user settings files, there is also a global PySimpleGUI settings file.
|
## UserSettings API - Class Interface
|
||||||
|
|
||||||
You can directly access the global settings through the UserSettings object: `pysimplegui_user_settings`
|
The User Settings API is used to store your settings information from one session to another or from one program to another. They are stored on disk in either JSON or INI file formats.
|
||||||
|
|
||||||
|
In addition to user settings files, there is also a global PySimpleGUI settings file that PySimpleGUI uses to store information about the default Python interpreter you want to use with the Exec APIs, the default theme. You can directly access the global settings through the UserSettings object: `pysimplegui_user_settings`
|
||||||
|
|
||||||
|
<!-- <+UserSettings.doc+> -->
|
||||||
|
<!-- <+UserSettings.__init__+> -->
|
||||||
|
|
||||||
|
### delete_entry
|
||||||
|
<!-- <+UserSettings.delete_entry+> -->
|
||||||
|
|
||||||
|
### delete_file
|
||||||
|
<!-- <+UserSettings.delete_file+> -->
|
||||||
|
|
||||||
|
|
||||||
|
### delete_section
|
||||||
|
<!-- <+UserSettings.delete_section+> -->
|
||||||
|
|
||||||
|
|
||||||
|
### exists
|
||||||
|
<!-- <+UserSettings.exists+> -->
|
||||||
|
|
||||||
|
### get
|
||||||
|
<!-- <+UserSettings.get+> -->
|
||||||
|
|
||||||
|
### get_dict
|
||||||
|
<!-- <+UserSettings.get_dict+> -->
|
||||||
|
|
||||||
|
### get_filename
|
||||||
|
<!-- <+UserSettings.get_filename+> -->
|
||||||
|
|
||||||
|
### load
|
||||||
|
<!-- <+UserSettings.load+> -->
|
||||||
|
|
||||||
|
### read
|
||||||
|
<!-- <+UserSettings.read+> -->
|
||||||
|
|
||||||
|
### save
|
||||||
|
<!-- <+UserSettings.save+> -->
|
||||||
|
|
||||||
|
### set
|
||||||
|
<!-- <+UserSettings.set+> -->
|
||||||
|
|
||||||
|
### set_default_value
|
||||||
|
<!-- <+UserSettings.set_default_value+> -->
|
||||||
|
|
||||||
|
### set_location
|
||||||
|
<!-- <+UserSettings.set_location+> -->
|
||||||
|
|
||||||
|
### write_new_dictionary
|
||||||
|
<!-- <+UserSettings.write_new_dictionary+> -->
|
||||||
|
|
||||||
|
|
||||||
|
## User Settings API - Function Interface
|
||||||
|
|
||||||
|
You have a couple of ways to access User Settings if your information is stored in JSON format. If you're using the INI format, then you must use the `UserSettings` object.
|
||||||
|
|
||||||
|
These are particularly useful directly in layouts, allowing you to you can easily set default values.
|
||||||
|
|
||||||
<!-- <+func.user_settings+> -->
|
<!-- <+func.user_settings+> -->
|
||||||
<!-- <+func.user_settings_delete_entry+> -->
|
<!-- <+func.user_settings_delete_entry+> -->
|
||||||
|
@ -3117,9 +3155,11 @@ You can directly access the global settings through the UserSettings object: `py
|
||||||
<!-- <+func.user_settings_silent_on_error+> -->
|
<!-- <+func.user_settings_silent_on_error+> -->
|
||||||
<!-- <+func.user_settings_write_new_dictionary+> -->
|
<!-- <+func.user_settings_write_new_dictionary+> -->
|
||||||
|
|
||||||
## Exec APIs
|
-----------------
|
||||||
|
|
||||||
These API calls are used to launch subprocesses.
|
## Exec APIs - Launching Subprocesses
|
||||||
|
|
||||||
|
These API calls are used to launch subprocesses. You can launch Python files or any type of executable file. In these calls is where you invoke the editor and file explorer that was specified in the PySimpleGUI Global Settings.
|
||||||
|
|
||||||
<!-- <+func.execute_command_subprocess+> -->
|
<!-- <+func.execute_command_subprocess+> -->
|
||||||
<!-- <+func.execute_editor+> -->
|
<!-- <+func.execute_editor+> -->
|
||||||
|
@ -3129,6 +3169,8 @@ These API calls are used to launch subprocesses.
|
||||||
<!-- <+func.execute_py_file+> -->
|
<!-- <+func.execute_py_file+> -->
|
||||||
<!-- <+func.execute_subprocess_still_running+> -->
|
<!-- <+func.execute_subprocess_still_running+> -->
|
||||||
|
|
||||||
|
------------
|
||||||
|
|
||||||
## Clipboard APIs
|
## 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.
|
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.
|
||||||
|
@ -3143,15 +3185,9 @@ Note that this clipboard uses tkinter's clipboard. There is a known limitation t
|
||||||
<!-- <+func.FillFormWithValues+> -->
|
<!-- <+func.FillFormWithValues+> -->
|
||||||
|
|
||||||
|
|
||||||
## Layout Helper Funcs
|
|
||||||
|
|
||||||
<!-- <+func.pin+> -->
|
|
||||||
<!-- <+func.vbottom+> -->
|
|
||||||
<!-- <+func.vcenter+> -->
|
|
||||||
<!-- <+func.vtop+> -->
|
|
||||||
|
|
||||||
|
|
||||||
## Configuration / Settings / Extensions
|
## Application-wide Configuration / Settings (`set_options`, etc)
|
||||||
|
|
||||||
<!-- <+func.get_globals+> -->
|
<!-- <+func.get_globals+> -->
|
||||||
<!-- <+func.set_global_icon+> -->
|
<!-- <+func.set_global_icon+> -->
|
||||||
|
@ -3177,8 +3213,10 @@ You should NOT use these calls. They are here for your reference should you run
|
||||||
|
|
||||||
-------------
|
-------------
|
||||||
|
|
||||||
This documentation is copyright 2021 by PySimpleGUI Inc
|
This documentation is copyright 2021 by PySimpleGUI(tm)
|
||||||
|
|
||||||
Republishing the copyrighted PySimpleGUI documentation and selling it are not allowed.
|
The PySimpleGUI name and logo are trademarked. Use without permission is prohibited.
|
||||||
|
|
||||||
When in doubt, ask.
|
Republishing the copyrighted PySimpleGUI documentation and selling it ***IS PROHIBITED***.
|
||||||
|
|
||||||
|
***When in doubt, ask.***
|
File diff suppressed because it is too large
Load Diff
|
@ -9267,6 +9267,58 @@ Column Element allow None for 1 size direction
|
||||||
* Very useful for multi-window applications
|
* Very useful for multi-window applications
|
||||||
* Also works when you've set a default window location using the `set_options` call.
|
* Also works when you've set a default window location using the `set_options` call.
|
||||||
|
|
||||||
|
## 4.51.2 - 4.41.7
|
||||||
|
|
||||||
|
A series of dot releases to make the psg commands operational for upgrading, etc. Was a bit of a mess for a week
|
||||||
|
|
||||||
|
## 4.52.0 - A deleted release that instead fell back to 4.51.* dot releases
|
||||||
|
|
||||||
|
## 4.53.0 PySimpleGUI 24-Oct-2021
|
||||||
|
|
||||||
|
The "Mike's really excited about this release!" release
|
||||||
|
|
||||||
|
psg commands!
|
||||||
|
psgmain
|
||||||
|
psgupgrade
|
||||||
|
psghelp
|
||||||
|
psgver
|
||||||
|
psgsettings
|
||||||
|
Control Click window movement
|
||||||
|
Frame Elements with `size` parameter
|
||||||
|
|
||||||
|
I really like this release. It pulls together a ***lot*** of work over the past week. It fixes some things that have bothered me for a long time and adds support for some things that have bothered users for a long time.... so here we go....
|
||||||
|
|
||||||
|
* Added Commands that you can type or make shortcuts to
|
||||||
|
* psgmain - Runs the sg.main() test harness. Your gateway to settings, version info, etc
|
||||||
|
* psgupgrade - Upgrades PySimpleGUI to the latest version on ***GitHub***
|
||||||
|
* psghelp - view the SDK help window
|
||||||
|
* psgver - view the version numbers
|
||||||
|
* psgsettings - access the settings window (usually done via the main window)
|
||||||
|
* Don't forget to use `sudo` if you're upgrading on Linux!
|
||||||
|
* Control Key Dragging - move ***any*** PySimpleGUI window by holding down control key while holding the left mouse button down. Ignores the usual Grab Anywhere restrictions and allows dragging over Multiline elements for example
|
||||||
|
* A new, shorter, version of the 1x1 pixel BLANK_BASE64 image
|
||||||
|
* Image Element
|
||||||
|
* New logic for the `Image.update()` (with no parms). This will delete an image and now will also shrink down to 1 pixel
|
||||||
|
* Set border width to 0 so that takes up even less space when empty
|
||||||
|
* Frame Element
|
||||||
|
* Can now use the `size` parameter to create a fixed size Frame
|
||||||
|
* `element_justification` behaves properly - consider using a `Frame` with border width=0 and no text instead of a `Column` element if you need both a hard coded size and to justify the elements inside
|
||||||
|
* `set_options`
|
||||||
|
* Added `dpi_awareness` setting to turn on DPI Awareness (currently only on Windows)
|
||||||
|
* Added `scaling` parameter for system-wide Window scaling
|
||||||
|
* `Window`
|
||||||
|
* Added `scaling` parameter - will scale the contents of the window. Takes a float value
|
||||||
|
* If need scaling for **all windows** then set using the `set_options` call
|
||||||
|
* Better 3.4 compatibility
|
||||||
|
* Previously has issues with subprocesses
|
||||||
|
* Upgrade to GitHub version now works
|
||||||
|
* The new psgcommands to work too so all you 3.4, 3.5 users out there aren't left behind!
|
||||||
|
* The PySimpleGUI Tent was built to be big and has plans on staying that way
|
||||||
|
* Exec APIs - improved ability to modify interpreter to use in other programs so that your program will then pick up the latest changes
|
||||||
|
* Testing more thoroughly 3.4, 3.6, 3.7, 3.8, 3.9, 3.10 and tkinter 8.6.2 through 8.6.10
|
||||||
|
* Doc updates to the Call Reference doc - Added `Sizer` element and reorganizing a bit.
|
||||||
|
* Special thanks to Jason for providing amazing support to the PySimpleGUI users. If you think PySimpleGUI is great... if you really want to see something impressive, try logging an issue on the GitHub and watch Jason do his thing.
|
||||||
|
|
||||||
## Code Condition
|
## Code Condition
|
||||||
|
|
||||||
Make it run
|
Make it run
|
||||||
|
|
Loading…
Reference in New Issue