New justification parameter for Multiline, Multiline.update, cprint

This commit is contained in:
PySimpleGUI 2020-07-28 07:30:54 -04:00
parent 2d94a7c736
commit fc69d73377
1 changed files with 48 additions and 18 deletions

View File

@ -1,5 +1,5 @@
#!/usr/bin/python3 #!/usr/bin/python3
version = __version__ = "4.26.0.13 Unreleased\nNew Sponsor button, highly experimental read_all_windows(), search option for theme previewer, theme button in main, progress bar color can use new 'on' format, combined ProgressBar.update_bar with ProgressBar.update so now only update is needed, theme previewer restore previous theme, raise KeyError when find_element or window[] hits a bad key (unless find_element has silent error set), better traceback shown on key errors, fix for get item, formatting of error location information. raise key error by default, added up / down arrow bindings for spinner if enabling events, key guessing attempt for bad lookups, read_all_windows - close window when X found" version = __version__ = "4.26.0.14 Unreleased\nNew Sponsor button, highly experimental read_all_windows(), search option for theme previewer, theme button in main, progress bar color can use new 'on' format, combined ProgressBar.update_bar with ProgressBar.update so now only update is needed, theme previewer restore previous theme, raise KeyError when find_element or window[] hits a bad key (unless find_element has silent error set), better traceback shown on key errors, fix for get item, formatting of error location information. raise key error by default, added up / down arrow bindings for spinner if enabling events, key guessing attempt for bad lookups, read_all_windows - close window when X found, new Multiline Justification parameter for both creation and update"
port = 'PySimpleGUI' port = 'PySimpleGUI'
@ -2118,7 +2118,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, auto_refresh=False, reroute_stdout=False, reroute_stderr=False, reroute_cprint=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, reroute_stdout=False, reroute_stderr=False, reroute_cprint=False, focus=False, font=None, pad=None, tooltip=None, justification=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
@ -2194,6 +2194,8 @@ class Multiline(Element):
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 self.previous_stdout = self.previous_stderr = None
self.reroute_cprint = reroute_cprint self.reroute_cprint = reroute_cprint
self.Justification = 'left' if justification is None else justification
self.justification_tag = self.just_center_tag = self.just_left_tag = self.just_right_tag = None
if reroute_stdout: if reroute_stdout:
self.reroute_stdout_to_here() self.reroute_stdout_to_here()
if reroute_stderr: if reroute_stderr:
@ -2204,7 +2206,7 @@ class Multiline(Element):
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)
return return
def Update(self, value=None, disabled=None, append=False, font=None, text_color=None, background_color=None, text_color_for_value=None, background_color_for_value=None, visible=None, autoscroll=None): def Update(self, value=None, disabled=None, append=False, font=None, text_color=None, background_color=None, text_color_for_value=None, background_color_for_value=None, visible=None, autoscroll=None, justification=None):
""" """
Changes some of the settings for the Multiline Element. Must call `Window.Read` or `Window.Finalize` prior Changes some of the settings for the Multiline Element. Must call `Window.Read` or `Window.Finalize` prior
:param value: new text to display :param value: new text to display
@ -2231,6 +2233,18 @@ class Multiline(Element):
if autoscroll is not None: if autoscroll is not None:
self.Autoscroll = autoscroll self.Autoscroll = autoscroll
if justification is not None:
if justification.startswith('l'):
just_tag = 'left'
if justification.startswith('r'):
just_tag = 'right'
if justification.startswith('c'):
just_tag = 'center'
else:
just_tag = self.justification_tag
starting_point = self.Widget.index(tk.INSERT)
tag = None
if value is not None: if value is not None:
value = str(value) value = str(value)
if background_color_for_value is not None or text_color_for_value is not None: if background_color_for_value is not None or text_color_for_value is not None:
@ -2243,23 +2257,25 @@ class Multiline(Element):
if text_color_for_value is not None: if text_color_for_value is not None:
self.TKText.tag_configure(tag, foreground=text_color_for_value) self.TKText.tag_configure(tag, foreground=text_color_for_value)
except Exception as e: except Exception as e:
print('* Multiline.update - bad color likely specified') print(f'* Multiline.update - bad color likely specified: {e}')
else:
tag = None
if self.Disabled: if self.Disabled:
self.TKText.configure(state='normal') self.TKText.configure(state='normal')
try: try:
if not append: if not append:
self.TKText.delete('1.0', tk.END) self.TKText.delete('1.0', tk.END)
if tag is not None: if tag is not None or just_tag is not None:
self.TKText.insert(tk.END, value, tag) self.TKText.insert(tk.END, value, (just_tag, tag))
else: else:
self.TKText.insert(tk.END, value) self.TKText.insert(tk.END, value)
except:
pass # self.TKText.tag_add(just_tag, starting_point, starting_point)
except Exception as e:
print(f'* Error setting multiline {e}')
if self.Disabled: if self.Disabled:
self.TKText.configure(state='disabled') self.TKText.configure(state='disabled')
self.DefaultText = value self.DefaultText = value
if self.Autoscroll: if self.Autoscroll:
self.TKText.see(tk.END) self.TKText.see(tk.END)
if disabled is True: if disabled is True:
@ -2297,7 +2313,7 @@ class Multiline(Element):
def print(self, *args, end=None, sep=None, text_color=None, background_color=None): def print(self, *args, end=None, sep=None, text_color=None, background_color=None, justification=None):
""" """
Print like Python normally prints except route the output to a multline element and also add colors if desired Print like Python normally prints except route the output to a multline element and also add colors if desired
@ -2312,7 +2328,7 @@ class Multiline(Element):
:param background_color: The background color of the line :param background_color: The background color of the line
:type background_color: (str) :type background_color: (str)
""" """
_print_to_element(self, *args, end=end, sep=sep, text_color=text_color, background_color=background_color ) _print_to_element(self, *args, end=end, sep=sep, text_color=text_color, background_color=background_color, justification=justification )
def reroute_stdout_to_here(self): def reroute_stdout_to_here(self):
@ -11423,6 +11439,20 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
element.TKText.config(highlightthickness=0) element.TKText.config(highlightthickness=0)
if element.BackgroundColor is not None and element.BackgroundColor != COLOR_SYSTEM_DEFAULT: if element.BackgroundColor is not None and element.BackgroundColor != COLOR_SYSTEM_DEFAULT:
element.TKText.configure(background=element.BackgroundColor) element.TKText.configure(background=element.BackgroundColor)
element.TKText.tag_configure("center", justify='center')
element.TKText.tag_configure("left", justify='left')
element.TKText.tag_configure("right", justify='right')
if element.Justification.startswith('l'):
element.TKText.tag_add("left", 1.0, "end")
element.justification_tag = 'left'
elif element.Justification.startswith('r'):
element.TKText.tag_add("right", 1.0, "end")
element.justification_tag = 'right'
elif element.Justification.startswith('c'):
element.TKText.tag_add("center", 1.0, "end")
element.justification_tag = 'center'
# if DEFAULT_SCROLLBAR_COLOR not in (None, COLOR_SYSTEM_DEFAULT): # only works on Linux so not including it # if DEFAULT_SCROLLBAR_COLOR not in (None, COLOR_SYSTEM_DEFAULT): # only works on Linux so not including it
# element.TKText.vbar.config(troughcolor=DEFAULT_SCROLLBAR_COLOR) # element.TKText.vbar.config(troughcolor=DEFAULT_SCROLLBAR_COLOR)
element.TKText.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1]) element.TKText.pack(side=tk.LEFT, padx=elementpad[0], pady=elementpad[1])
@ -12871,7 +12901,7 @@ def cprint_set_output_destination(window, multiline_key):
# def cprint(*args, **kwargs): # def cprint(*args, **kwargs):
def cprint(*args, end=None, sep=' ', text_color=None, t=None, background_color=None, b=None, colors=None, c=None, window=None, key=None): def cprint(*args, end=None, sep=' ', text_color=None, t=None, background_color=None, b=None, colors=None, c=None, window=None, key=None, justification=None):
""" """
Color print to a multiline element in a window of your choice. Color print to a multiline element in a window of your choice.
Must have EITHER called cprint_set_output_destination prior to making this call so that the Must have EITHER called cprint_set_output_destination prior to making this call so that the
@ -12953,10 +12983,10 @@ def cprint(*args, end=None, sep=' ', text_color=None, t=None, background_color=N
try: try:
# mline = destination_window[destination_key] # type: Multiline # mline = destination_window[destination_key] # type: Multiline
if end is None: if end is None:
mline.print(*args, text_color=kw_text_color, background_color=kw_background_color, end='', sep=sep) mline.print(*args, text_color=kw_text_color, background_color=kw_background_color, end='', sep=sep, justification=justification)
mline.print('') mline.print('', justification=justification)
else: else:
mline.print(*args,text_color=kw_text_color, background_color=kw_background_color, end=end, sep=sep) mline.print(*args,text_color=kw_text_color, background_color=kw_background_color, end=end, sep=sep, justification=justification)
except Exception as e: except Exception as e:
print('** cprint error trying to print to the multiline. Printing to console instead **', e) print('** cprint error trying to print to the multiline. Printing to console instead **', e)
print(*args, end=end, sep=sep) print(*args, end=end, sep=sep)
@ -12966,7 +12996,7 @@ def cprint(*args, end=None, sep=' ', text_color=None, t=None, background_color=N
# A print-like call that can be used to output to a multiline element as if it's an Output element # # A print-like call that can be used to output to a multiline element as if it's an Output element #
# ------------------------------------------------------------------------------------------------ # # ------------------------------------------------------------------------------------------------ #
def _print_to_element(multiline_element, *args, end=None, sep=None, text_color=None, background_color=None, autoscroll=None): def _print_to_element(multiline_element, *args, end=None, sep=None, text_color=None, background_color=None, autoscroll=None, justification=None):
""" """
Print like Python normally prints except route the output to a multline element and also add colors if desired Print like Python normally prints except route the output to a multline element and also add colors if desired
@ -12996,7 +13026,7 @@ def _print_to_element(multiline_element, *args, end=None, sep=None, text_color=N
outstring += sep_str outstring += sep_str
outstring += end_str outstring += end_str
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, justification=justification)
try: # if the element is set to autorefresh, then refresh the parent window try: # if the element is set to autorefresh, then refresh the parent window
if multiline_element.AutoRefresh: if multiline_element.AutoRefresh: