Merge pull request #1358 from PySimpleGUI/Dev-latest

Removed use of .Layout. Moved layout to inside of Window call.
This commit is contained in:
MikeTheWatchGuy 2019-05-01 10:36:03 -04:00 committed by GitHub
commit bc7ce8e527
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 25 additions and 25 deletions

View File

@ -50,7 +50,7 @@ layout = [[sg.Text('My one-shot window.')],
[sg.InputText()], [sg.InputText()],
[sg.Submit(), sg.Cancel()]] [sg.Submit(), sg.Cancel()]]
window = sg.Window('Window Title').Layout(layout) window = sg.Window('Window Title', layout)
event, values = window.Read() event, values = window.Read()
window.Close() window.Close()
@ -77,7 +77,7 @@ layout = [[sg.Text('Persistent window')],
[sg.Input(do_not_clear=True)], [sg.Input(do_not_clear=True)],
[sg.Button('Read'), sg.Exit()]] [sg.Button('Read'), sg.Exit()]]
window = sg.Window('Window that stays open').Layout(layout) window = sg.Window('Window that stays open', layout)
while True: while True:
event, values = window.Read() event, values = window.Read()
@ -111,7 +111,7 @@ layout = [[sg.Text('Your typed chars appear here:'), sg.Text('', key='_OUTPUT_')
[sg.Input(do_not_clear=True, key='_IN_')], [sg.Input(do_not_clear=True, key='_IN_')],
[sg.Button('Show'), sg.Button('Exit')]] [sg.Button('Show'), sg.Button('Exit')]]
window = sg.Window('Window Title').Layout(layout) window = sg.Window('Window Title', layout)
while True: # Event Loop while True: # Event Loop
event, values = window.Read() event, values = window.Read()
@ -146,7 +146,7 @@ Same GUI screen except the return values are in a list instead of a dictionary a
[sg.Submit(), sg.Cancel()] [sg.Submit(), sg.Cancel()]
] ]
window = sg.Window('Simple data entry window').Layout(layout) window = sg.Window('Simple data entry window', layout)
event, values = window.Read() event, values = window.Read()
window.Close() window.Close()
print(event, values[0], values[1], values[2]) print(event, values[0], values[1], values[2])
@ -172,7 +172,7 @@ A simple GUI with default values. Results returned in a dictionary.
[sg.Submit(), sg.Cancel()] [sg.Submit(), sg.Cancel()]
] ]
window = sg.Window('Simple data entry GUI').Layout(layout) window = sg.Window('Simple data entry GUI', layout)
event, values = window.Read() event, values = window.Read()
@ -200,7 +200,7 @@ Browse for a filename that is populated directly into the user's variable
[sg.InputText(), sg.FileBrowse()], [sg.InputText(), sg.FileBrowse()],
[sg.Submit(), sg.Cancel()]] [sg.Submit(), sg.Cancel()]]
(event, (source_filename,)) = sg.Window('SHA-1 & 256 Hash').Layout(layout ).Read() (event, (source_filename,)) = sg.Window('SHA-1 & 256 Hash', layout).Read()
print(event, source_filename) print(event, source_filename)
``` ```
@ -244,7 +244,7 @@ Browse to get 2 file names that can be then compared.
[sg.Text('File 2', size=(8, 1)), sg.InputText(), sg.FileBrowse()], [sg.Text('File 2', size=(8, 1)), sg.InputText(), sg.FileBrowse()],
[sg.Submit(), sg.Cancel()]] [sg.Submit(), sg.Cancel()]]
window = sg.Window('File Compare').Layout(layout) window = sg.Window('File Compare', layout)
event, values = window.Read() event, values = window.Read()
window.Close() window.Close()
@ -301,7 +301,7 @@ Example of nearly all of the widgets in a single window. Uses a customized colo
] ]
window = sg.Window('Everything bagel', default_element_size=(40, 1), grab_anywhere=False).Layout(layout) window = sg.Window('Everything bagel', layout, default_element_size=(40, 1), grab_anywhere=False)
event, values = window.Read() event, values = window.Read()
@ -331,7 +331,7 @@ layout = [[sg.Text('Stopwatch', size=(20, 2), justification='center')],
[sg.Text('', size=(10, 2), font=('Helvetica', 20), justification='center', key='_OUTPUT_')], [sg.Text('', size=(10, 2), font=('Helvetica', 20), justification='center', key='_OUTPUT_')],
[sg.T(' ' * 5), sg.Button('Start/Stop', focus=True), sg.Quit()]] [sg.T(' ' * 5), sg.Button('Start/Stop', focus=True), sg.Quit()]]
window = sg.Window('Running Timer').Layout(layout) window = sg.Window('Running Timer', layout)
timer_running = True timer_running = True
i = 0 i = 0
@ -376,7 +376,7 @@ The architecture of some programs works better with button callbacks instead of
[sg.Button('1'), sg.Button('2'), sg.Quit()]] [sg.Button('1'), sg.Button('2'), sg.Quit()]]
# Show the Window to the user # Show the Window to the user
window = sg.Window('Button callback example').Layout(layout) window = sg.Window('Button callback example', layout)
# Event loop. Read buttons, make callbacks # Event loop. Read buttons, make callbacks
while True: while True:
@ -413,7 +413,7 @@ This recipe implements a remote control interface for a robot. There are 4 dire
[sg.Quit(button_color=('black', 'orange'))] [sg.Quit(button_color=('black', 'orange'))]
] ]
window = sg.Window('Robotics Remote Control', auto_size_text=True).Layout(layout ) window = sg.Window('Robotics Remote Control', layout, auto_size_text=True)
# #
# Some place later in your code... # Some place later in your code...
@ -508,8 +508,8 @@ def MediaPlayerGUI():
] ]
# Open a form, note that context manager can't be used generally speaking for async forms # Open a form, note that context manager can't be used generally speaking for async forms
window = sg.Window('Media File Player', auto_size_text=True, default_element_size=(20, 1), window = sg.Window('Media File Player', layout, auto_size_text=True, default_element_size=(20, 1),
font=("Helvetica", 25)).Layout(layout) font=("Helvetica", 25))
# Our event loop # Our event loop
while(True): while(True):
event, values = window.Read(timeout=100) # Poll every 100 ms event, values = window.Read(timeout=100) # Poll every 100 ms
@ -552,7 +552,7 @@ This Window doesn't close after button clicks. To achieve this the buttons are
] ]
window = sg.Window('Script launcher').Layout(layout) window = sg.Window('Script launcher', layout)
# ---===--- Loop taking in user input and using it to call scripts --- # # ---===--- Loop taking in user input and using it to call scripts --- #
@ -584,7 +584,7 @@ layout = [ [sg.Text('Text area', key='_TEXT_')],
[sg.Input(do_not_clear=True, key='_URL_')], [sg.Input(do_not_clear=True, key='_URL_')],
[sg.Button('Chrome'), sg.Button('Exit')]] [sg.Button('Chrome'), sg.Button('Exit')]]
window = sg.Window('Window Title').Layout(layout) window = sg.Window('Window Title', layuout)
while True: # Event Loop while True: # Event Loop
event, values = window.Read() event, values = window.Read()
@ -631,7 +631,7 @@ A standard non-blocking GUI with lots of inputs.
[sg.Radio('MSE(L2)', 'loss', size=(12, 1)), sg.Radio('MB(L0)', 'loss', size=(12, 1))], [sg.Radio('MSE(L2)', 'loss', size=(12, 1)), sg.Radio('MB(L0)', 'loss', size=(12, 1))],
[sg.Submit(), sg.Cancel()]] [sg.Submit(), sg.Cancel()]]
window = sg.Window('Machine Learning Front End', font=("Helvetica", 12)).Layout(layout) window = sg.Window('Machine Learning Front End', layout, font=("Helvetica", 12))
event, values = window.Read() event, values = window.Read()
``` ```
@ -652,7 +652,7 @@ layout = [[sg.Text('A custom progress meter')],
[sg.Cancel()]] [sg.Cancel()]]
# create the Window # create the Window
window = sg.Window('Custom Progress Meter').Layout(layout) window = sg.Window('Custom Progress Meter', layout)
# loop that would normally do something useful # loop that would normally do something useful
for i in range(1000): for i in range(1000):
# check to see if the cancel button was clicked and exit loop if clicked # check to see if the cancel button was clicked and exit loop if clicked
@ -684,7 +684,7 @@ Instead of
[sg.Input(), sg.FileBrowse()], [sg.Input(), sg.FileBrowse()],
[sg.OK(), sg.Cancel()]] [sg.OK(), sg.Cancel()]]
event, (number,) = sg.Window('Get filename example').Layout(layout).Read() event, (number,) = sg.Window('Get filename example', layout).Read()
``` ```
you can write this line of code for the exact same result (OK, two lines with the import): you can write this line of code for the exact same result (OK, two lines with the import):
```python ```python
@ -727,7 +727,7 @@ To make it easier to see the Column in the window, the Column background has bee
# Display the Window and get values # Display the Window and get values
event, values = sg.Window('Compact 1-line Window with column').Layout(layout).Read() event, values = sg.Window('Compact 1-line Window with column', layout).Read()
sg.Popup(event, values, line_width=200) sg.Popup(event, values, line_width=200)
``` ```
@ -749,7 +749,7 @@ This simple program keep a window open, taking input values until the user termi
[sg.Txt('', size=(8,1), key='output') ], [sg.Txt('', size=(8,1), key='output') ],
[sg.Button('Calculate', bind_return_key=True)]] [sg.Button('Calculate', bind_return_key=True)]]
window = sg.Window('Math').Layout(layout) window = sg.Window('Math', layout)
while True: while True:
event, values = window.Read() event, values = window.Read()
@ -782,7 +782,7 @@ layout = [[sg.Text('Slider Demonstration'), sg.Text('', key='_OUTPUT_')],
sg.T('0', key='_RIGHT_')], sg.T('0', key='_RIGHT_')],
[sg.Button('Show'), sg.Button('Exit')]] [sg.Button('Show'), sg.Button('Exit')]]
window = sg.Window('Window Title').Layout(layout) window = sg.Window('Window Title', layout)
while True: # Event Loop while True: # Event Loop
event, values = window.Read() event, values = window.Read()
@ -814,7 +814,7 @@ layout = [[ sg.Text('Window 1'),],
[sg.Text('', key='_OUTPUT_')], [sg.Text('', key='_OUTPUT_')],
[sg.Button('Launch 2')]] [sg.Button('Launch 2')]]
win1 = sg.Window('Window 1').Layout(layout) win1 = sg.Window('Window 1', layout)
win2_active=False win2_active=False
while True: while True:
ev1, vals1 = win1.Read(timeout=100) ev1, vals1 = win1.Read(timeout=100)
@ -828,7 +828,7 @@ while True:
layout2 = [[sg.Text('Window 2')], # note must create a layout from scratch every time. No reuse layout2 = [[sg.Text('Window 2')], # note must create a layout from scratch every time. No reuse
[sg.Button('Exit')]] [sg.Button('Exit')]]
win2 = sg.Window('Window 2').Layout(layout2) win2 = sg.Window('Window 2', layout2)
while True: while True:
ev2, vals2 = win2.Read() ev2, vals2 = win2.Read()
if ev2 is None or ev2 == 'Exit': if ev2 is None or ev2 == 'Exit':