From 2745fc24b53d269f9c0768e32da6612cd7e9dbe1 Mon Sep 17 00:00:00 2001 From: PySimpleGUI Date: Thu, 14 Oct 2021 19:34:55 -0400 Subject: [PATCH] Better pin implementation. Col element - w or h can be None now. Added friendly error popup to the deprication raise for Window.LayoutAndRead. Yes, working on the Column lesson and thus changes..... --- PySimpleGUI.py | 22 +++++++++++++++++----- 1 file changed, 17 insertions(+), 5 deletions(-) diff --git a/PySimpleGUI.py b/PySimpleGUI.py index bfe578b0..9d88886d 100644 --- a/PySimpleGUI.py +++ b/PySimpleGUI.py @@ -1,6 +1,6 @@ #!/usr/bin/python3 -version = __version__ = "4.49.0.12 Unreleased" +version = __version__ = "4.49.0.13 Unreleased" _change_log = """ @@ -43,7 +43,13 @@ _change_log = """ 4.49.0.11 Better formnatted printing of INI based UserSettings object 4.49.0.12 - Addition of horizontal scrollbar to Listbox. Parameter is horizontal_scroll. Default = False + Addition of horizontal scrollbar to Listbox + 4.49.0.13 + Better pin implementation, maybe. Was able to not use a Canvas element and instead use a blank Column element. Blended better. Still uses 1 pixel :-( + Column element - Changed how None in one of locations in size tuple handled. + If width is None, then required width will be used, if height is None, then 1/2 required height. + These are same values as None, None currently. + Window.LayoutAndRead deprication made more friendly with popup. """ __version__ = version.split()[0] # For PEP 396 and PEP 345 @@ -6868,9 +6874,9 @@ class Column(Element): :param background_color: color of background of entire Column :type background_color: (str) :param size: (width, height) size in pixels (doesn't work quite right, sometimes only 1 dimension is set by tkinter. Use a Sizer Element to help set sizes - :type size: (int, int) + :type size: (int | None, int | None) :param s: Same as size parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, size will be used - :type s: (int, int) | (None, None) + :type s: (int | None, int | None) :param pad: Amount of padding to put around element in pixels (left/right, top/bottom) or ((left, right), (top, bottom)) or an int. If an int, then it's converted into a tuple (int, int) :type pad: (int, int) or ((int, int),(int,int)) or (int,(int,int)) or ((int, int),int) | int :param p: Same as pad parameter. It's an alias. If EITHER of them are set, then the one that's set will be used. If BOTH are set, pad will be used @@ -8810,6 +8816,9 @@ class Window: :param non_blocking: if True the Read call will not block :type non_blocking: (bool) """ + _error_popup_with_traceback('LayoutAndRead Depricated', 'Wow! You have been using PySimpleGUI for a very long time.', + 'The Window.LayoutAndRead call is no longer supported') + raise DeprecationWarning( 'LayoutAndRead is no longer supported... change your call window.Layout(layout).Read()\nor window(title, layout).Read()') # self.AddRows(rows) @@ -11060,7 +11069,8 @@ def pin(elem, vertical_alignment=None, shrink=True, expand_x=None, expand_y=None :rtype: Column """ if shrink: - return Column([[elem, Canvas(size=(0, 0),background_color=elem.BackgroundColor, pad=(0, 0))]], pad=(0, 0), vertical_alignment=vertical_alignment, expand_x=expand_x, expand_y=expand_y) + # return Column([[elem, Canvas(size=(0, 0),background_color=elem.BackgroundColor, pad=(0, 0))]], pad=(0, 0), vertical_alignment=vertical_alignment, expand_x=expand_x, expand_y=expand_y) + return Column([[elem, Column([[]],pad=(0,0))]], pad=(0, 0), vertical_alignment=vertical_alignment, expand_x=expand_x, expand_y=expand_y) else: return Column([[elem]], pad=(0, 0), vertical_alignment=vertical_alignment, expand_x=expand_x, expand_y=expand_y) @@ -13315,6 +13325,8 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form): element.TKColFrame.canvas.config(width=element.TKColFrame.TKFrame.winfo_reqwidth(), height=element.TKColFrame.TKFrame.winfo_reqheight() // 2) else: + element.TKColFrame.canvas.config(width=element.TKColFrame.TKFrame.winfo_reqwidth(), + height=element.TKColFrame.TKFrame.winfo_reqheight() // 2) if None not in (element.Size[0], element.Size[1]): element.TKColFrame.canvas.config(width=element.Size[0], height=element.Size[1]) elif element.Size[1] is not None: