commit
						a48b1fb34e
					
				
					 2 changed files with 72 additions and 11 deletions
				
			
		|  | @ -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…
	
	Add table
		Add a link
		
	
		Reference in a new issue