commit
a48b1fb34e
|
@ -20,13 +20,15 @@ import PySimpleGUI as sg
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
|
|
||||||
|
|
||||||
|
cprint = sg.cprint
|
||||||
|
|
||||||
MLINE_KEY = '-ML-'+sg.WRITE_ONLY_KEY # multiline element's key. Indicate it's an output only element
|
MLINE_KEY = '-ML-'+sg.WRITE_ONLY_KEY # multiline element's key. Indicate it's an output only element
|
||||||
MLINE_KEY2 = '-ML2-'+sg.WRITE_ONLY_KEY # multiline element's key. Indicate it's an output only element
|
MLINE_KEY2 = '-ML2-'+sg.WRITE_ONLY_KEY # multiline element's key. Indicate it's an output only element
|
||||||
MLINE_KEY3 = '-ML3-'+sg.WRITE_ONLY_KEY # multiline element's key. Indicate it's an output only element
|
MLINE_KEY3 = '-ML3-'+sg.WRITE_ONLY_KEY # multiline element's key. Indicate it's an output only element
|
||||||
|
|
||||||
output_key = MLINE_KEY
|
output_key = MLINE_KEY
|
||||||
|
|
||||||
|
|
||||||
layout = [ [sg.Text('Multiline Color Print Demo', font='Any 18')],
|
layout = [ [sg.Text('Multiline Color Print Demo', font='Any 18')],
|
||||||
[sg.Multiline('Multiline\n', size=(80,20), key=MLINE_KEY)],
|
[sg.Multiline('Multiline\n', size=(80,20), key=MLINE_KEY)],
|
||||||
[sg.Multiline('Multiline2\n', size=(80,20), key=MLINE_KEY2)],
|
[sg.Multiline('Multiline2\n', size=(80,20), key=MLINE_KEY2)],
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
#!/usr/bin/python3
|
#!/usr/bin/python3
|
||||||
|
|
||||||
version = __version__ = "4.24.0.4 Unreleased\nAdded k parameter to buttons, new text wrapping behavior for popups, new docstring for keys, new single-string button_color format ('white on red'), moved Tree image caching to be on a per-element basis rather than system wide"
|
version = __version__ = "4.24.0.5 Unreleased\nAdded k parameter to buttons, new text wrapping behavior for popups, new docstring for keys, new single-string button_color format ('white on red'), moved Tree image caching to be on a per-element basis rather than system wide, automatically refresh window when printing to multiline"
|
||||||
|
|
||||||
port = 'PySimpleGUI'
|
port = 'PySimpleGUI'
|
||||||
|
|
||||||
|
@ -592,10 +592,7 @@ class ToolTip:
|
||||||
# Element CLASS #
|
# Element CLASS #
|
||||||
# ------------------------------------------------------------------------- #
|
# ------------------------------------------------------------------------- #
|
||||||
class Element():
|
class Element():
|
||||||
"""
|
""" The base class for all Elements. Holds the basic description of an Element like size and colors """
|
||||||
The base class for all Elements.
|
|
||||||
Holds the basic description of an Element like size and colors
|
|
||||||
"""
|
|
||||||
|
|
||||||
def __init__(self, type, size=(None, None), auto_size_text=None, font=None, background_color=None, text_color=None, key=None, pad=None, tooltip=None,
|
def __init__(self, type, size=(None, None), auto_size_text=None, font=None, background_color=None, text_color=None, key=None, pad=None, tooltip=None,
|
||||||
visible=True, metadata=None):
|
visible=True, metadata=None):
|
||||||
|
@ -874,6 +871,7 @@ class Element():
|
||||||
:param bind_string: The string tkinter expected in its bind function
|
:param bind_string: The string tkinter expected in its bind function
|
||||||
:type bind_string: (str)
|
:type bind_string: (str)
|
||||||
:param key_modifier: Additional data to be added to the element's key when event is returned
|
:param key_modifier: Additional data to be added to the element's key when event is returned
|
||||||
|
:type key_modifier: (str)
|
||||||
"""
|
"""
|
||||||
if not self._widget_was_created(): # if widget hasn't been created yet, then don't allow
|
if not self._widget_was_created(): # if widget hasn't been created yet, then don't allow
|
||||||
return
|
return
|
||||||
|
@ -2128,7 +2126,7 @@ class Multiline(Element):
|
||||||
|
|
||||||
def __init__(self, default_text='', enter_submits=False, disabled=False, autoscroll=False, border_width=None,
|
def __init__(self, default_text='', enter_submits=False, disabled=False, autoscroll=False, border_width=None,
|
||||||
size=(None, None), auto_size_text=None, background_color=None, text_color=None, change_submits=False,
|
size=(None, None), auto_size_text=None, background_color=None, text_color=None, change_submits=False,
|
||||||
enable_events=False, do_not_clear=True, key=None, k=None, write_only=False, focus=False, font=None, pad=None, tooltip=None,
|
enable_events=False, do_not_clear=True, key=None, k=None, write_only=False, auto_refresh=False, focus=False, font=None, pad=None, tooltip=None,
|
||||||
right_click_menu=None, visible=True, metadata=None):
|
right_click_menu=None, visible=True, metadata=None):
|
||||||
"""
|
"""
|
||||||
:param default_text: Initial text to show
|
:param default_text: Initial text to show
|
||||||
|
@ -2161,6 +2159,8 @@ class Multiline(Element):
|
||||||
:type k: Union[str, int, tuple, object]
|
:type k: Union[str, int, tuple, object]
|
||||||
:param write_only: If True then no entry will be added to the values dictionary when the window is read
|
:param write_only: If True then no entry will be added to the values dictionary when the window is read
|
||||||
:type write_only: bool
|
:type write_only: bool
|
||||||
|
:param auto_refresh: If True then anytime the element is updated, the window will be refreshed so that the change is immediately displayed
|
||||||
|
:type auto_refresh: (bool)
|
||||||
:param focus: if True initial focus will go to this element
|
:param focus: if True initial focus will go to this element
|
||||||
:type focus: (bool)
|
:type focus: (bool)
|
||||||
:param font: specifies the font family, size, etc
|
:param font: specifies the font family, size, etc
|
||||||
|
@ -2192,7 +2192,9 @@ class Multiline(Element):
|
||||||
self.TKText = self.Widget = None # type: tkst.ScrolledText
|
self.TKText = self.Widget = None # type: tkst.ScrolledText
|
||||||
self.tags = set()
|
self.tags = set()
|
||||||
self.WriteOnly = write_only
|
self.WriteOnly = write_only
|
||||||
|
self.AutoRefresh = auto_refresh
|
||||||
key = key if key is not None else k
|
key = key if key is not None else k
|
||||||
|
self.previous_stdout = self.previous_stderr = None
|
||||||
|
|
||||||
super().__init__(ELEM_TYPE_INPUT_MULTILINE, size=size, auto_size_text=auto_size_text, background_color=bg,
|
super().__init__(ELEM_TYPE_INPUT_MULTILINE, size=size, auto_size_text=auto_size_text, background_color=bg,
|
||||||
text_color=fg, key=key, pad=pad, tooltip=tooltip, font=font or DEFAULT_FONT, visible=visible, metadata=metadata)
|
text_color=fg, key=key, pad=pad, tooltip=tooltip, font=font or DEFAULT_FONT, visible=visible, metadata=metadata)
|
||||||
|
@ -2303,6 +2305,54 @@ class Multiline(Element):
|
||||||
_print_to_element(self, *args, end=end, sep=sep, text_color=text_color, background_color=background_color, autoscroll=autoscroll)
|
_print_to_element(self, *args, end=end, sep=sep, text_color=text_color, background_color=background_color, autoscroll=autoscroll)
|
||||||
|
|
||||||
|
|
||||||
|
def reroute_stdout_to_here(self):
|
||||||
|
self.previous_stdout = sys.stdout
|
||||||
|
sys.stdout = self
|
||||||
|
|
||||||
|
|
||||||
|
def reroute_stderr_to_here(self):
|
||||||
|
self.previous_stderr = sys.stderr
|
||||||
|
sys.stderr = self
|
||||||
|
|
||||||
|
def restore_stdout(self):
|
||||||
|
if self.previous_stdout:
|
||||||
|
sys.stdout = self.previous_stdout
|
||||||
|
|
||||||
|
|
||||||
|
def restore_stderr(self):
|
||||||
|
if self.previous_stderr:
|
||||||
|
sys.stderr = self.previous_stderr
|
||||||
|
|
||||||
|
|
||||||
|
def write(self, txt):
|
||||||
|
"""
|
||||||
|
Called by Python (not tkinter?) when stdout or stderr wants to write
|
||||||
|
|
||||||
|
:param txt: text of output
|
||||||
|
:type txt: (str)
|
||||||
|
"""
|
||||||
|
try:
|
||||||
|
self.update(txt, append=True, autoscroll=True)
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
def flush(self):
|
||||||
|
"""
|
||||||
|
Flush parameter was passed into a print statement.
|
||||||
|
For now doing nothing. Not sure what action should be taken to ensure a flush happens regardless.
|
||||||
|
"""
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
|
def __del__(self):
|
||||||
|
"""
|
||||||
|
If this Widget is deleted, be sure and restore the old stdout, stderr
|
||||||
|
"""
|
||||||
|
self.restore_stdout()
|
||||||
|
self.restore_stderr()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
get = Get
|
get = Get
|
||||||
set_focus = Element.SetFocus
|
set_focus = Element.SetFocus
|
||||||
|
@ -6536,6 +6586,8 @@ class TreeData(object):
|
||||||
|
|
||||||
def __init__(self, parent, key, text, values, icon=None):
|
def __init__(self, parent, key, text, values, icon=None):
|
||||||
"""
|
"""
|
||||||
|
Represents a node within the TreeData class
|
||||||
|
|
||||||
:param parent: The parent Node
|
:param parent: The parent Node
|
||||||
:type parent: (TreeData.Node)
|
:type parent: (TreeData.Node)
|
||||||
:param key: Used to uniquely identify this node
|
:param key: Used to uniquely identify this node
|
||||||
|
@ -7799,8 +7851,9 @@ class Window:
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
self.TKrootDestroyed = True
|
self.TKrootDestroyed = True
|
||||||
del self.TKroot
|
|
||||||
del self.Rows
|
del self.Rows
|
||||||
|
del self.TKroot
|
||||||
|
|
||||||
# IT FINALLY WORKED! 29-Oct-2018 was the first time this damned thing got called
|
# IT FINALLY WORKED! 29-Oct-2018 was the first time this damned thing got called
|
||||||
def _OnClosingCallback(self):
|
def _OnClosingCallback(self):
|
||||||
|
@ -8585,7 +8638,7 @@ def FolderBrowse(button_text='Browse', target=(ThisRow, -1), initial_folder=None
|
||||||
def FileBrowse(button_text='Browse', target=(ThisRow, -1), file_types=(("ALL Files", "*.*"),), initial_folder=None,
|
def FileBrowse(button_text='Browse', target=(ThisRow, -1), file_types=(("ALL Files", "*.*"),), initial_folder=None,
|
||||||
tooltip=None, size=(None, None), auto_size_button=None, button_color=None, change_submits=False,
|
tooltip=None, size=(None, None), auto_size_button=None, button_color=None, change_submits=False,
|
||||||
enable_events=False, font=None, disabled=False,
|
enable_events=False, font=None, disabled=False,
|
||||||
pad=None, key=None, metadata=None):
|
pad=None, key=None, k=None, metadata=None):
|
||||||
"""
|
"""
|
||||||
|
|
||||||
:param button_text: text in the button (Default value = 'Browse')
|
:param button_text: text in the button (Default value = 'Browse')
|
||||||
|
@ -12401,6 +12454,11 @@ def _print_to_element(multiline_element, *args, end=None, sep=None, text_color=N
|
||||||
|
|
||||||
multiline_element.update(outstring, append=True, text_color_for_value=text_color, background_color_for_value=background_color, autoscroll=autoscroll)
|
multiline_element.update(outstring, append=True, text_color_for_value=text_color, background_color_for_value=background_color, autoscroll=autoscroll)
|
||||||
|
|
||||||
|
try: # if the element is set to autorefresh, then refresh the parent window
|
||||||
|
if multiline_element.AutoRefresh:
|
||||||
|
multiline_element.ParentForm.refresh()
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
# ============================== SetGlobalIcon ======#
|
# ============================== SetGlobalIcon ======#
|
||||||
# Sets the icon to be used by default #
|
# Sets the icon to be used by default #
|
||||||
|
@ -13892,9 +13950,9 @@ def theme_add_new(new_theme_name, new_theme_dict):
|
||||||
"""
|
"""
|
||||||
Add a new theme to the dictionary of themes
|
Add a new theme to the dictionary of themes
|
||||||
|
|
||||||
:param new_theme_name: text to display in eleemnt
|
:param new_theme_name: text to display in element
|
||||||
:type new_theme_name: (str)
|
:type new_theme_name: (str)
|
||||||
:param new_theme_dict: text to display in eleemnt
|
:param new_theme_dict: text to display in element
|
||||||
:type new_theme_dict: (dict)
|
:type new_theme_dict: (dict)
|
||||||
"""
|
"""
|
||||||
global LOOK_AND_FEEL_TABLE
|
global LOOK_AND_FEEL_TABLE
|
||||||
|
@ -16667,3 +16725,4 @@ if __name__ == '__main__':
|
||||||
main()
|
main()
|
||||||
exit(0)
|
exit(0)
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue