1. Field of the Invention
The invention relates generally to windowing toolkits for computers.
2. Background Art
The basic functionality of a computer is dictated both by the hardware of the computer and by the type of operating system it uses. Various operating systems exist in the marketplace, including Solaris from Sun Microsystems, Inc., MacOS from Apple Computer, Inc., the “Windows” operating systems, e.g., Windows® 95/98 and Windows NT®, from Microsoft Corporation, and Linux. A given combination of computer hardware, an operating system, and a windowing system will be referred to herein as a “platform.” Prior to the popularity of the Internet, software developers wrote programs specifically designed to run on specific platforms. Thus, a program written for one platform could not be run on another. However, the advent of the Internet made cross-platform compatibility a necessity.
Prior art
The Java™ programming language was developed by Sun Microsystems to address this problem. The Java™ programming language was designed to be simple for the programmer to use, yet to be able to run securely over a network and work on a wide range of platforms.
Prior art
A Java™ compiler 13, such as “javac” available from Sun Microsystems, Inc., is used to compile the source code into a machine-readable binary file 15. The source text file 11 will contain Java™ language commands, e.g., “import java.awt.Frame”. A discussion of the Java™ language itself is beyond the scope of this document. However, complete information regarding the Java™ programming language is available from Sun Microsystems, both in print and via the Internet at java.sun.com. The resulting binary file 15 will automatically receive the same file name as the source text file 11, but will use “.class” as the trailing extension.
The Java™ runtime environment incorporates a Java™ “virtual machine” (“JVM”) 16 to convert the “.class” byte codes into actual machine executions 17. The machine executions (like drawing windows, buttons, and user prompt fields) will occur in accordance to the application developer's code instructions. Because Sun Microsystems specifically designed the JVM to run on different platforms, a single set of “.class” byte codes will execute on any platform where a JVM has been installed. An Internet browser such as Netscape Navigator or Microsoft Internet Explorer that incorporates a JVM is called a “Java™-enabled” browser.
The cross-platform architecture of the Java™ programming language is illustrated in prior art
Typical computer applications, including most Java™ applications, provide graphical user interfaces, or GUIs. A GUI consists of graphical components, such as windows, buttons, and text fields displayed on the screen. The user interacts with an application by means of the GUI, clicking on the buttons or typing text into the text fields.
Platforms, including the Java™ platform, provide the developer convenient means for writing the GUI portions of applications in the form of user interface toolkits. Such toolkits typically include a set of pre-built graphical components (buttons, text fields, etc.) that the developer uses to build applications. The toolkits may also provide mechanisms for other functions. One such function is keeping track of which component will receive keyboard input typed by the user. Typically, at any given time, keyboard input will be directed to one special component, called the “focused component” or “focus owner”. This component may be distinguished in appearance by a highlight or a blinking caret. The user may change which component is the focused component, typically by using the mouse to click on the desired new focus owner. Many user interface toolkits will interpret such mouse clicks and respond by resetting the focus owner to the clicked-on component.
Modem platforms provide facilities for multiple graphical applications to be running at the same time, and each application may present the user with multiple windows. Therefore, a typical display will show many windows simultaneously. One of these windows will usually be distinguished, typically with a darkened titlebar, as the “active window”. The active window is the window with which the user is currently interacting. It will contain the focused component, if there is one.
Prior art
The Java™ platform provides the developer with two user interface toolkits that may be used to build applications: the Abstract Windowing Toolkit, abbreviated AWT, and Swing. The AWT has a unique architecture, in that it is built on top of each platform's native toolkit and uses each platform's native components. For example, an AWT text field consists of the native toolkit's text field component, together with additional data. The underlying native component, called the “heavyweight peer,” is used to provide much of the AWT component's functionality. For example, the AWT delegates the job of painting the component on the screen to the native toolkit. In this way, the AWT can be used to build applications that, on each platform, look and behave like the platform's native applications.
Swing, by contrast, contains no heavyweight peers. Instead, its components are “lightweight,” that is, have no corresponding native components. In fact, the underlying native toolkit is unaware of Swing's components, so nearly all of the components' functionality must be provided by Swing.
When a user interacts with a computer by typing on the keyboard or clicking the mouse on different areas of the computer screen, the underlying native platform informs the appropriate application of the user's actions by means of native “events.” These events are platform-specific and contain different information depending on the action that the user performed. For example, if the user typed a key on the keyboard, the underlying platform might generate a “key pressed” event when the key was pressed and a “key released event” when the key was released. The events will contain various information about the user action, such as which key was pressed and released or the state of the keyboard (e.g., the CAPS-LOCK key) during the user's actions.
As mentioned above, the events are generated by the underlying platform and are therefore platform-specific. Different platforms will generate different events in response to the same user actions, and the events themselves will contain different information depending on the platform that generated them. Another difference between platforms may be the way in which events are delivered to the appropriate application. On some systems, events might be placed on a queue, and it is the application's responsibility to dequeue the events and process them. On other systems, the application may register a special procedure, called an “event handler,” with the underlying platform. This event handler will be called whenever the platform wishes to deliver an event to that application.
These platform differences in events and event delivery mechanisms are some of the reasons that, prior to the Java™ platform's introduction, it was impossible for developers to write applications that worked on multiple platforms without customizing the application for each platform. The Java™ user interface toolkits address this problem by providing a uniform event model for all platforms on which the Java™ platform is implemented. The Java™ implementation hides both the native delivery mechanism and the native events themselves from its applications by registering native handlers or dequeuing native events as appropriate. Then, based on the native events it receives, it generates the appropriate “Java™ events” and delivers them to its applications via a mechanism of its own (typically by calling Java™ event handlers registered by the Java™ application.)
Because different platforms generate different native events, it follows that there is not a one-to-one mapping between native events and Java™ events. Also, because native events on different platforms contain different information, in some cases platform-specific information may be omitted from a Java™ event, while in other cases information not present in a native event may need to be computed for inclusion in a Java™ event. It is the job of the Java™ implementation on each platform to unify these differences so that Java™ applications on different platforms receive the same sequence of Java™ events when exposed to the same user actions.
One class of Java™ events generated by the Java™ implementation on each platform are focus events. A component becomes the focus owner when it receives a FocusGained event, and it ceases being the focus owner when it receives a FocusLost event. The Java™ Standard Edition SDK, version 1.4 defines a new field in its focus events: the “opposite” field. In a FocusLost event, the opposite field specifies the component that is gaining focus in conjunction with this FocusLost event, that is, it specifies where the focus is going next. In a FocusGained event, the opposite field specifies the component that is losing focus in conjunction with this FocusGained event, that is, it specifies where the focus is coming from. Some native platforms, such as those running the various Windows operating systems, provide the opposite components in their native focus events, and those components can then be included in the corresponding Java™ events. However, the X windowing system, for example, does not provide this information, so Java™ implementations on X-based platforms must compute the opposite components for inclusion in the Java™ focus events.
Therefore, there is a need for a method for computing the information to include in opposite fields of Java™ focus events.
In one aspect, the invention relates to a method for generating information for inclusion in focus events which comprises maintaining a list of components requesting focus in a selected application and determining whether a target of a first focus event matches a component at the head of the list. If the target of the first focus event matches the component at the head of the list, the method further comprises marking the component at the head of the list for inclusion in an opposite field of a second focus event.
In another aspect, the invention relates to a method for generating information for inclusion in focus events which comprises maintaining a list of components requesting focus in a selected application and determining whether a target of a first focus event matches a component at the head of the list. If the target of the first focus event matches the component at the head of the list, the method further comprises marking the component at the head of the list for inclusion in an opposite field of a second focus event and marking a component next to the component at the head of the list for inclusion in an opposite field of the first focus event.
In another aspect, the invention relates to a computer-readable medium having stored thereon a program which is executable by a processor. The program comprises instructions for maintaining a list of components requesting focus in a selected application. The program further includes determining an opposite field of a first focus event and an opposite field of a second focus event based on a target of the first focus event, a target of the second focus event, and the list of components requesting focus.
Other aspects and advantages of the invention will be apparent from the following description and the appended claims.
Specific embodiments of the invention will now be described in detail with reference to the accompanying drawings. Like elements in the various figures are denoted by the same reference numerals for consistency.
The invention described here may be implemented on virtually any type of computer regardless of the platform being used. For example, as shown in
The present invention provides a method for computing the information to include in “opposite” fields of Java™ focus events. The method works perfectly for computing such information whenever focus is transferred between components within the same top-level window. When focus transfers outside of the window, the method may fail and report the opposite component incorrectly or as “null”. However, it will recover and report opposite components correctly upon subsequent, intra-window transfers.
The method relies on two observations about the circumstances under which Java™ focus events are generated due only to the operation of the Java™ application in question. The key observation is that such events are generated only as a result of one of two causes: either a Java™-level programmatic focus request, or a user button click on a focusable heavyweight component (resulting in a native focus request on that component). In each of these two cases, a pair of events is generated: a FocusLost event on the component that previously had focus, and a FocusGained event on the component requesting focus. Thus, our second observation is that, since application-caused Java™ focus events are always generated in such “lost/gained” pairs, computing the opposite component for FocusGained events is easy: it is the component on which a FocusLost event has just been generated. If there is no such FocusLost event, then focus is coming from somewhere outside the scope of our application; in that case, we use “null” as the opposite component.
On the other hand, in order to compute the opposite component for a FocusLost event, we would need to predict the future: we would need to know what FocusGained event will be generated next. We can't know this information for certain—for example, the focus change may not be internal to the application and focus may be going to an unrelated, native application window. Recall, however, that each focus request will typically result in a FocusGained event being generated. Thus, if we keep a queue of all the focus requests, we can use it to guess the opposite component for FocusLost events. When generating a FocusLost event, we would look at the first request on the queue, use the component making the request as the opposite component in the FocusLost event, and dequeue the request.
In order to compute this information, a list of components that have issued either Java™ or native-level focus requests, but have not yet received focus notification events, is maintained. Herein, this list of components is referred to as the Focus List.
As illustrated, the process involves checking whether Focus List End is null (ST112), i.e., whether Focus List (100 in
Returning to step ST112, if Focus List End is not null, then the process involves checking whether the component requesting focus is the same as the “requestor” member of the element pointed to by Focus List End (ST120). If the component requesting focus and the “requestor” member of the element pointed to by Focus List End are the same, then no action is required (ST122). Otherwise, memory allocation is made for a new list element (ST124). The “next” member of the element pointed to by Focus List End is set to the new list element, and Focus List End is then adjusted to point to the new list element (ST126). The “requester” member of the element pointed to by Focus List End is set to the component requesting focus, and the “next” member of the element pointed to by Focus List End is set to null (ST118).
As Java™-level focus events are generated by the Java™ platform, the opposite component involved in the focus transfer is computed.
To clear the Focus List (100 in
Returning to step ST133, if the “requester” member of the list element pointed to by Focus List Head is the same as the current focus owner, then the component identified by the “requester” member is saved as the opposite field for the next FocusGained event.
Returning to step ST160, if the component at the head of the Focus List (100 in
The invention may provide general advantages in that it provides a method for computing the information required for opposite fields of focus events. The invention is useful when the native platform or native windowing toolkit does not normally provide this information. As described above, a list of components that have issued focus requests is maintained. The list is then used to determine the opposite information when focus events are processed.
While the invention has been described with respect to a limited number of embodiments, those skilled in the art, having benefit of this disclosure, will appreciate that other embodiments can be devised which do not depart from the scope of the invention as disclosed herein. Accordingly, the scope of the invention should be limited only by the attached claims.
Number | Name | Date | Kind |
---|---|---|---|
5377317 | Bates et al. | Dec 1994 | A |
5625763 | Cirne | Apr 1997 | A |
5634124 | Khoyi et al. | May 1997 | A |
5687331 | Volk et al. | Nov 1997 | A |
5724589 | Wold | Mar 1998 | A |
5872973 | Mitchell et al. | Feb 1999 | A |
6249284 | Bogdan | Jun 2001 | B1 |
6262713 | Brusky et al. | Jul 2001 | B1 |
6606106 | Mendenhall et al. | Aug 2003 | B1 |
6614457 | Sanada et al. | Sep 2003 | B1 |
6625804 | Ringseth et al. | Sep 2003 | B1 |
6654038 | Gajewska et al. | Nov 2003 | B1 |
6677933 | Yogaratnam | Jan 2004 | B1 |
6892360 | Pabla et al. | May 2005 | B1 |
20020175952 | Gajewska et al. | Nov 2002 | A1 |
Number | Date | Country |
---|---|---|
0 869 421 | Oct 1998 | EP |
Number | Date | Country | |
---|---|---|---|
20020175951 A1 | Nov 2002 | US |