2020-10-09 20:15:36 +00:00
|
|
|
import PySimpleGUI as sg
|
|
|
|
|
|
|
|
"""
|
|
|
|
Demo of using the vertical layout parameters and layout helper functions.
|
|
|
|
Three methods of vertical alignment are shown:
|
|
|
|
1. Using Column element to align a single element
|
|
|
|
2. Using vtop layout helper function to align a single element
|
|
|
|
3. Using vtop layout helper function to align an entire row
|
|
|
|
|
|
|
|
There is also a funciton provided that will convert an entire layout into
|
|
|
|
a top aligned layout.
|
|
|
|
|
|
|
|
Copyright 2020 PySimpleGUI.org
|
|
|
|
"""
|
|
|
|
|
|
|
|
def top_align_layout(layout):
|
|
|
|
"""
|
|
|
|
Given a layout, return a layout with all rows vertically adjusted to the top
|
|
|
|
|
|
|
|
:param layout: List[List[sg.Element]] The layout to justify
|
|
|
|
:return: List[List[sg.Element]] The new layout that is all top justified
|
|
|
|
"""
|
|
|
|
new_layout = []
|
|
|
|
for row in layout:
|
|
|
|
new_layout.append(sg.vtop(row))
|
|
|
|
return new_layout
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
# -------------------- Example 1 - No alignment --------------------
|
|
|
|
layout = [ [sg.T('This layout uses no vertical alignment. The default is "center"')],
|
|
|
|
[sg.Text('On row 1'), sg.Listbox(list(range(10)), size=(5,4)), sg.Text('On row 1')],
|
|
|
|
[sg.Button('OK')] ]
|
|
|
|
|
2020-10-10 15:17:00 +00:00
|
|
|
sg.Window('Example 1', layout).read(close=True)
|
2020-10-09 20:15:36 +00:00
|
|
|
|
|
|
|
# -------------------- Example 2 - Top aligned Text element using Column --------------------
|
|
|
|
layout = [ [sg.T('This uses a Column Element to align 1 element')],
|
|
|
|
[sg.Col([[sg.Text('On row 1')]], vertical_alignment='top', pad=(0,0)), sg.Listbox(list(range(10)), size=(5,4)), sg.Text('On row 1')],
|
|
|
|
[sg.Button('OK')] ]
|
|
|
|
|
2020-10-10 15:17:00 +00:00
|
|
|
sg.Window('Example 2', layout).read(close=True)
|
2020-10-09 20:15:36 +00:00
|
|
|
|
|
|
|
|
|
|
|
# -------------------- Example 3 - Top aligned Text element using Column --------------------
|
|
|
|
layout = [ [sg.T('This layout uses the "vtop" layout helper function on 1 element')],
|
|
|
|
[sg.vtop(sg.Text('On row 1')), sg.Listbox(list(range(10)), size=(5,4)), sg.Text('On row 1')],
|
|
|
|
[sg.Button('OK')] ]
|
|
|
|
|
2020-10-10 15:17:00 +00:00
|
|
|
sg.Window('Example 3', layout).read(close=True)
|
2020-10-09 20:15:36 +00:00
|
|
|
|
|
|
|
# -------------------- Example 4 - Top align an entire row --------------------
|
|
|
|
# Note that the vtop function takes a row as input and returns a row. DO NOT place [ ] around vtop
|
|
|
|
# because it is a row already.
|
|
|
|
layout = [ [sg.T('This layout uses the "vtop" layout helper function on 1 row')],
|
|
|
|
sg.vtop([sg.Text('On row 1'), sg.Listbox(list(range(10)), size=(5,4)), sg.Text('On row 1')]),
|
|
|
|
[sg.Button('OK')] ]
|
|
|
|
|
2020-10-10 15:17:00 +00:00
|
|
|
sg.Window('Example 4', layout).read(close=True)
|
2020-10-09 20:15:36 +00:00
|
|
|
|
|
|
|
|
2020-10-10 15:17:00 +00:00
|
|
|
# -------------------- Example 5 - Top align portion of a row --------------------
|
|
|
|
# You can combine 2 lists to make a row [a,b] + [c,d] = [a,b,c,d]
|
|
|
|
# To combine vtop with a normally specified row, add them vtop(a,b) + [c,d] = [a, b, c, d] (sorta)
|
|
|
|
layout = [ [sg.T('This layout uses the "vtop" for first part of row')],
|
|
|
|
sg.vtop([sg.Text('On row 1'), sg.Listbox(list(range(10)), size=(5,4)), sg.Text('On row 1')]) + [sg.Text('More elements'), sg.CB('Last')],
|
|
|
|
[sg.Button('OK')] ]
|
|
|
|
|
|
|
|
sg.Window('Example 5', layout).read(close=True)
|
|
|
|
|
|
|
|
|
|
|
|
# -------------------- Example 5B - Top align portion of a row --------------------
|
|
|
|
# Same operation as adding the 2 lists, but instead unpacks vtop list directly into a row layout
|
|
|
|
layout = [ [sg.T('This layout uses the "vtop" for first part of row')],
|
|
|
|
[*sg.vtop([sg.Text('On row 1'), sg.Listbox(list(range(10)), size=(5,4)), sg.Text('On row 1')]), sg.Text('More elements'), sg.CB('Last')],
|
|
|
|
[sg.Button('OK')] ]
|
|
|
|
|
|
|
|
sg.Window('Example 5B', layout).read(close=True)
|
|
|
|
|
|
|
|
# -------------------- Example 6 - Use function to align all rows in layout --------------------
|
2020-10-09 20:15:36 +00:00
|
|
|
layout = [ [sg.T('This layout has all rows top aligned using function')],
|
|
|
|
[sg.Text('On row 1'), sg.Listbox(list(range(10)), size=(5,4)), sg.Text('On row 1')],
|
|
|
|
[sg.Text('On row 2'), sg.Listbox(list(range(10)), size=(5,4)), sg.Text('On row 2')],
|
|
|
|
[sg.Button('OK')] ]
|
|
|
|
|
|
|
|
layout = top_align_layout(layout) # pass in a layout, get a loyout back
|
|
|
|
|
2020-10-10 15:17:00 +00:00
|
|
|
sg.Window('Example 6', layout).read(close=True)
|
2020-10-09 20:15:36 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|