RELEASE 2.6

This commit is contained in:
MikeTheWatchGuy 2018-07-27 15:52:59 -04:00
parent 2c0afe8fb8
commit 05caecc600
1 changed files with 34 additions and 8 deletions

View File

@ -3,7 +3,7 @@
[![Downloads](http://pepy.tech/badge/pysimplegui)](http://pepy.tech/project/pysimplegui) since Jul 11, 2018 [![Downloads](http://pepy.tech/badge/pysimplegui)](http://pepy.tech/project/pysimplegui) since Jul 11, 2018
# PySimpleGUI # PySimpleGUI
(Ver 2.5) (Ver 2.6)
Super-simple GUI to grasp... Powerfully customizable. Super-simple GUI to grasp... Powerfully customizable.
@ -22,7 +22,7 @@ Looking to take your Python code from the world of command lines and into the co
Perhaps you're looking for a way to interact with your Raspberry Pi in a more friendly way. The is the same form as above, except shown on a Pi. Perhaps you're looking for a way to interact with your Raspberry Pi in a more friendly way. The is the same form as above, except shown on a Pi.
![snap0153](https://user-images.githubusercontent.com/13696193/43261051-5838b356-90a9-11e8-96cc-e8a4860d0464.jpg) ![raspberry pi](https://user-images.githubusercontent.com/13696193/43298356-9cfe9008-9123-11e8-9612-14649a2f6c7f.jpg)
In addition to a primary GUI, you can add a Progress Meter to your code with ONE LINE of code. Slide this into any of your `for` loops and get a nice meter like this: In addition to a primary GUI, you can add a Progress Meter to your code with ONE LINE of code. Slide this into any of your `for` loops and get a nice meter like this:
@ -494,7 +494,8 @@ This is the definition of the FlexForm object:
def FlexForm(title, def FlexForm(title,
default_element_size=(DEFAULT_ELEMENT_SIZE[0], DEFAULT_ELEMENT_SIZE[1]), default_element_size=(DEFAULT_ELEMENT_SIZE[0], DEFAULT_ELEMENT_SIZE[1]),
auto_size_text=DEFAULT_AUTOSIZE_TEXT, auto_size_text=None,
auto_size_buttons=None,
scale=(None, None), scale=(None, None),
location=(None, None), location=(None, None),
button_color=None,Font=None, button_color=None,Font=None,
@ -508,7 +509,8 @@ This is the definition of the FlexForm object:
Parameter Descriptions. You will find these same parameters specified for each `Element` and some of them in `Row` specifications. The `Element` specified value will take precedence over the `Row` and `Form` values. Parameter Descriptions. You will find these same parameters specified for each `Element` and some of them in `Row` specifications. The `Element` specified value will take precedence over the `Row` and `Form` values.
default_element_size - Size of elements in form in characters (width, height) default_element_size - Size of elements in form in characters (width, height)
auto_size_text - Bool. True is elements should size themselves according to contents auto_size_text - Bool. True if elements should size themselves according to contents
auto_size_buttons - Bool. True if button elements should size themselves according to their text label
scale - Set size of element to be a multiple of the Element size scale - Set size of element to be a multiple of the Element size
location - Location to place window in pixels location - Location to place window in pixels
button_color - Default color for buttons (foreground, background). Can be text or hex button_color - Default color for buttons (foreground, background). Can be text or hex
@ -868,7 +870,7 @@ While it's possible to build forms using the Button Element directly, you should
SimpleButton(text, SimpleButton(text,
scale=(None, None), scale=(None, None),
size=(None, None), size=(None, None),
auto_size_text=None, auto_size_button=None,
button_color=None, button_color=None,
font=None) font=None)
@ -906,13 +908,13 @@ The code for the entire form could be:
[SG.FolderBrowse(Target=(-1,0)), SG.OK()]] [SG.FolderBrowse(Target=(-1,0)), SG.OK()]]
**Custom Buttons** **Custom Buttons**
If you want to define your own button, you will generally do this with the Button Element `SimpleButton`. Not all buttons are created equal. A button that closes a form is different that a button that returns from the form without closing it. If you want to define your own button, you will generally do this with the Button Element `SimpleButton`, which closes the form when clicked.
layout = [[SG.SimpleButton('My Button')]] layout = [[SG.SimpleButton('My Button')]]
![singlebutton](https://user-images.githubusercontent.com/13696193/42718281-9453deca-86d5-11e8-83c7-4b6d33720858.jpg) ![singlebutton](https://user-images.githubusercontent.com/13696193/42718281-9453deca-86d5-11e8-83c7-4b6d33720858.jpg)
All buttons can have their text changed by changing the `button_text` variable. All buttons can have their text changed by changing the `button_text` variable in the button call. It is this text that is returned when a form is read. This text will be what tells you which button is called so make it unique. Most of the convenience buttons (Submit, Cancel, Yes, etc) are all SimpleButtons. The two that are not are `FileBrowse` and `FolderBrowse`. They clearly do not close the form. Instead they bring up a file or folder browser dialog box.
**Button Images** **Button Images**
Now this is an exciting feature not found in many simplified packages.... images on buttons! You can make a pretty spiffy user interface with the help of a few button images. Now this is an exciting feature not found in many simplified packages.... images on buttons! You can make a pretty spiffy user interface with the help of a few button images.
@ -932,6 +934,7 @@ Three parameters are used for button images.
image_subsample - Amount to divide the size by. 2 means your image will be 1/2 the size. 3 means 1/3 image_subsample - Amount to divide the size by. 2 means your image will be 1/2 the size. 3 means 1/3
Here's an example form made with button images. Here's an example form made with button images.
![media file player](https://user-images.githubusercontent.com/13696193/43161977-9ee7cace-8f57-11e8-8ff8-3ea24b69dab9.jpg) ![media file player](https://user-images.githubusercontent.com/13696193/43161977-9ee7cace-8f57-11e8-8ff8-3ea24b69dab9.jpg)
You'll find the source code in the file Demo Media Player. Here is what the button calls look like to create media player form You'll find the source code in the file Demo Media Player. Here is what the button calls look like to create media player form
@ -1080,6 +1083,7 @@ Let's have some fun customizing! Make PySimpleGUI look the way you want it to l
margins=(None,None), margins=(None,None),
element_padding=(None,None) element_padding=(None,None)
auto_size_text=None auto_size_text=None
auto_size_buttons=None
font=None font=None
border_width=None border_width=None
slider_border_width=None slider_border_width=None
@ -1108,6 +1112,7 @@ Explanation of parameters
margins - tkinter margins around outsize margins - tkinter margins around outsize
element_padding - tkinter padding around each element element_padding - tkinter padding around each element
auto_size_text - autosize the elements to fit their text auto_size_text - autosize the elements to fit their text
auto_size_buttons - autosize the buttons to fit their text
font - font used for elements font - font used for elements
border_width - amount of bezel or border around sunken or raised elements border_width - amount of bezel or border around sunken or raised elements
slider_border_width - changes the way sliders look slider_border_width - changes the way sliders look
@ -1307,6 +1312,7 @@ A MikeTheWatchGuy production... entirely responsible for this code.... unless it
| 2.3.0 | July 23, 2018 - Changed form.Read return codes, Slider Elements, Listbox element. Renamed some methods but left legacy calls in place for now. | 2.3.0 | July 23, 2018 - Changed form.Read return codes, Slider Elements, Listbox element. Renamed some methods but left legacy calls in place for now.
| 2.4.0 | July 24, 2018 - Button images. Fixes so can run on Raspberry Pi | 2.4.0 | July 24, 2018 - Button images. Fixes so can run on Raspberry Pi
| 2.5.0 | July 26, 2018 - Colors. Listbox scrollbar. tkinter Progress Bar instead of homegrown. | 2.5.0 | July 26, 2018 - Colors. Listbox scrollbar. tkinter Progress Bar instead of homegrown.
| 2.6.0 | July 27, 2018 - auto_size_button setting. License changed to LGPL 3+
### Release Notes ### Release Notes
2.3 - Sliders, Listbox's and Image elements (oh my!) 2.3 - Sliders, Listbox's and Image elements (oh my!)
@ -1322,6 +1328,8 @@ Listboxes are still without scrollwheels. The mouse can drag to see more items.
### Upcoming ### Upcoming
Make suggestions people! Future release features Make suggestions people! Future release features
Auto Sized Buttons - Rather than using the default setting for TEXT fields, broke out button sizing into it's own setting. Makes much more sense. Reduces the amount of code.
Columns. How multiple columns would be specified in the SDK interface are still being designed. Columns. How multiple columns would be specified in the SDK interface are still being designed.
@ -1338,12 +1346,30 @@ While the internals to PySimpleGUI are a tad sketchy, the public interfaces into
Please log bugs and suggestions in the GitHub! It will only make the code stronger and better in the end, a good thing for us all, right? Please log bugs and suggestions in the GitHub! It will only make the code stronger and better in the end, a good thing for us all, right?
## Design
A moment about the design-spirit of `PySimpleGUI`. From the beginning, this package was meant to take advantage of Python's capabilities with the goal of programming ease.
**Single File**
While not the best programming practice, the implementation resulted in a single file solution. Only one file is needed, PySimpleGUI.py. You can post this file, email it, and easily import it using one statement.
**Functions as objects**
In Python, functions behave just like classes. When you're placing a Text Element into your form, you may be sometimes calling a function and other times declaring an object. If you use the word Text, then you're getting an object. If you're using `Txt`, then you're calling a function that returns a `Text` object.
**Lists**
It seemed quite natural to use Python's powerful list constructs when possible.
## Authors ## Authors
MikeTheWatchGuy MikeTheWatchGuy
## License ## License
GNU Lesser General Public License (LGPL 3) GNU Lesser General Public License (LGPL 3) +
## Acknowledgments ## Acknowledgments