Docstrings, Warnings added to Window so that bad titles and bad layout types are warned. It's crude but will be helpful. Also first time using this warnings module. Hope it's OK! New Demo Program - invisible elements shows using a column for visibility

This commit is contained in:
MikeTheWatchGuy 2019-08-04 13:50:06 -04:00
parent 01b5dc4a32
commit 0b839ccb70
2 changed files with 46 additions and 13 deletions

View File

@ -0,0 +1,27 @@
import PySimpleGUI as sg
"""
Demonstrates that using a Column Element to make groups of Elements appear and disappear
will cause the layout of the elements in the column to remain as they were. If each individual element
were made invisible and then visible, then tkinter puts EACH ELEMENT on a separate row when it is made
visible again. This means a row of 6 elements will become a column of 6 elements if you make each of them
visible one at a time.
"""
layout = [[sg.Column([[sg.Text('My Window')],[sg.Input(key='_IN_'), sg.B('My button', key='_OUT_')]], key='_COL_')],
[sg.Button('Invisible'), sg.B('Visible'), sg.Button('Exit')]]
window = sg.Window('Window Title', layout)
while True: # Event Loop
event, values = window.Read()
print(event, values)
if event in (None, 'Exit'):
break
if event == 'Invisible':
window.Elem('_COL_').Update(visible=False)
elif event == 'Visible':
window.Elem('_COL_').Update(visible=True)
window.Close()

View File

@ -2748,7 +2748,7 @@ class Graph(Element):
self.BottomLeft = graph_bottom_left self.BottomLeft = graph_bottom_left
self.TopRight = graph_top_right self.TopRight = graph_top_right
# self._TKCanvas = None # type: tk.Canvas # self._TKCanvas = None # type: tk.Canvas
self._TKCanvas2 = None # type: tk.Canvas self._TKCanvas2 = self.Widget = None # type: tk.Canvas
self.ChangeSubmits = change_submits or enable_events self.ChangeSubmits = change_submits or enable_events
self.DragSubmits = drag_submits self.DragSubmits = drag_submits
self.ClickPosition = (None, None) self.ClickPosition = (None, None)
@ -3697,16 +3697,16 @@ class Slider(Element):
# ---------------------------------------------------------------------- # # ---------------------------------------------------------------------- #
# TkScrollableFrame (Used by Column) # # TkFixedFrame (Used by Column) #
# ---------------------------------------------------------------------- # # ---------------------------------------------------------------------- #
class TkFixedFrame(tk.Frame): class TkFixedFrame(tk.Frame):
""" """ """
A tkinter frame that is used with Column Elements that do not have a scrollbar
"""
def __init__(self, master, **kwargs): def __init__(self, master, **kwargs):
""" """
:param master: (tk.Widget) The parent widget
:param master: :param **kwargs: The keyword args
:param **kwargs:
""" """
tk.Frame.__init__(self, master, **kwargs) tk.Frame.__init__(self, master, **kwargs)
@ -3730,17 +3730,17 @@ class TkFixedFrame(tk.Frame):
# TkScrollableFrame (Used by Column) # # TkScrollableFrame (Used by Column) #
# ---------------------------------------------------------------------- # # ---------------------------------------------------------------------- #
class TkScrollableFrame(tk.Frame): class TkScrollableFrame(tk.Frame):
""" """ """
A frame with one or two scrollbars. Used to make Columns with scrollbars
"""
def __init__(self, master, vertical_only, **kwargs): def __init__(self, master, vertical_only, **kwargs):
""" """
:param master: ???????????????????????? :param master: (tk.Widget) The parent widget
:param vertical_only: ???????????????????????? :param vertical_only: (bool) if True the only a vertical scrollbar will be shown
:param **kwargs: :param **kwargs: The keyword parms
""" """
tk.Frame.__init__(self, master, **kwargs) tk.Frame.__init__(self, master, **kwargs)
# create a canvas object and a vertical scrollbar for scrolling it # create a canvas object and a vertical scrollbar for scrolling it
self.vscrollbar = tk.Scrollbar(self, orient=tk.VERTICAL) self.vscrollbar = tk.Scrollbar(self, orient=tk.VERTICAL)
self.vscrollbar.pack(side='right', fill="y", expand="false") self.vscrollbar.pack(side='right', fill="y", expand="false")
@ -5000,6 +5000,12 @@ class Window:
self.TransparentColor = transparent_color self.TransparentColor = transparent_color
self.UniqueKeyCounter = 0 self.UniqueKeyCounter = 0
self.DebuggerEnabled = debugger_enabled self.DebuggerEnabled = debugger_enabled
if type(title) != str:
warnings.warn('Your title is not a string. Are you passing in the right parameters?', UserWarning)
if layout is not None and type(layout) != list:
warnings.warn('Your layout is not a list... this is not good!')
if layout is not None: if layout is not None:
self.Layout(layout) self.Layout(layout)