None.
None.
Embodiments of the present invention relate to tracking of application responsiveness and more specifically to improving the visual experience for a user by providing improved visual feedback.
When interacting with a computer application, users may be confronted with a situation in which an application fails to appropriately respond. The application may appear to the user to be “hung” or non-responsive. Applications that appear to the user to be non-responsive may in some instances be legitimately non-responsive, but in other instances may simply fail to provide sufficient feedback to the user, when in fact the application remains operational.
In the Microsoft Windows operating system, produced by the Microsoft Corporation of Redmond Wash., applications that stop responding to messages sent by the operating system are classified as non-responsive. Other applications continue to respond to messages sent by the operating system but do not provide sufficient visual feedback to the users. As set forth above, both of these scenarios give users the impression that applications are hung.
Typically, operating systems have a mechanism for reacting to an application that is non-responsive. When the application fails to respond to messages sent by the operating system, the user can terminate the application through the operating system. A white space or ghosted screen typically appears in the window where the application was shown. Thus, visual treatments for non-responsive applications are not descriptive and do not provide sufficient visual feedback to the user.
Furthermore, no solution exists for tracking poorly behaved applications that, although they are responsive, provide insufficient visual feedback to users. A poorly behaved application may be sending messages to the operating system and receiving messages from the operating system, but fail to show a user prompt or dialog box in a manner that will appropriately alert the user that a response is required.
Accordingly, a solution is needed for determining whether an application is non-responsive or is merely awaiting user input. Furthermore a solution is needed for improving the visual treatment applied to application windows that are either non-responsive or that are operating normally but fail to provide a user with sufficient visual feedback to enable the user to continue working with the application. Furthermore, a solution is needed that enables a user to distinguish between a non-responsive and a poorly behaved application.
Embodiments of the present invention are directed to a method for ensuring, from a computer operating system, that a responsive application is providing sufficient visual feedback to a user. The method includes determining whether the application is showing a dialog to the user and determining whether any shown dialog is visible to the user. The method additionally includes repositioning any dialog not visible to the user so that the repositioned dialog becomes visible to the user.
In an additional aspect of the invention, a method provides visual feedback to a user from a computer operating system to indicate non-responsive application status. The method includes determining a non-responsive application state by finding one of a ghosted application window and lack of an application dialog. The method further includes capturing an application window state and applying a visual treatment to each application window for the application using the captured application window state.
In yet a further aspect of the invention, a method for monitoring application status and responding with visual feedback from an operating system is provided. The method includes determining if an application window is ghosted and sending a message to an application if the application window is not ghosted. The method additionally includes waiting for a response from the application for a pre-set time period and determining whether the application is showing a dialog if the application provides a response within the pre-set time period. The method additionally includes applying a visual treatment to the application window if the application window is ghosted and applying a visual treatment if the application is not showing a dialog.
In yet a further aspect of the invention, a system is provided for monitoring application status and responding with visual feedback from an operating system. The system includes an application state monitoring component for determining whether an application is responsive, a window state capture component for capturing a state of a non-responsive application, and window appearance control components for altering an appearance of a non-responsive application window using the captured state.
In yet an additional aspect of the invention, a system is provided for monitoring application status and responding with visual feedback from an operating system. The system includes an application state monitoring component for determining whether an application is responsive and whether an application is showing a dialog. The system additionally includes a dialog manipulation component for re-positioning the dialog for a responsive application that provides a dialog that is not visible to the user. The system additionally includes window appearance control components for altering an appearance of a non-responsive application window.
The present invention is described in detail below with reference to the attached drawings figures, wherein:
I. System Overview
Embodiments of the invention include a method and system for monitoring an application and providing suitable visual treatment in accordance with a hung or non-responsive application status.
The application window monitoring and correction system 200 operates within the operating system 10 to monitor states of the applications 20, 30, and 40 and application windows 60. A user interacts with the operating system 10 and applications 20, 30, 40 through application windows 60 provided on the user interface 50.
The applications 20, 30, 40 may include any type of application including, but not limited to word processing applications, spreadsheet applications, Internet browsers, etc. The application window monitoring and correction system 200 may be included in any type of operating system including Microsoft Windows.
The system and method of the invention allow visual treatment to be applied to a last active state of applications. The visual treatment is preferably in the form of a frosting. However, other visual treatments may also be utilized. Any of a number of visual treatments that will allow a user to distinguish a responsive application window from a non-responsive application window may be used.
The system and method further detect hidden dialogs that are shown in response to an application closing or exit request. The system and method additionally trap applications that respond to messages but ignore close commands and detect applications that do not provide visual feedback in response to user requests to close. Through these functions, a user is able to more readily distinguish between a non-responsive application and an improperly functioning application window.
II. Exemplary Operating Environment
The invention is described in the general context of computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. Moreover, those skilled in the art will appreciate that the invention may be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers, and the like. The invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer storage media including memory storage devices.
With reference to
Computer 110 typically includes a variety of computer readable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. The system memory 130 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 131 and random access memory (RAM) 132. A basic input/output system 133 (BIOS), containing the basic routines that help to transfer information between elements within computer 110, such as during start-up, is typically stored in ROM 131. RAM 132 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 120. By way of example, and not limitation,
The computer 110 may also include other removable/nonremovable, volatile/nonvolatile computer storage media. By way of example only,
The drives and their associated computer storage media discussed above and illustrated in
The computer 110 in the present invention will operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 180. The remote computer 180 may be a personal computer, and typically includes many or all of the elements described above relative to the computer 110, although only a memory storage device 181 has been illustrated in
When used in a LAN networking environment, the computer 110 is connected to the LAN 171 through a network interface or adapter 170. When used in a WAN networking environment, the computer 110 typically includes a modem 172 or other means for establishing communications over the WAN 173, such as the Internet. The modem 172, which may be internal or external, may be connected to the system bus 121 via the user input interface 160, or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 110, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation,
Although many other internal components of the computer 110 are not shown, those of ordinary skill in the art will appreciate that such components and the interconnection are well known. Accordingly, additional details concerning the internal construction of the computer 110 need not be disclosed in connection with the present invention.
III. System and Method of the Invention
As set forth above,
In the first scenario, the application window monitoring and correction system 200 monitors the application window to determine if the application window is a ghosted window. As explained above, a ghosted window is an effect that is typically shown when an application is not responding. The system knows that an application is not responding if the ghosted window is present. If the window is ghosted, the user interacts with the application in step A04, and the application window monitoring and correction system applies a visual treatment such as frosting to the application window in step A08 and offers an application termination dialog.
In the second scenario, after a user interacts with an application in step B02, the application window monitoring and correction system 200 determines if the application window is ghosted in step B04.
If the application window is ghosted in step B04, then the application is non-responsive and the process continues to step B30, in which the application window monitoring and correction system 200 applies a visual treatment such as frosting to all application windows in the process set. In step B32, the system begins the reporting process.
If the application window is not ghosted in step B04, the application window monitoring and correction system does not know if the application is healthy and accordingly takes steps to determine if the application is non-responsive. In step B06, the application monitoring and correction system sends “WM_Close” messages to the application to determine if application is healthy.
If the application does not respond within a pre-set threshold of “N” seconds in step B08, the system determines that the application is not responsive and begins to forcibly terminate the application. The system proceeds to step B30 to apply an appropriate visual treatment such as frosting to all windows in the process set.
Alternatively, if the application does respond within the pre-set time threshold in step B08, the system determines that since the application has responded, the application is healthy. Thereafter the system will determine whether the application has responded in an acceptable manner.
In step B10, the system determines if the application is showing a dialog. If the application is not showing the dialog in step B10, the system captures the state of the current window in step B18. After waiting a predetermined number of seconds in step B20, the system determines if the application closed in step B22. If the application does not provide any feedback to the user after a certain amount of time, the invention prompts the user to forcefully terminate, even though the application is still sending messages. If the application closed in step B22, the system enables related windows in step B4. If the application did not close in step B22, the system determines if the application changed its application window state in step B28. If the application did not change its application window state in step B28, the system applies the appropriate visual treatment, such as frosting, to all windows in the process set in step B30 and begins the reporting process in step B32. If the application did change its window state in step B28, the system enables related windows in step B24.
Returning to step B10, if the application is showing the dialog in step B10, the system examines whether the application shows a dialog that is visible to the user. The system determines whether the dialog is hidden in step B12. For instance, the dialog may be buried in the z-order and may not be visible on the user screen. If the dialog is not hidden in step B12, the application is behaving properly and all related windows are enabled in step B24. If the dialog is hidden in step B12, the system moves the dialog to a visible position for the user in step B14. In step B16, the system returns the window to its normal state by unfrosting or unghosting and the application proceeds to operate normally. All related windows are enabled in step B24 and the process is complete in step B26.
The application window shows a bitmap that replaces a hole in an application that would normally appear when an application ceases to respond. When applications become non-responsive, the last active visual representation for those application windows is captured and superimposed with a visual treatment thus identifying those windows as non-responsive.
The visual treatment referred to as “frosting” can be accomplished using a series of steps. These steps include boosting RGB values and alpha blending them with captured windows. The frosting process may then segment captured windows into sections. One or more stored frosting bitmaps may then be combined through a randomization function to distribute frosting bitmaps. The process then superimposes a frosted window with a saturated application window.
In summary, the system of the invention determines if an application is non-responsive and applies a visual treatment to non-responsive application windows in order to give better feedback to computer users. The system also traps poorly behaved applications that respond to messages from the operating system but do not provide UI feedback to the user.
The system and method of the invention provide a highly visible technique for identifying and displaying non-responsive applications. Non-responsive applications are a frequent problem for computer users and this technique will allow operating systems to provide a better user experience for the non-responsive application problem. The technique for detecting poorly behaved applications addresses new classes of scenarios that other operating systems currently overlook. Prevention of data loss occurs by notifying user that an application that appears to be hung is actually still responsive.
While particular embodiments of the invention have been illustrated and described in detail herein, it should be understood that various changes and modifications might be made to the invention without departing from the scope and intent of the invention. The embodiments described herein are intended in all respects to be illustrative rather than restrictive. Alternate embodiments will become apparent to those skilled in the art to which the present invention pertains without departing from its scope. From the foregoing it will be seen that this invention is one well adapted to attain all the ends and objects set forth above, together with other advantages, which are obvious and inherent to the system and method. It will be understood that certain features and sub-combinations are of utility and may be employed without reference to other features and sub-combinations. This is contemplated and within the scope of the appended claims.
Number | Name | Date | Kind |
---|---|---|---|
5075675 | Barker et al. | Dec 1991 | A |
5363483 | Jones et al. | Nov 1994 | A |
5455904 | Bouchet et al. | Oct 1995 | A |
5499334 | Staab | Mar 1996 | A |
5515493 | Boston et al. | May 1996 | A |
5815702 | Kannan et al. | Sep 1998 | A |
5859639 | Ebrahim | Jan 1999 | A |
5911060 | Elliott | Jun 1999 | A |
6009258 | Elliott | Dec 1999 | A |
6009440 | Watson et al. | Dec 1999 | A |
6026362 | Kim et al. | Feb 2000 | A |
6118451 | Alexander | Sep 2000 | A |
6230286 | Shapiro et al. | May 2001 | B1 |
6239796 | Alexander | May 2001 | B1 |
6314532 | Daudelin et al. | Nov 2001 | B1 |
6407759 | Kanungo et al. | Jun 2002 | B1 |
6438709 | Poisner | Aug 2002 | B2 |
6459440 | Monnes et al. | Oct 2002 | B1 |
6567937 | Flores et al. | May 2003 | B1 |
6630946 | Elliott et al. | Oct 2003 | B2 |
6701454 | Fischer et al. | Mar 2004 | B1 |
6801230 | Driskell | Oct 2004 | B2 |
6850257 | Colleran et al. | Feb 2005 | B1 |
6874125 | Carroll et al. | Mar 2005 | B1 |
6915449 | Bantz et al. | Jul 2005 | B2 |
7019757 | Brown et al. | Mar 2006 | B2 |
7028056 | Hendel et al. | Apr 2006 | B1 |
7039872 | Raheman | May 2006 | B1 |
7047533 | Circenis | May 2006 | B2 |
7149928 | van Os | Dec 2006 | B2 |
7207047 | Subramanian et al. | Apr 2007 | B2 |
7219264 | Pail et al. | May 2007 | B2 |
20020152228 | Lopez et al. | Oct 2002 | A1 |
20020162053 | Os | Oct 2002 | A1 |
20030007004 | Kanungo et al. | Jan 2003 | A1 |
20030112278 | Driskell | Jun 2003 | A1 |
20030142137 | Brown et al. | Jul 2003 | A1 |
20030142140 | Brown et al. | Jul 2003 | A1 |
20040056900 | Blume | Mar 2004 | A1 |
20040078734 | Deuter | Apr 2004 | A1 |
20040130565 | Fujita et al. | Jul 2004 | A1 |
20050091611 | Colleran et al. | Apr 2005 | A1 |
20060031781 | Keohane et al. | Feb 2006 | A1 |
20060200702 | Canning et al. | Sep 2006 | A1 |
20070050769 | Switzer et al. | Mar 2007 | A1 |
20070074128 | Lim et al. | Mar 2007 | A1 |
Number | Date | Country | |
---|---|---|---|
20050257168 A1 | Nov 2005 | US |