Merge pull request #2679 from PySimpleGUI/Dev-latest
Debugger stack frame changed (still not working most likely). The la…
This commit is contained in:
		
						commit
						6487f2bed1
					
				
					 1 changed files with 222 additions and 138 deletions
				
			
		
							
								
								
									
										360
									
								
								PySimpleGUI.py
									
										
									
									
									
								
							
							
						
						
									
										360
									
								
								PySimpleGUI.py
									
										
									
									
									
								
							|  | @ -1,6 +1,6 @@ | ||||||
| #!/usr/bin/python3 | #!/usr/bin/python3 | ||||||
| 
 | 
 | ||||||
| version = __version__ = "4.16.10  Unreleased\n update_animation_no_buffering, popup_notify, removed TRANSPARENT_BUTTON, TabGroup now autonumbers keys, Table col width better size based on font, Table measure row height, Upgrade from GitHub utility (experimental), Multiline.print, fix padding lost with visibility, new upgrade utility" | version = __version__ = "4.16.11  Unreleased\n update_animation_no_buffering, popup_notify, removed TRANSPARENT_BUTTON, TabGroup now autonumbers keys, Table col width better size based on font, Table measure row height, Upgrade from GitHub utility (experimental), Multiline.print, fix padding lost with visibility, new upgrade utility" | ||||||
| 
 | 
 | ||||||
| port = 'PySimpleGUI' | port = 'PySimpleGUI' | ||||||
| 
 | 
 | ||||||
|  | @ -1275,7 +1275,8 @@ class Combo(Element): | ||||||
|         Returns the current (right now) value of the Combo.  DO NOT USE THIS AS THE NORMAL WAY OF READING A COMBO! |         Returns the current (right now) value of the Combo.  DO NOT USE THIS AS THE NORMAL WAY OF READING A COMBO! | ||||||
|         You should be using values from your call to window.Read instead.  Know what you're doing if you use it. |         You should be using values from your call to window.Read instead.  Know what you're doing if you use it. | ||||||
| 
 | 
 | ||||||
|         :return: Union[Any, None] Returns the value of what is currently chosen |         :return: Returns the value of what is currently chosen | ||||||
|  |         :rtype: Union[Any, None] | ||||||
|         """ |         """ | ||||||
|         try: |         try: | ||||||
|             if self.TKCombo.current() == -1:  # if the current value was not in the original list |             if self.TKCombo.current() == -1:  # if the current value was not in the original list | ||||||
|  | @ -4808,7 +4809,8 @@ class TabGroup(Element): | ||||||
|         Note that this is exactly the same data that would be returned from a call to Window.Read. Are you sure you |         Note that this is exactly the same data that would be returned from a call to Window.Read. Are you sure you | ||||||
|         are using this method correctly? |         are using this method correctly? | ||||||
| 
 | 
 | ||||||
|         :return: Union[Any, None] The key of the currently selected tab or the tab's text if it has no key |         :return:  The key of the currently selected tab or the tab's text if it has no key | ||||||
|  |         :rtype: Union[Any, None] | ||||||
|         """ |         """ | ||||||
| 
 | 
 | ||||||
|         try: |         try: | ||||||
|  | @ -5057,34 +5059,18 @@ class TkScrollableFrame(tk.Frame): | ||||||
|         self.canvas.itemconfig(self.frame_id, height=e.height, width=e.width) |         self.canvas.itemconfig(self.frame_id, height=e.height, width=e.width) | ||||||
| 
 | 
 | ||||||
|     def yscroll(self, event): |     def yscroll(self, event): | ||||||
|         """ |  | ||||||
| 
 |  | ||||||
|         :param event: |  | ||||||
| 
 |  | ||||||
|         """ |  | ||||||
|         if event.num == 5 or event.delta < 0: |         if event.num == 5 or event.delta < 0: | ||||||
|             self.canvas.yview_scroll(1, "unit") |             self.canvas.yview_scroll(1, "unit") | ||||||
|         elif event.num == 4 or event.delta > 0: |         elif event.num == 4 or event.delta > 0: | ||||||
|             self.canvas.yview_scroll(-1, "unit") |             self.canvas.yview_scroll(-1, "unit") | ||||||
| 
 | 
 | ||||||
|     def xscroll(self, event): |     def xscroll(self, event): | ||||||
|         """ |  | ||||||
| 
 |  | ||||||
|         :param event: |  | ||||||
| 
 |  | ||||||
|         """ |  | ||||||
|         if event.num == 5 or event.delta < 0: |         if event.num == 5 or event.delta < 0: | ||||||
|             self.canvas.xview_scroll(1, "unit") |             self.canvas.xview_scroll(1, "unit") | ||||||
|         elif event.num == 4 or event.delta > 0: |         elif event.num == 4 or event.delta > 0: | ||||||
|             self.canvas.xview_scroll(-1, "unit") |             self.canvas.xview_scroll(-1, "unit") | ||||||
| 
 | 
 | ||||||
|     def bind_mouse_scroll(self, parent, mode): |     def bind_mouse_scroll(self, parent, mode): | ||||||
|         """ |  | ||||||
| 
 |  | ||||||
|         :param parent: |  | ||||||
|         :param mode: |  | ||||||
| 
 |  | ||||||
|         """ |  | ||||||
|         # ~~ Windows only |         # ~~ Windows only | ||||||
|         parent.bind("<MouseWheel>", mode) |         parent.bind("<MouseWheel>", mode) | ||||||
|         # ~~ Unix only |         # ~~ Unix only | ||||||
|  | @ -5706,41 +5692,70 @@ class Table(Element): | ||||||
|                  size=(None, None), change_submits=False, enable_events=False, bind_return_key=False, pad=None, |                  size=(None, None), change_submits=False, enable_events=False, bind_return_key=False, pad=None, | ||||||
|                  key=None, tooltip=None, right_click_menu=None, visible=True, metadata=None): |                  key=None, tooltip=None, right_click_menu=None, visible=True, metadata=None): | ||||||
|         """ |         """ | ||||||
|         :param values: List[List[Union[str, int, float]]] |         :param values: ??? | ||||||
|         :param headings: List[str] The headings to show on the top line |         :type values: List[List[Union[str, int, float]]] | ||||||
|         :param visible_column_map: List[bool] One entry for each column. False indicates the column is not shown |         :param headings: The headings to show on the top line | ||||||
|         :param col_widths: List[int] Number of characters that each column will occupy |         :type headings: List[str] | ||||||
|         :param def_col_width: (int) Default column width in characters |         :param visible_column_map: One entry for each column. False indicates the column is not shown | ||||||
|         :param auto_size_columns: (bool) if True columns will be sized automatically |         :type visible_column_map: List[bool] | ||||||
|         :param max_col_width: (int) Maximum width for all columns in characters |         :param col_widths: Number of characters that each column will occupy | ||||||
|         :param select_mode: (enum) Select Mode. Valid values start with "TABLE_SELECT_MODE_".  Valid values are: |         :type col_widths: List[int] | ||||||
|                             TABLE_SELECT_MODE_NONE |         :param def_col_width: Default column width in characters | ||||||
|                             TABLE_SELECT_MODE_BROWSE |         :type def_col_width: (int) | ||||||
|                             TABLE_SELECT_MODE_EXTENDED |         :param auto_size_columns: if True columns will be sized automatically | ||||||
|         :param display_row_numbers: (bool) if True, the first column of the table will be the row # |         :type auto_size_columns: (bool) | ||||||
|         :param num_rows: (int) The number of rows of the table to display at a time |         :param max_col_width: Maximum width for all columns in characters | ||||||
|         :param row_height: (int) height of a single row in pixels |         :type max_col_width: (int) | ||||||
|         :param font: Union[str, Tuple[str, int]] specifies the font family, size, etc |         :param select_mode: Select Mode. Valid values start with "TABLE_SELECT_MODE_".  Valid values are: TABLE_SELECT_MODE_NONE TABLE_SELECT_MODE_BROWSE TABLE_SELECT_MODE_EXTENDED | ||||||
|         :param justification:  (str) 'left', 'right', 'center' are valid choices |         :type select_mode: (enum) | ||||||
|         :param text_color: (str) color of the text |         :param display_row_numbers: if True, the first column of the table will be the row # | ||||||
|         :param background_color: (str) color of background |         :type display_row_numbers: (bool) | ||||||
|         :param alternating_row_color: (str) if set then every other row will have this color in the background. |         :param num_rows: The number of rows of the table to display at a time | ||||||
|         :param header_text_color: (str) sets the text color for the header |         :type num_rows: (int) | ||||||
|         :param header_background_color: (str) sets the background color for the header |         :param row_height: height of a single row in pixels | ||||||
|         :param header_font: Union[str, Tuple[str, int]] specifies the font family, size, etc |         :type row_height: (int) | ||||||
|         :param row_colors: List[Union[Tuple[int, str], Tuple[Int, str, str]] list of tuples of (row, background color) OR (row, foreground color, background color). Sets the colors of listed rows to the color(s) provided (note the optional foreground color) |         :param font: specifies the font family, size, etc | ||||||
|         :param vertical_scroll_only:  (bool) if True only the vertical scrollbar will be visible |         :type font: Union[str, Tuple[str, int]] | ||||||
|         :param hide_vertical_scroll:  (bool) if True vertical scrollbar will be hidden |         :param justification: 'left', 'right', 'center' are valid choices | ||||||
|         :param size: Tuple[int, int] DO NOT USE! Use num_rows instead |         :type justification: (str) | ||||||
|         :param change_submits: (bool) DO NOT USE. Only listed for backwards compat - Use enable_events instead |         :param text_color: color of the text | ||||||
|         :param enable_events: (bool) Turns on the element specific events. Table events happen when row is clicked |         :type text_color: (str) | ||||||
|         :param bind_return_key: (bool) if True, pressing return key will cause event coming from Table, ALSO a left button double click will generate an event if this parameter is True |         :param background_color: color of background | ||||||
|         :param pad: (int, int) or ((int, int),(int,int)) Amount of padding to put around element (left/right, top/bottom) or ((left, right), (top, bottom)) |         :type background_color: (str) | ||||||
|         :param key: (Any) Used with window.FindElement and with return values to uniquely identify this element to uniquely identify this element |         :param alternating_row_color: if set then every other row will have this color in the background. | ||||||
|         :param tooltip: (str) text, that will appear when mouse hovers over the element |         :type alternating_row_color: (str) | ||||||
|         :param right_click_menu: List[List[Union[List[str],str]]] A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. |         :param header_text_color: sets the text color for the header | ||||||
|         :param visible: (bool) set visibility state of the element |         :type header_text_color: (str) | ||||||
|         :param metadata: (Any) User metadata that can be set to ANYTHING |         :param header_background_color: sets the background color for the header | ||||||
|  |         :type header_background_color: (str) | ||||||
|  |         :param header_font: specifies the font family, size, etc | ||||||
|  |         :type header_font: Union[str, Tuple[str, int]] | ||||||
|  |         :param row_colors: list of tuples of (row, background color) OR (row, foreground color, background color). Sets the colors of listed rows to the color(s) provided (note the optional foreground color) | ||||||
|  |         :type row_colors: List[Union[Tuple[int, str], Tuple[Int, str, str]] | ||||||
|  |         :param vertical_scroll_only: if True only the vertical scrollbar will be visible | ||||||
|  |         :type vertical_scroll_only: (bool) | ||||||
|  |         :param hide_vertical_scroll: if True vertical scrollbar will be hidden | ||||||
|  |         :type hide_vertical_scroll: (bool) | ||||||
|  |         :param size: DO NOT USE! Use num_rows instead | ||||||
|  |         :type size: Tuple[int, int] | ||||||
|  |         :param change_submits: DO NOT USE. Only listed for backwards compat - Use enable_events instead | ||||||
|  |         :type change_submits: (bool) | ||||||
|  |         :param enable_events: Turns on the element specific events. Table events happen when row is clicked | ||||||
|  |         :type enable_events: (bool) | ||||||
|  |         :param bind_return_key: if True, pressing return key will cause event coming from Table, ALSO a left button double click will generate an event if this parameter is True | ||||||
|  |         :type bind_return_key: (bool) | ||||||
|  |         :param pad: Amount of padding to put around element (left/right, top/bottom) or ((left, right), (top, bottom)) | ||||||
|  |         :type pad: (int, int) or ((int, int),(int,int)) | ||||||
|  |         :param key: Used with window.FindElement and with return values to uniquely identify this element to uniquely identify this element | ||||||
|  |         :type key: (Any) | ||||||
|  |         :param tooltip: text, that will appear when mouse hovers over the element | ||||||
|  |         :type tooltip: (str) | ||||||
|  |         :param right_click_menu: A list of lists of Menu items to show when this element is right clicked. See user docs for exact format. | ||||||
|  |         :type right_click_menu: List[List[Union[List[str],str]]] | ||||||
|  |         :param visible: set visibility state of the element | ||||||
|  |         :type visible: (bool) | ||||||
|  |         :param metadata: User metadata that can be set to ANYTHING | ||||||
|  |         :type metadata: Any | ||||||
|         """ |         """ | ||||||
| 
 | 
 | ||||||
|         self.Values = values |         self.Values = values | ||||||
|  | @ -6692,8 +6707,10 @@ class Window: | ||||||
|         * bytes object |         * bytes object | ||||||
|         * BASE64 encoded file held in a variable |         * BASE64 encoded file held in a variable | ||||||
| 
 | 
 | ||||||
|         :param icon: (str) Filename or bytes object |         :param icon: Filename or bytes object | ||||||
|         :param pngbase64: (str) Base64 encoded image |         :type icon: (str) | ||||||
|  |         :param pngbase64: Base64 encoded image | ||||||
|  |         :type pngbase64: (str) | ||||||
|         """ |         """ | ||||||
|         if type(icon) is bytes or pngbase64 is not None: |         if type(icon) is bytes or pngbase64 is not None: | ||||||
|             wicon = tkinter.PhotoImage(data=icon if icon is not None else pngbase64) |             wicon = tkinter.PhotoImage(data=icon if icon is not None else pngbase64) | ||||||
|  | @ -7071,7 +7088,8 @@ class Window: | ||||||
|     def FindElementWithFocus(self): |     def FindElementWithFocus(self): | ||||||
|         """ |         """ | ||||||
|         Returns the Element that currently has focus as reported by tkinter. If no element is found None is returned! |         Returns the Element that currently has focus as reported by tkinter. If no element is found None is returned! | ||||||
|         :return: Union[Element, None] An Element if one has been found with focus or None if no element found |         :return: An Element if one has been found with focus or None if no element found | ||||||
|  |         :rtype: Union[Element, None] | ||||||
|         """ |         """ | ||||||
|         element = _FindElementWithFocusInSubForm(self) |         element = _FindElementWithFocusInSubForm(self) | ||||||
|         return element |         return element | ||||||
|  | @ -7513,7 +7531,8 @@ class Window: | ||||||
|         """ |         """ | ||||||
|         Get the current location of the window's top left corner |         Get the current location of the window's top left corner | ||||||
| 
 | 
 | ||||||
|         :return: Tuple[(int), (int)] The x and y location in tuple form (x,y) |         :return: The x and y location in tuple form (x,y) | ||||||
|  |         :rtype: Tuple[(int), (int)] | ||||||
|         """ |         """ | ||||||
|         return int(self.TKroot.winfo_x()), int(self.TKroot.winfo_y()) |         return int(self.TKroot.winfo_x()), int(self.TKroot.winfo_y()) | ||||||
| 
 | 
 | ||||||
|  | @ -7522,7 +7541,8 @@ class Window: | ||||||
|         """ |         """ | ||||||
|         Return the current size of the window in pixels |         Return the current size of the window in pixels | ||||||
| 
 | 
 | ||||||
|         :return: Tuple[(int), (int)] the (width, height) of the window |         :return: (width, height) of the window | ||||||
|  |         :rtype: Tuple[(int), (int)] | ||||||
|         """ |         """ | ||||||
|         win_width = self.TKroot.winfo_width() |         win_width = self.TKroot.winfo_width() | ||||||
|         win_height = self.TKroot.winfo_height() |         win_height = self.TKroot.winfo_height() | ||||||
|  | @ -7533,7 +7553,8 @@ class Window: | ||||||
|         """ |         """ | ||||||
|         Changes the size of the window, if possible |         Changes the size of the window, if possible | ||||||
| 
 | 
 | ||||||
|         :param size: Tuple[int, int] (width, height) of the desired window size |         :param size: (width, height) of the desired window size | ||||||
|  |         :type size: Tuple[int, int] | ||||||
|         """ |         """ | ||||||
|         try: |         try: | ||||||
|             self.TKroot.geometry("%sx%s" % (size[0], size[1])) |             self.TKroot.geometry("%sx%s" % (size[0], size[1])) | ||||||
|  | @ -7554,7 +7575,8 @@ class Window: | ||||||
|         """ |         """ | ||||||
|         Set the color that will be transparent in your window. Areas with this color will be SEE THROUGH. |         Set the color that will be transparent in your window. Areas with this color will be SEE THROUGH. | ||||||
| 
 | 
 | ||||||
|         :param color: (str) Color string that defines the transparent color |         :param color: Color string that defines the transparent color | ||||||
|  |         :type color: (str) | ||||||
|         """ |         """ | ||||||
|         try: |         try: | ||||||
|             self.TKroot.attributes('-transparentcolor', color) |             self.TKroot.attributes('-transparentcolor', color) | ||||||
|  | @ -7602,7 +7624,9 @@ class Window: | ||||||
|         Used to add tkinter events to a Window. |         Used to add tkinter events to a Window. | ||||||
|         The tkinter specific data is in the Window's member variable user_bind_event |         The tkinter specific data is in the Window's member variable user_bind_event | ||||||
|         :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) | ||||||
|         :param key: The event that will be generated when the tkinter event occurs |         :param key: The event that will be generated when the tkinter event occurs | ||||||
|  |         :type key: Any | ||||||
|         """ |         """ | ||||||
|         self.TKroot.bind(bind_string, lambda evt: self._user_bind_callback(bind_string, evt)) |         self.TKroot.bind(bind_string, lambda evt: self._user_bind_callback(bind_string, evt)) | ||||||
|         self.user_bind_dict[bind_string] = key |         self.user_bind_dict[bind_string] = key | ||||||
|  | @ -7661,8 +7685,10 @@ class Window: | ||||||
|         This is "called" by writing code as thus: |         This is "called" by writing code as thus: | ||||||
|         window['element key'].Update |         window['element key'].Update | ||||||
| 
 | 
 | ||||||
|         :param key: (Any) The key to find |         :param key: The key to find | ||||||
|         :return: Union[Element, None] The element found or None if no element was found |         :type key: (Any) | ||||||
|  |         :return: The element found or None if no element was found | ||||||
|  |         :rtype: Union[Element, None] | ||||||
|         """ |         """ | ||||||
|         try: |         try: | ||||||
|             return self.FindElement(key) |             return self.FindElement(key) | ||||||
|  | @ -7676,9 +7702,8 @@ class Window: | ||||||
|         window() == window.Read() |         window() == window.Read() | ||||||
|         window(timeout=50) == window.Read(timeout=50) |         window(timeout=50) == window.Read(timeout=50) | ||||||
| 
 | 
 | ||||||
|         :param args: |         :return: The famous event, values that Read returns. | ||||||
|         :param kwargs: |         :rtype: Tuple[Any, Dict[Any:Any]] | ||||||
|         :return: Tuple[Any, Dict[Any:Any]] The famous event, values that Read returns. |  | ||||||
|         """ |         """ | ||||||
|         return self.Read(*args, **kwargs) |         return self.Read(*args, **kwargs) | ||||||
| 
 | 
 | ||||||
|  | @ -7804,11 +7829,17 @@ class SystemTray: | ||||||
|         """ |         """ | ||||||
|         SystemTray - create an icon in the system tray |         SystemTray - create an icon in the system tray | ||||||
|         :param menu: Menu definition |         :param menu: Menu definition | ||||||
|  |         :type menu: ??? | ||||||
|         :param filename: filename for icon |         :param filename: filename for icon | ||||||
|  |         :type filename: ???? | ||||||
|         :param data: in-ram image for icon |         :param data: in-ram image for icon | ||||||
|  |         :type data: ??? | ||||||
|         :param data_base64: basee-64 data for icon |         :param data_base64: basee-64 data for icon | ||||||
|  |         :type data_base64: ??? | ||||||
|         :param tooltip: tooltip string |         :param tooltip: tooltip string | ||||||
|         :param metadata: (Any) User metadata that can be set to ANYTHING |         :type tooltip: (str) | ||||||
|  |         :param metadata: User metadata that can be set to ANYTHING | ||||||
|  |         :type metadata: Any | ||||||
|         """ |         """ | ||||||
|         self.Menu = menu |         self.Menu = menu | ||||||
|         self.TrayIcon = None |         self.TrayIcon = None | ||||||
|  | @ -7872,12 +7903,19 @@ class SystemTray: | ||||||
|         """ |         """ | ||||||
|         Shows a balloon above icon in system tray |         Shows a balloon above icon in system tray | ||||||
|         :param title:  Title shown in balloon |         :param title:  Title shown in balloon | ||||||
|  |         :type title: | ||||||
|         :param message: Message to be displayed |         :param message: Message to be displayed | ||||||
|  |         :type message: | ||||||
|         :param filename: Optional icon filename |         :param filename: Optional icon filename | ||||||
|  |         :type filename: | ||||||
|         :param data: Optional in-ram icon |         :param data: Optional in-ram icon | ||||||
|  |         :type data: | ||||||
|         :param data_base64: Optional base64 icon |         :param data_base64: Optional base64 icon | ||||||
|         :param time: Union[int, Tuple[int, int]] Amount of time to display message in milliseconds. If tuple, first item is fade in/out duration |         :type data_base64: | ||||||
|         :return: (Any)  The event that happened during the display such as user clicked on message |         :param time: Amount of time to display message in milliseconds. If tuple, first item is fade in/out duration | ||||||
|  |         :type time: Union[int, Tuple[int, int]] | ||||||
|  |         :return:   The event that happened during the display such as user clicked on message | ||||||
|  |         :rtype:  (Any) | ||||||
|         """ |         """ | ||||||
| 
 | 
 | ||||||
|         if isinstance(time, tuple): |         if isinstance(time, tuple): | ||||||
|  | @ -7903,11 +7941,15 @@ class SystemTray: | ||||||
|         """ |         """ | ||||||
|         Updates the menu, tooltip or icon |         Updates the menu, tooltip or icon | ||||||
|         :param menu: menu defintion |         :param menu: menu defintion | ||||||
|  |         :type menu: ??? | ||||||
|         :param tooltip: string representing tooltip |         :param tooltip: string representing tooltip | ||||||
|  |         :type tooltip: ??? | ||||||
|         :param filename:  icon filename |         :param filename:  icon filename | ||||||
|  |         :type filename: ??? | ||||||
|         :param data:  icon raw image |         :param data:  icon raw image | ||||||
|  |         :type data: ??? | ||||||
|         :param data_base64: icon base 64 image |         :param data_base64: icon base 64 image | ||||||
|         :return: |         :type data_base64: ??? | ||||||
|         """ |         """ | ||||||
|         # Menu |         # Menu | ||||||
|         if menu is not None: |         if menu is not None: | ||||||
|  | @ -7932,14 +7974,22 @@ class SystemTray: | ||||||
|         """ |         """ | ||||||
|         Displays a "notification window", usually in the bottom right corner of your display.  Has an icon, a title, and a message |         Displays a "notification window", usually in the bottom right corner of your display.  Has an icon, a title, and a message | ||||||
|         The window will slowly fade in and out if desired.  Clicking on the window will cause it to move through the end the current "phase". For example, if the window was fading in and it was clicked, then it would immediately stop fading in and instead be fully visible.  It's a way for the user to quickly dismiss the window. |         The window will slowly fade in and out if desired.  Clicking on the window will cause it to move through the end the current "phase". For example, if the window was fading in and it was clicked, then it would immediately stop fading in and instead be fully visible.  It's a way for the user to quickly dismiss the window. | ||||||
|         :param title: (str) Text to be shown at the top of the window in a larger font |         :param title: Text to be shown at the top of the window in a larger font | ||||||
|         :param message: (str) Text message that makes up the majority of the window |         :type title: (str) | ||||||
|         :param icon: Union[bytes, str) A base64 encoded PNG/GIF image or PNG/GIF filename that will be displayed in the window |         :param message: Text message that makes up the majority of the window | ||||||
|         :param display_duration_in_ms: (int) Number of milliseconds to show the window |         :type message: (str) | ||||||
|         :param fade_in_duration: (int) Number of milliseconds to fade window in and out |         :param icon: A base64 encoded PNG/GIF image or PNG/GIF filename that will be displayed in the window | ||||||
|         :param alpha: (float) Alpha channel. 0 - invisible 1 - fully visible |         :type icon: Union[bytes, str] | ||||||
|         :param location: Tuple[int, int] Location on the screen to display the window |         :param display_duration_in_ms: Number of milliseconds to show the window | ||||||
|  |         :type display_duration_in_ms: (int) | ||||||
|  |         :param fade_in_duration: Number of milliseconds to fade window in and out | ||||||
|  |         :type fade_in_duration: (int) | ||||||
|  |         :param alpha: Alpha channel. 0 - invisible 1 - fully visible | ||||||
|  |         :type alpha: (float) | ||||||
|  |         :param location: Location on the screen to display the window | ||||||
|  |         :type location: Tuple[int, int] | ||||||
|         :return: (int) reason for returning |         :return: (int) reason for returning | ||||||
|  |         :rtype: (int) | ||||||
|         """ |         """ | ||||||
| 
 | 
 | ||||||
|         messages = message.split('\n') |         messages = message.split('\n') | ||||||
|  | @ -8030,8 +8080,11 @@ def Sizer(h_pixels=0, v_pixels=0): | ||||||
|     "Pushes" out the size of whatever it is placed inside of.  This includes Columns, Frames, Tabs and Windows |     "Pushes" out the size of whatever it is placed inside of.  This includes Columns, Frames, Tabs and Windows | ||||||
| 
 | 
 | ||||||
|     :param h_pixels: (int) number of horizontal pixels |     :param h_pixels: (int) number of horizontal pixels | ||||||
|  |     :type h_pixels: (int) | ||||||
|     :param v_pixels: (int) number of vertical pixels |     :param v_pixels: (int) number of vertical pixels | ||||||
|  |     :type v_pixels: (int) | ||||||
|     :return: (Column) A column element that has a pad setting set according to parameters |     :return: (Column) A column element that has a pad setting set according to parameters | ||||||
|  |     :rtype: (Column) | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
|     return Column([[]], pad=((h_pixels, 0), (v_pixels, 0))) |     return Column([[]], pad=((h_pixels, 0), (v_pixels, 0))) | ||||||
|  | @ -12887,23 +12940,40 @@ def Popup(*args, title=None, button_color=None, background_color=None, text_colo | ||||||
|     Popup - Display a popup Window with as many parms as you wish to include.  This is the GUI equivalent of the |     Popup - Display a popup Window with as many parms as you wish to include.  This is the GUI equivalent of the | ||||||
|     "print" statement.  It's also great for "pausing" your program's flow until the user can read some error messages. |     "print" statement.  It's also great for "pausing" your program's flow until the user can read some error messages. | ||||||
| 
 | 
 | ||||||
|     :param *args: (Any) Variable number of your arguments.  Load up the call with stuff to see! |     :param *args:  Variable number of your arguments.  Load up the call with stuff to see! | ||||||
|     :param title: (str)  Optional title for the window. If none provided, the first arg will be used instead. |     :type *args: (Any) | ||||||
|     :param button_color: Tuple[str, str] Color of the buttons shown (text color, button color) |     :param title:   Optional title for the window. If none provided, the first arg will be used instead. | ||||||
|     :param background_color: (str) Window's background color |     :type title: (str) | ||||||
|     :param text_color: (str) text color |     :param button_color: Color of the buttons shown (text color, button color) | ||||||
|     :param button_type: (enum) NOT USER SET!  Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). There are many Popup functions and they call Popup, changing this parameter to get the desired effect. |     :type button_color: Tuple[str, str] | ||||||
|     :param auto_close: (bool) If True the window will automatically close |     :param background_color:  Window's background color | ||||||
|     :param auto_close_duration:  (int) time in seconds to keep window open before closing it automatically |     :type background_color: (str) | ||||||
|     :param custom_text:  Union[Tuple[str, str], str] A string or pair of strings that contain the text to display on the buttons |     :param text_color:  text color | ||||||
|     :param non_blocking:  (bool) If True then will immediately return from the function without waiting for the user's input. |     :type text_color: (str) | ||||||
|     :param icon: Union[str, bytes] icon to display on the window. Same format as a Window call |     :param button_type:  NOT USER SET!  Determines which pre-defined buttons will be shown (Default value = POPUP_BUTTONS_OK). There are many Popup functions and they call Popup, changing this parameter to get the desired effect. | ||||||
|     :param line_width: (int) Width of lines in characters.  Defaults to MESSAGE_BOX_LINE_WIDTH |     :type button_type: (enum) | ||||||
|     :param font:  Union[str, tuple(font name, size, modifiers) specifies the font family, size, etc |     :param auto_close:  If True the window will automatically close | ||||||
|     :param no_titlebar:  (bool) If True will not show the frame around the window and the titlebar across the top |     :type auto_close: (bool) | ||||||
|     :param grab_anywhere: (bool) If True can grab anywhere to move the window. If no_titlebar is True, grab_anywhere should likely be enabled too |     :param auto_close_duration:  time in seconds to keep window open before closing it automatically | ||||||
|     :param location: Tuple[int, int]  Location on screen to display the top left corner of window. Defaults to window centered on screen |     :type auto_close_duration: (int) | ||||||
|     :return: Union[str, None] Returns text of the button that was pressed.  None will be returned if user closed window with X |     :param custom_text:  A string or pair of strings that contain the text to display on the buttons | ||||||
|  |     :type custom_text: Union[Tuple[str, str], str] | ||||||
|  |     :param non_blocking:  If True then will immediately return from the function without waiting for the user's input. | ||||||
|  |     :type non_blocking: (bool) | ||||||
|  |     :param icon:  icon to display on the window. Same format as a Window call | ||||||
|  |     :type icon: Union[str, bytes] | ||||||
|  |     :param line_width:  Width of lines in characters.  Defaults to MESSAGE_BOX_LINE_WIDTH | ||||||
|  |     :type line_width: (int) | ||||||
|  |     :param font:  specifies the font family, size, etc | ||||||
|  |     :type font: Union[str, tuple(font name, size, modifiers] | ||||||
|  |     :param no_titlebar:  If True will not show the frame around the window and the titlebar across the top | ||||||
|  |     :type no_titlebar: (bool) | ||||||
|  |     :param grab_anywhere:  If True can grab anywhere to move the window. If no_titlebar is True, grab_anywhere should likely be enabled too | ||||||
|  |     :type grab_anywhere: (bool) | ||||||
|  |     :param location:   Location on screen to display the top left corner of window. Defaults to window centered on screen | ||||||
|  |     :type location: Tuple[int, int] | ||||||
|  |     :return: Returns text of the button that was pressed.  None will be returned if user closed window with X | ||||||
|  |     :rtype: Union[str, None] | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
|     if not args: |     if not args: | ||||||
|  | @ -13611,20 +13681,35 @@ def PopupGetText(message, title=None, default_text='', password_char='', size=(N | ||||||
|     Display Popup with text entry field. Returns the text entered or None if closed / cancelled |     Display Popup with text entry field. Returns the text entered or None if closed / cancelled | ||||||
| 
 | 
 | ||||||
|     :param message: (str) message displayed to user |     :param message: (str) message displayed to user | ||||||
|  |     :type message: (str) | ||||||
|     :param title: (str) Window title |     :param title: (str) Window title | ||||||
|  |     :type title: (str) | ||||||
|     :param default_text:  (str) default value to put into input area |     :param default_text:  (str) default value to put into input area | ||||||
|  |     :type default_text: (str) | ||||||
|     :param password_char: (str) character to be shown instead of actually typed characters |     :param password_char: (str) character to be shown instead of actually typed characters | ||||||
|     :param size: Tuple[int, int] (width, height) of the InputText Element |     :type password_char: (str) | ||||||
|     :param button_color: Tuple[str, str] Color of the button (text, background) |     :param size: (width, height) of the InputText Element | ||||||
|  |     :type size: Tuple[int, int] | ||||||
|  |     :param button_color:  Color of the button (text, background) | ||||||
|  |     :type button_color: Tuple[str, str] | ||||||
|     :param background_color: (str) background color of the entire window |     :param background_color: (str) background color of the entire window | ||||||
|  |     :type background_color: (str) | ||||||
|     :param text_color: (str) color of the message text |     :param text_color: (str) color of the message text | ||||||
|     :param icon: Union[bytes, str] filename or base64 string to be used for the window's icon |     :type text_color: (str) | ||||||
|     :param font: Union[str, Tuple[str, int]] specifies the font family, size, etc |     :param icon: filename or base64 string to be used for the window's icon | ||||||
|  |     :type icon: Union[bytes, str] | ||||||
|  |     :param font: specifies the font family, size, etc | ||||||
|  |     :type font: Union[str, Tuple[str, int]] | ||||||
|     :param no_titlebar: (bool) If True no titlebar will be shown |     :param no_titlebar: (bool) If True no titlebar will be shown | ||||||
|  |     :type no_titlebar: (bool) | ||||||
|     :param grab_anywhere: (bool) If True can click and drag anywhere in the window to move the window |     :param grab_anywhere: (bool) If True can click and drag anywhere in the window to move the window | ||||||
|  |     :type grab_anywhere: (bool) | ||||||
|     :param keep_on_top: (bool) If True the window will remain above all current windows |     :param keep_on_top: (bool) If True the window will remain above all current windows | ||||||
|     :param location: Tuyple[int, int] (x,y) Location on screen to display the upper left corner of window |     :type keep_on_top: (bool) | ||||||
|     :return: Union[str, None] Text entered or None if window was closed or cancel button clicked |     :param location: (x,y) Location on screen to display the upper left corner of window | ||||||
|  |     :type location: Tuple[int, int] | ||||||
|  |     :return: Text entered or None if window was closed or cancel button clicked | ||||||
|  |     :rtype: Union[str, None] | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
|     layout = [[Text(message, auto_size_text=True, text_color=text_color, background_color=background_color, font=font)], |     layout = [[Text(message, auto_size_text=True, text_color=text_color, background_color=background_color, font=font)], | ||||||
|  | @ -13706,13 +13791,21 @@ def popup_notify(*args, title='', icon=SYSTEM_TRAY_MESSAGE_ICON_INFORMATION, dis | ||||||
|     The return code specifies why the call is returning (e.g. did the user click the message to dismiss it) |     The return code specifies why the call is returning (e.g. did the user click the message to dismiss it) | ||||||
| 
 | 
 | ||||||
|     :param title: (str) Text to be shown at the top of the window in a larger font |     :param title: (str) Text to be shown at the top of the window in a larger font | ||||||
|  |     :type title: (str) | ||||||
|     :param message: (str) Text message that makes up the majority of the window |     :param message: (str) Text message that makes up the majority of the window | ||||||
|     :param icon: Union[bytes, str] A base64 encoded PNG/GIF image or PNG/GIF filename that will be displayed in the window |     :type message: (str) | ||||||
|  |     :param icon: A base64 encoded PNG/GIF image or PNG/GIF filename that will be displayed in the window | ||||||
|  |     :type icon: Union[bytes, str] | ||||||
|     :param display_duration_in_ms: (int) Number of milliseconds to show the window |     :param display_duration_in_ms: (int) Number of milliseconds to show the window | ||||||
|  |     :type display_duration_in_ms: (int) | ||||||
|     :param fade_in_duration: (int) Number of milliseconds to fade window in and out |     :param fade_in_duration: (int) Number of milliseconds to fade window in and out | ||||||
|  |     :type fade_in_duration: (int) | ||||||
|     :param alpha: (float) Alpha channel. 0 - invisible 1 - fully visible |     :param alpha: (float) Alpha channel. 0 - invisible 1 - fully visible | ||||||
|     :param location: Tuple[int, int] Location on the screen to display the window |     :type alpha: (float) | ||||||
|     :return: (int) reason for returning |     :param location: Location on the screen to display the window | ||||||
|  |     :type location: Tuple[int, int] | ||||||
|  |     :return: reason for returning | ||||||
|  |     :rtype: (int) | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
|     if not args: |     if not args: | ||||||
|  | @ -13739,6 +13832,8 @@ def popup_notify(*args, title='', icon=SYSTEM_TRAY_MESSAGE_ICON_INFORMATION, dis | ||||||
|         total_lines += height |         total_lines += height | ||||||
| 
 | 
 | ||||||
|     message = output |     message = output | ||||||
|  | 
 | ||||||
|  |     # def __init__(self, menu=None, filename=None, data=None, data_base64=None, tooltip=None, metadata=None): | ||||||
|     return SystemTray.notify(title=title, message=message, icon=icon, display_duration_in_ms=display_duration_in_ms, fade_in_duration=fade_in_duration, alpha=alpha, location=location) |     return SystemTray.notify(title=title, message=message, icon=icon, display_duration_in_ms=display_duration_in_ms, fade_in_duration=fade_in_duration, alpha=alpha, location=location) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -13766,20 +13861,35 @@ def shell_with_animation(command, args=None, image_source=DEFAULT_BASE64_LOADING | ||||||
|     command is being executed.  Without this mechanism, the GUI appears locked up. |     command is being executed.  Without this mechanism, the GUI appears locked up. | ||||||
| 
 | 
 | ||||||
|     :param command: (str) The command to run |     :param command: (str) The command to run | ||||||
|  |     :type command: (str) T | ||||||
|     :param args: List[str] List of arguments |     :param args: List[str] List of arguments | ||||||
|     :param image_source: Union[str, bytes] Either a filename or a base64 string. |     :type args: List[str] | ||||||
|  |     :param image_source: Either a filename or a base64 string. | ||||||
|  |     :type image_source: Union[str, bytes] | ||||||
|     :param message: (str) An optional message to be shown with the animation |     :param message: (str) An optional message to be shown with the animation | ||||||
|  |     :type message: (str) | ||||||
|     :param background_color: (str) color of background |     :param background_color: (str) color of background | ||||||
|  |     :type background_color: (str) | ||||||
|     :param text_color: (str) color of the text |     :param text_color: (str) color of the text | ||||||
|     :param font: Union[str, tuple) specifies the font family, size, etc |     :type text_color: (str) | ||||||
|  |     :param font:  specifies the font family, size, etc | ||||||
|  |     :type font: Union[str, tuple] | ||||||
|     :param no_titlebar: (bool)  If True then the titlebar and window frame will not be shown |     :param no_titlebar: (bool)  If True then the titlebar and window frame will not be shown | ||||||
|  |     :type no_titlebar: (bool) | ||||||
|     :param grab_anywhere: (bool) If True then you can move the window just clicking anywhere on window, hold and drag |     :param grab_anywhere: (bool) If True then you can move the window just clicking anywhere on window, hold and drag | ||||||
|  |     :type grab_anywhere: (bool) | ||||||
|     :param keep_on_top:  (bool) If True then Window will remain on top of all other windows currently shownn |     :param keep_on_top:  (bool) If True then Window will remain on top of all other windows currently shownn | ||||||
|     :param location:  (int, int) (x,y) location on the screen to place the top left corner of your window. Default is to center on screen |     :type keep_on_top: (bool) | ||||||
|  |     :param location:  (x,y) location on the screen to place the top left corner of your window. Default is to center on screen | ||||||
|  |     :type location: (int, int) | ||||||
|     :param alpha_channel: (float) Window transparency 0 = invisible 1 = completely visible. Values between are see through |     :param alpha_channel: (float) Window transparency 0 = invisible 1 = completely visible. Values between are see through | ||||||
|  |     :type alpha_channel: (float) | ||||||
|     :param time_between_frames: (int) Amount of time in milliseconds between each frame |     :param time_between_frames: (int) Amount of time in milliseconds between each frame | ||||||
|  |     :type time_between_frames: (int) | ||||||
|     :param transparent_color: (str) This color will be completely see-through in your window. Can even click through |     :param transparent_color: (str) This color will be completely see-through in your window. Can even click through | ||||||
|     :return: (str) The resulting string output from stdout |     :type transparent_color: (str) | ||||||
|  |     :return: The resulting string output from stdout | ||||||
|  |     :rtype: (str) | ||||||
|     """ |     """ | ||||||
| 
 | 
 | ||||||
|     global __shell_process__ |     global __shell_process__ | ||||||
|  | @ -13833,8 +13943,6 @@ POPOUT_WINDOW_FONT = 'Sans 8' | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class _Debugger(): | class _Debugger(): | ||||||
|     """ """ |  | ||||||
| 
 |  | ||||||
|     debugger = None |     debugger = None | ||||||
| 
 | 
 | ||||||
|     #     #                    ###### |     #     #                    ###### | ||||||
|  | @ -13846,7 +13954,6 @@ class _Debugger(): | ||||||
|     #     # #    # # #    #    ######  ###### #####   ####   ####   ####  ###### #    # |     #     # #    # # #    #    ######  ###### #####   ####   ####   ####  ###### #    # | ||||||
| 
 | 
 | ||||||
|     def __init__(self): |     def __init__(self): | ||||||
|         """ """ |  | ||||||
|         self.watcher_window = None  # type: Window |         self.watcher_window = None  # type: Window | ||||||
|         self.popout_window = None  # type: Window |         self.popout_window = None  # type: Window | ||||||
|         self.local_choices = {} |         self.local_choices = {} | ||||||
|  | @ -13858,11 +13965,6 @@ class _Debugger(): | ||||||
| 
 | 
 | ||||||
|     # Includes the DUAL PANE (now 2 tabs)!  Don't forget REPL is there too! |     # Includes the DUAL PANE (now 2 tabs)!  Don't forget REPL is there too! | ||||||
|     def _build_main_debugger_window(self, location=(None, None)): |     def _build_main_debugger_window(self, location=(None, None)): | ||||||
|         """ |  | ||||||
| 
 |  | ||||||
|         :param location: |  | ||||||
| 
 |  | ||||||
|         """ |  | ||||||
|         ChangeLookAndFeel(COLOR_SCHEME) |         ChangeLookAndFeel(COLOR_SCHEME) | ||||||
| 
 | 
 | ||||||
|         def InVar(key1): |         def InVar(key1): | ||||||
|  | @ -13934,12 +14036,6 @@ class _Debugger(): | ||||||
|     #     # #    # # #    #    #######   ##   ###### #    #   #      #######  ####   ####  # |     #     # #    # # #    #    #######   ##   ###### #    #   #      #######  ####   ####  # | ||||||
| 
 | 
 | ||||||
|     def _refresh_main_debugger_window(self, mylocals, myglobals): |     def _refresh_main_debugger_window(self, mylocals, myglobals): | ||||||
|         """ |  | ||||||
| 
 |  | ||||||
|         :param mylocals: |  | ||||||
|         :param myglobals: |  | ||||||
| 
 |  | ||||||
|         """ |  | ||||||
|         if not self.watcher_window:  # if there is no window setup, nothing to do |         if not self.watcher_window:  # if there is no window setup, nothing to do | ||||||
|             return False |             return False | ||||||
|         event, values = self.watcher_window.Read(timeout=1) |         event, values = self.watcher_window.Read(timeout=1) | ||||||
|  | @ -14077,11 +14173,6 @@ class _Debugger(): | ||||||
|     # displays them into a single text box |     # displays them into a single text box | ||||||
| 
 | 
 | ||||||
|     def _display_all_vars(self, dict): |     def _display_all_vars(self, dict): | ||||||
|         """ |  | ||||||
| 
 |  | ||||||
|         :param dict: |  | ||||||
| 
 |  | ||||||
|         """ |  | ||||||
|         num_cols = 3 |         num_cols = 3 | ||||||
|         output_text = '' |         output_text = '' | ||||||
|         num_lines = 2 |         num_lines = 2 | ||||||
|  | @ -14121,11 +14212,6 @@ class _Debugger(): | ||||||
|        #    #    # #    # # #    # #####  ###### ######  ####      ## ##  # #    # |        #    #    # #    # # #    # #####  ###### ######  ####      ## ##  # #    # | ||||||
| 
 | 
 | ||||||
|     def _choose_auto_watches(self, my_locals): |     def _choose_auto_watches(self, my_locals): | ||||||
|         """ |  | ||||||
| 
 |  | ||||||
|         :param my_locals: |  | ||||||
| 
 |  | ||||||
|         """ |  | ||||||
|         ChangeLookAndFeel(COLOR_SCHEME) |         ChangeLookAndFeel(COLOR_SCHEME) | ||||||
|         num_cols = 3 |         num_cols = 3 | ||||||
|         output_text = '' |         output_text = '' | ||||||
|  | @ -14316,8 +14402,8 @@ class _Debugger(): | ||||||
| def show_debugger_window(location=(None, None), *args): | def show_debugger_window(location=(None, None), *args): | ||||||
|     """ |     """ | ||||||
|     Shows the large main debugger window |     Shows the large main debugger window | ||||||
|     :param location: Tuple[int, int] Locations (x,y) on the screen to place upper left corner of the window |     :param location:  Locations (x,y) on the screen to place upper left corner of the window | ||||||
|     :param *args:  Not used |     :ttype location: Tuple[int, int] | ||||||
|     """ |     """ | ||||||
|     if _Debugger.debugger is None: |     if _Debugger.debugger is None: | ||||||
|         _Debugger.debugger = _Debugger() |         _Debugger.debugger = _Debugger() | ||||||
|  | @ -14340,8 +14426,8 @@ def show_debugger_popout_window(location=(None, None), *args): | ||||||
|     """ |     """ | ||||||
|     Shows the smaller "popout" window.  Default location is the upper right corner of your screen |     Shows the smaller "popout" window.  Default location is the upper right corner of your screen | ||||||
| 
 | 
 | ||||||
|     :param location: Tuple[int, int] Locations (x,y) on the screen to place upper left corner of the window |     :param location:  Locations (x,y) on the screen to place upper left corner of the window | ||||||
|     :param *args:  Not used |     :type location: Tuple[int, int] | ||||||
|     """ |     """ | ||||||
|     if _Debugger.debugger is None: |     if _Debugger.debugger is None: | ||||||
|         _Debugger.debugger = _Debugger() |         _Debugger.debugger = _Debugger() | ||||||
|  | @ -14373,7 +14459,7 @@ def _refresh_debugger(): | ||||||
|     Window._read_call_from_debugger = True |     Window._read_call_from_debugger = True | ||||||
|     # frame = inspect.currentframe() |     # frame = inspect.currentframe() | ||||||
|     # frame = inspect.currentframe().f_back |     # frame = inspect.currentframe().f_back | ||||||
|     frame, *others = inspect.stack()[0] |     frame, *others = inspect.stack()[1] | ||||||
|     try: |     try: | ||||||
|         debugger.locals = frame.f_back.f_locals |         debugger.locals = frame.f_back.f_locals | ||||||
|         debugger.globals = frame.f_back.f_globals |         debugger.globals = frame.f_back.f_globals | ||||||
|  | @ -14593,8 +14679,6 @@ def _upgrade_from_github(): | ||||||
| def main(): | def main(): | ||||||
|     """ |     """ | ||||||
|     The PySimpleGUI "Test Harness".  This is meant to be a super-quick test of the Elements. |     The PySimpleGUI "Test Harness".  This is meant to be a super-quick test of the Elements. | ||||||
| 
 |  | ||||||
|     :return: |  | ||||||
|     """ |     """ | ||||||
|     from random import randint |     from random import randint | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue