From 1186dca8ad34a34355f8848c5f27e561b32ac8a2 Mon Sep 17 00:00:00 2001 From: PySimpleGUI Date: Sun, 23 May 2021 16:38:41 -0400 Subject: [PATCH] Added Window.ding(). Added more error information when a "Finalize is needed" error happens. Traceback added to all finalize needed errors so that user can be taken to the error. --- PySimpleGUI.py | 81 ++++++++++++++++++++++++++++++-------------------- 1 file changed, 49 insertions(+), 32 deletions(-) diff --git a/PySimpleGUI.py b/PySimpleGUI.py index efd83bf3..4a00dba3 100644 --- a/PySimpleGUI.py +++ b/PySimpleGUI.py @@ -1,6 +1,6 @@ #!/usr/bin/python3 -version = __version__ = "4.42.0 Released 23-May-2021" +version = __version__ = "4.42.0.1 Unreleased\nAdded Window.ding() - fun is a particularly important feature, better error reporting when finalize required" __version__ = version.split()[0] # For PEP 396 and PEP 345 @@ -8901,7 +8901,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg """ Minimize this window to the task bar """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.minimize'): return self.TKroot.iconify() self.maximized = False @@ -8914,7 +8914,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg The reason for the difference is the title bar is removed in some cases when using fullscreen option """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.maximize'): return if not running_linux(): self.TKroot.state('zoomed') @@ -8928,7 +8928,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg """ Restore a window to a non-maximized state. Does different things depending on platform. See Maximize for more. """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.normal'): return if self.TKroot.state() == 'iconic': self.TKroot.deiconify() @@ -9192,7 +9192,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg """ Disables window from taking any input from the user """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.disable'): return self.TKroot.attributes('-disabled', 1) # self.TKroot.grab_set_global() @@ -9201,7 +9201,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg """ Re-enables window to take user input after having it be Disabled previously """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.enable'): return self.TKroot.attributes('-disabled', 0) # self.TKroot.grab_release() @@ -9210,7 +9210,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg """ Hides the window from the screen and the task bar """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.hide'): return self._Hidden = True self.TKroot.withdraw() @@ -9219,7 +9219,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg """ Used to bring back a window that was previously hidden using the Hide method """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.un_hide'): return if self._Hidden: self.TKroot.deiconify() @@ -9231,7 +9231,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg channel to 0. NOTE that on some platforms alpha is not supported. The window will remain showing on these platforms. The Raspberry Pi for example does not have an alpha setting """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.disappear'): return self.TKroot.attributes('-alpha', 0) @@ -9239,7 +9239,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg """ Causes a window previously made to "Disappear" (using that method). Does this by restoring the alpha channel """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.reappear'): return self.TKroot.attributes('-alpha', 255) @@ -9250,7 +9250,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg :param alpha: 0 to 1. 0 is completely transparent. 1 is completely visible and solid (can't see through) :type alpha: (float) """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.set_alpha'): return self._AlphaChannel = alpha self.TKroot.attributes('-alpha', alpha) @@ -9272,7 +9272,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg :param alpha: 0 to 1. 0 is completely transparent. 1 is completely visible and solid (can't see through) :type alpha: (float) """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.alpha_channel'): return self._AlphaChannel = alpha self.TKroot.attributes('-alpha', alpha) @@ -9282,7 +9282,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg Brings this window to the top of all other windows (perhaps may not be brought before a window made to "stay on top") """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.bring_to_front'): return if running_windows(): try: @@ -9303,7 +9303,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg """ Pushes this window to the bottom of the stack of windows. It is the opposite of BringToFront """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.send_to_back'): return try: self.TKroot.lower() @@ -9318,7 +9318,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg :return: The x and y location in tuple form (x,y) :rtype: Tuple[(int), (int)] """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.current_location'): return return int(self.TKroot.winfo_x()), int(self.TKroot.winfo_y()) @@ -9331,7 +9331,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg :return: (width, height) of the window :rtype: Tuple[(int), (int)] or Tuple[None, None] """ - if not self._is_window_created(): + if not self._is_window_created('Tried to use Window.size property'): return (None, None) win_width = self.TKroot.winfo_width() win_height = self.TKroot.winfo_height() @@ -9360,7 +9360,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg :param size: (width, height) tuple (int, int) of the desired window size in pixels :type size: Tuple[int, int] """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.set_min_size'): return self.TKroot.minsize(size[0], size[1]) self.TKroot.update_idletasks() @@ -9381,7 +9381,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg :param color: Color string that defines the transparent color :type color: (str) """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.set_transparent_color'): return try: self.TKroot.attributes('-transparentcolor', color) @@ -9395,7 +9395,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg Turns on Grab Anywhere functionality AFTER a window has been created. Don't try on a window that's not yet been Finalized or Read. """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.grab_any_where_on'): return self.TKroot.bind("", self._StartMove) self.TKroot.bind("", self._StopMove) @@ -9407,7 +9407,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg Turns off Grab Anywhere functionality AFTER a window has been created. Don't try on a window that's not yet been Finalized or Read. """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.grab_any_where_off'): return self.TKroot.unbind("") self.TKroot.unbind("") @@ -9444,7 +9444,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg :param key: The event that will be generated when the tkinter event occurs :type key: str | int | tuple | object """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.bind'): return self.TKroot.bind(bind_string, lambda evt: self._user_bind_callback(bind_string, evt)) self.user_bind_dict[bind_string] = key @@ -9472,7 +9472,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg """ Enables the internal debugger. By default, the debugger IS enabled """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.enable_debugger'): return self.TKroot.bind('', self._callback_main_debugger_window_create_keystroke) self.TKroot.bind('', self._callback_popout_window_create_keystroke) @@ -9483,7 +9483,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg """ Disable the internal debugger. By default the debugger is ENABLED """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.disable_debugger'): return self.TKroot.unbind("") self.TKroot.unbind("") @@ -9497,7 +9497,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg :param title: The string to set the title to :type title: (str) """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.set_title'): return self.TKroot.wm_title(str(title)) @@ -9509,7 +9509,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg NOTE - Sorry Mac users - you can't have modal windows.... lobby your tkinter Mac devs """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.make_modal'): return if running_mac(): @@ -9527,7 +9527,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg """ Forces this window to take focus """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.force_focus'): return self.TKroot.focus_force() @@ -9554,7 +9554,7 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg :type cursor: (str) """ - if not self._is_window_created(): + if not self._is_window_created('tried Window.set_cursor'): return try: self.TKroot.config(cursor=cursor) @@ -9562,6 +9562,23 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg print('Warning bad cursor specified ', cursor) print(e) + + def ding(self, display_number=0): + """ + Make a "bell" sound. A capability provided by tkinter. Your window needs to be finalized prior to calling + Ring a display's bell is the tkinter description of the call + :param display_number: Passed to tkinter's bell method as parameter "displayof". + :type display_number: int + """ + if not self._is_window_created('tried Window.ding'): + return + try: + self.TKroot.bell(display_number) + except Exception as e: + if not SUPPRESS_ERROR_POPUPS: + _error_popup_with_traceback('Window.ding() - tkinter reported error from bell() call', e) + + def _window_tkvar_changed_callback(self, *args): """ Internal callback function for when the thread @@ -9697,13 +9714,13 @@ Normally a tuple, but can be a simplified-dual-color-string "foreground on backg """ return self.Read(*args, **kwargs) - def _is_window_created(self): + def _is_window_created(self, additional_message=''): + msg = str(additional_message) if self.TKroot is None: - warnings.warn('You cannot perform operations on a Window until it is read or finalized. Adding a "finalize=True" parameter to your Window creation will fix this', UserWarning) + warnings.warn('You cannot perform operations on a Window until it is read or finalized. Adding a "finalize=True" parameter to your Window creation will fix this. ' + msg, UserWarning) if not SUPPRESS_ERROR_POPUPS: - popup_error('You cannot perform operations on a Window until it is read or finalized.', - 'Yea, I know, it\'s a weird thing, but just fix it and keep going.... ', - 'Adding a "finalize=True" parameter to your Window creation will likely fix this', image=_random_error_emoji()) + _error_popup_with_traceback('You cannot perform operations on a Window until it is read or finalized.', + 'Adding a "finalize=True" parameter to your Window creation will likely fix this', msg) return False return True