US20030098886A1 - User interface and method for maximizing the information presented on a screen - Google Patents

User interface and method for maximizing the information presented on a screen Download PDF

Info

Publication number
US20030098886A1
US20030098886A1 US10/322,628 US32262802A US2003098886A1 US 20030098886 A1 US20030098886 A1 US 20030098886A1 US 32262802 A US32262802 A US 32262802A US 2003098886 A1 US2003098886 A1 US 2003098886A1
Authority
US
United States
Prior art keywords
display
window
mode
graphical
invisible
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US10/322,628
Inventor
Steve Janssen
Annette Gottstein-Puri
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Kongsberg Geospatial Ltd
Original Assignee
Gallium Software Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Gallium Software Inc filed Critical Gallium Software Inc
Priority to US10/322,628 priority Critical patent/US20030098886A1/en
Publication of US20030098886A1 publication Critical patent/US20030098886A1/en
Assigned to GALLIUM VISUAL SYSTEMS INC. reassignment GALLIUM VISUAL SYSTEMS INC. CHANGE OF NAME (SEE DOCUMENT FOR DETAILS). Assignors: 4340965 CANADA INC.
Assigned to 4340965 CANADA INC. reassignment 4340965 CANADA INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: GALLIUM SOFTWARE INC.
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0481Interaction techniques based on graphical user interfaces [GUI] based on specific properties of the displayed interaction object or a metaphor-based environment, e.g. interaction with desktop elements like windows or icons, or assisted by a cursor's changing behaviour or appearance
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/451Execution arrangements for user interfaces
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2203/00Indexing scheme relating to G06F3/00 - G06F3/048
    • G06F2203/048Indexing scheme relating to G06F3/048
    • G06F2203/04804Transparency, e.g. transparent or translucent windows

Definitions

  • the present invention generally relates to methods for displaying graphical information on a computer system, and more particularly, the present invention relates to a computer controlled display system for organizing the display of a high volume of information and a user interface to allow the operator to readily view all sets of information.
  • a windowing environment is system software that manages interactions between a user and an application program executing on a computer through a graphical display monitor.
  • the graphical display is arranged to resemble an electronic “desktop”, and each sheet of information on the “desktop” is displayed in a rectangular region of the screen called a “window”.
  • the windows on the “desktop” can be organized in a variety of different ways. They can be tiled so the contents of each window are totally visible to the operator, they can be overlapped so that the contents of a window partially overlays another window, or they can be stacked so that one window completely overlays another window.
  • the windows on the desktop can be used to contain any object, including simple objects such as menus, forms and tables and complex objects such as spreadsheets and radar displays for air traffic control.
  • GUI Graphical User Interface
  • the windows can be made larger or smaller, they can be expanded to be the full screen size, they can be moved to a different position on the screen, or they can be reduced to an icon.
  • An icon is a small, visually distinct display object which represents the window.
  • the windows are used to represent static information such as documents and spreadsheets.
  • the content of a window changes only when a change is effected by the operator.
  • the information in the windows changes dynamically independently of operator intervention.
  • one window may contain a geographic view of the airspace in which aircraft are plotted on the display according to their current position based on radar reports.
  • Another window may have a dynamically changing table summarizing details about each aircraft including information such as current speed and altitude, which is updated based on radar reports.
  • a still further problem is that the windowing systems on most modern computers (for X11 windows in the Unix environment) do not update data that lie directly beneath a window. Even if such a window is transparent, it will not be updated. Modern window systems typically cannot process input events on objects that are not drawn.
  • the present invention provides a method of designating windows as invisible so that information in background windows is not obscured, a user interface for viewing and hiding the data in the foreground window on demand, and a method for managing and rendering the displays when working with invisible windows.
  • One aspect of the present invention seeks to provide the operator with a rapid means of exposing/hiding information in windows.
  • Another aspect of the invention seeks to provide a method and system for updating images which reside beneath a window.
  • the present invention provides a method and user interface technique that allows the operator to maintain a large number of windows all containing information necessary for the operator to perform his task, while at the same time not obscuring other windows which are essential to perform the task.
  • This approach significantly increases operator productivity and also increases safety when employed in safety critical applications since it permits the operator to maintain maximum awareness of the main safety critical situation window, while still providing immediate access to the other information necessary for the operator to perform his task.
  • the invention operates in a standard environment of computer workstation with a graphical display. Information is displayed in “windows” on the graphical display, and the operator interacts with the display with standard input devices such as a keyboard and a mouse.
  • This invention may be embodied in an application program that executes on the workstation or any other type of program, including the Operating System which controls the workstation.
  • This invention consists of a user interface which provides the operator with a rapid means to expose and hide information in invisible windows.
  • the “invisible” windows can be totally invisible (i.e., there is no visual indication of their location), the windows may have a title bar that is visible, the: windows may have a window border that is visible, or the windows may have a title bar and window border that is visible.
  • These latter states provide the operator with a visual clue as to the location of the hidden window. In all these cases, the contents of the invisible window are not displayed and the background window is fully visible through the invisible window.
  • each invisible window is provided the ability to designate each invisible window as “normal”, “timed”, “locked”, or “timed icon”.
  • the user is also able to reduce an invisible window to an icon at any time. When an invisible window is reduced to an icon no window operations can be performed on the window until the icon is raised back into an invisible window.
  • the contents of the window are exposed when the cursor moves into the area of the window.
  • the window contents can be exposed either by allowing the window to be displayed on an opaque background, which enhances legibility of the window contents, or on a transparent background, which enables the contents of the background windows to be visible underneath the invisible window.
  • the window contents are hidden again by simply moving the cursor away from the window.
  • “timed” mode the contents of the window are exposed in the manner described above for a specified period of time, at which time the window automatically returns to its invisible state.
  • the “locked” mode the contents of the window are exposed in the opaque manner described above until another mode is selected for the window.
  • “timed icon” mode the contents of the window are exposed in the manner described above for a specified period of time, at which time the window is automatically reduced to an icon.
  • the invention can render windows which are not directly contained in the computer's native windows and provides unique drawing strategies to ensure that updates occur to data that lay beneath a given window.
  • FIG. 1 is a pictorial front view of a typical computer
  • FIG. 2 is a display presentation of an opaque window technique
  • FIG. 3 is the display presentation of FIG. 2, using a transparent window technique according to the invention.
  • FIG. 4 illustrates the display of FIG. 2 when the cursor is moved over the transparent window
  • FIG. 5 shows the display mode menu
  • FIG. 6 shows the general software architecture of a transparent window system according to the invention
  • FIG. 7 is a flowchart illustrating the logic used to process a motion event detected on a window
  • FIG. 8 is a flowchart illustrating the logic used to process a transparent time out event
  • FIG. 9 is a flowchart illustrating the logic used to process a timed icon time out event
  • FIG. 10 shows application oriented objects contained in the system of FIG. 6;
  • FIG. 11 is a flowchart illustrating the logic used to update areas located under a transparent window
  • FIG. 12 is a flowchart illustrating the logic used to implement behavior for objects which are invisible.
  • FIG. 1 depicts a typical computer system suitable for supporting the present invention.
  • FIG. 1 is but one of many computer configurations that can support the present invention.
  • FIG. 1 shows a computer system consisting of an output device I (display monitor), input devices (mouse 5 and keyboard 6 ) and a system chassis 3 .
  • Other configurations might include flat screen displays, X-terminals, trackballs, touch screens and other devices.
  • the system chassis 3 contains components such as the Central Processing Unit (CPU), memory, hard disk storage, power supply, local area network, parallel printer I/O, serial I/O, and video generation hardware.
  • the system chassis 3 may contain optional items such as CDROMs, tape drives, sound generation facilities and others.
  • the present invention provides a means to efficiently manage screen space when there are conflicting demands of high priority information in background windows which occupy large portions of the display surface 2 and numerous information windows overlaying it.
  • the present invention can be implemented at four different levels in a computer system. It can be applied in the graphics generation hardware, the operating system graphics subsystem software (X Windows, OpenGL®, Microsoft Windows®, Apple MacO/S®, etc.), a User Interface Management System (UIMS), or in application software.
  • UIMS User Interface Management System
  • a UIMS is a layer of software which manages all display and user device input activities for a specific application. The description is divided into three parts: Part 1 describes the invention as manipulated by the operator; Part 2 describes the invention in terms of the software algorithms which describe its operation; Part 3 describes the features of the UIMS to support the event capture and drawing techniques necessary.
  • FIG. 2 depicts a typical application display presentation where the present invention would greatly enhance operator usability and operator access to important data.
  • normal windowing techniques are in force.
  • the high importance background data 8 (radar return information in this case) is being obscured by multiple overlapping user interface windows 7 .
  • overlapping windows 7 are a necessary part of the user's displayed information set. They are explicitly requested by the user and necessarily appear on top of the background data 8 .
  • the present invention provides the operator with techniques to control their property of covering underlying data.
  • FIG. 3 depicts the same application with the invisible window feature operating. Notice now that the overlapping windows 10 no longer obscure the background radar data 9 . The overlapping windows' title bars and window frames 11 are still visible giving the user visible cues as to where the windows will be when opaque. The view of the background radar in FIG. 3 is vastly improved over that in FIG. 2.
  • FIG. 4 demonstrates the system's reaction to moving the cursor over an invisible window. Notice that the cursor 16 is now over the table titled “Category Select—CATEGORY” 15 . This table is now opaque while the others 14 remain invisible. The background data 13 is covered by tables 15 but remains unaffected by tables 14 .
  • FIG. 5 depicts the display mode menu.
  • the menu consists of four buttons 19 , 20 , 21 , 22 .
  • Each button has a graphical icon and textual label. When a button is selected, its icon is placed in the display mode menu 18 as seen in buttons 17 of FIG. 4. Each window can be placed in a separate mode.
  • Button 19 is used to activate the Normal display mode. In this mode all overlapping windows are invisible by default. A window becomes opaque when the cursor is placed within its extent. When the cursor leaves its extent the window becomes invisible again.
  • Button 20 is used to activate the Timed display mode. In this mode all overlapping windows are invisible by default. A window becomes opaque when the cursor is placed within its extent. When the cursor leaves its extent the window becomes invisible only after a time-out has occurred. This time-out is programmable but is typically 10 seconds. The time-out is terminated if the cursor is placed over the window before it turns invisible.
  • Button 21 is used to activate the Locked display mode. In this mode the overlapping windows are always opaque.
  • Button 22 is used to activate the Timed-Icon display mode. In this mode all overlapping windows are invisible-by default. A window becomes opaque when the cursor is placed within its extent. When the cursor leaves its extent a two step time-out process begins. After the first time-out, the window goes invisible and the second timeout begins. After the second time-out, the window automatically iconifies. Window 23 in FIG. 4 illustrates an iconified window. These time-outs are configurable but are typically ten seconds. The time-outs are terminated if the cursor is placed over the window before the operation completes.
  • FIG. 6 illustrates the general software architecture of the invisible window system.
  • a window has three pieces of data associated with it for the purposes of this discussion.
  • Each window has a unique identity stored in window id.
  • Each window can operate in one of four modes: Normal, Locked, Timed, or Timed-Icon.
  • Each window can be in one of three states: invisible, opaque or iconified.
  • the user moves the mouse 26 pointer from an opaque state window to the background which generates a hardware event 32 .
  • the operating system 25 services the hardware mouse event 32 and passes a message 29 to the UIMS 24 .
  • the UIMS 24 maintains the extent of all objects it manages. It traverses this list examining each window's extent to determine if the cursor now lies within the same window as the previous event if the UIMS 24 does not find a match, the UIMS checks if the cursor was previously on an opaque window. If true, the UIMS 24 next determines if that window has been designated as a potentially invisible window. If the window is designated as potentially invisible the application defined invisible state 30 is applied to the window by the UIMS 24 .
  • the user may specify the invisible state 30 to the UIMS such that the entire window becomes invisible or just user specified portions of it become invisible. The application of this state causes the UIMS 24 to redraw the window on the display 28 according to the invisible state specifications.
  • the user moves the mouse 26 pointer over an invisible window which generates a hardware event 32 .
  • the operating system 25 services the hardware mouse event 32 and passes a message 29 to the UIMS 24 .
  • the UIMS 24 maintains the extent of all objects it manages. It traverses this list examining each window's extent to determine if the cursor now lies within that extent. If the UIMS 24 finds a match, it next determines if that window has been designated as an invisible window. If the window is designated as potentially opaque the application defined normal state 30 is applied from the window by the UIMS 24 . The application of this state causes the UIMS 24 to redraw the window on the display 28 according to the normal state specifications. The UIMS 24 notes the fact that the cursor is over a particular window which is now opaque.
  • FIGS. 7 through 10 depict flow chart views of the logic within the UIMS 24 .
  • an algorithm depicted in FIG. 7 is initiated 33 .
  • the algorithm compares 34 the window id in the event message with the stored previous window id. If the window ids are the same, the algorithm terminates 44 .
  • the mode of the window is tested 35 . If the window is in normal mode then apply the invisible state to the window 36 . If the window is not in normal state then test to see if it is in Timed mode 37 . If the window is in Timed mode then schedule a “timed invisible” time out event to start 39 . If the window is not in Timed mode then test to see if it is in Timed-Icon mode 38 . If the window is in Timed-Icon mode then schedule a “timed invisible” time out event to start 39 . Regardless of which mode the current window is in the state of the previous window is now tested 40 . If the current window is invisible, remove the invisible state 41 to make the window opaque. Next, store the current window id as the previous window id 42 and remove any time outs that may be pending on the window from previous cursor movement 43 . This algorithm now terminates and regular processing continues.
  • FIG. 8 depicts the algorithm used to process “timed invisible” time out events.
  • the algorithm is initiated when a time out of type “timed invisible” is received 45 .
  • the window state is set to invisible and the window is checked to see if it is in Timed-Icon mode 48 . If it is a new time out of type “timed icon” is initiated 47 .
  • the algorithm now terminates 49 .
  • FIG. 9 depicts the algorithm used to process “timed icon” time out events.
  • the algorithm is initiated when a time out of type “timed icon” is received 50 .
  • the window state is set to iconified 51 .
  • the algorithm now terminates 52 .
  • the UIMS of FIG. 6 contains application-oriented objects, hierarchical InterMAPhics display lists, and one or more rasterized images. Representations of the objects are maintained in the display lists by the presentation manager, and the rasterized images are created from the display lists by the renderer. This is shown in detail in FIG. 10.
  • the application oriented objects include the user interface windows used to present information to the operators.
  • Each object has the following properties:
  • the presentation manager maintains the hierarchical display lists according to the current properties of the application-oriented objects.
  • the presentation manager provides the following functionality:
  • the hierarchical UIMS display lists contain graphical data describing the appearance of the display.
  • the display lists have the following characteristics:
  • graphical data consisting of vector-based graphical primitives and symbolic graphical attributes such as color, drawing style, and text characteristics;
  • any display list may contain other display lists as well as graphical data
  • the display lists, their contained display lists, and the graphical data are sorted from lowest layer (underlying) to highest layer (overlying) relative to the containing display list.
  • the presentation manager establishes and maintains these characteristics, which are referenced by the renderer.
  • the renderer maintains rasterized images according to the contents of the display lists.
  • the renderer provides the following functionality:
  • [0076] traverses the display list hierarchy in either ascending and descending sort order performing vector-by-vector conversion of graphical primitives to raster images (rendering). This traversal can be constrained by an image extent or distance from a specific image pixel;
  • [0077] determines a set of rendered pixels for each primitive. This is based on the primitive vectors and a translation of the symbolic graphic attributes for drawing styles and/or text characteristics;
  • [0078] determines a value to be applied against the raster image for each rendered pixel. This is based on a translation of the symbolic graphic attributes for color
  • [0079] determines a logical function for each rendered pixel specifying how the pixel value is to be applied against the raster image. This is based on a translation of the symbolic attributes for color, drawing styles, and/or text characteristics. For transparent pixels, the logical function leaves the corresponding pixel in the raster image unchanged, while for opaque pixels the logical function replaces the corresponding pixel in the raster image. Other logical functions provide different visual effects;
  • [0080] updates one or more raster images from the rendered pixel set, values, and functions determined from a primitive
  • the presentation manager invokes this functionality to request visual updates or to determine which primitives in the display list contain specific pixels in their rendered pixel set.
  • Symbolic graphical attribute translation to pixel sets, values, and logical functions is through a mapping specified by UIMS configuration data, typically loaded at system startup. This mapping supports transparency through transparent colors and hollow fill drawing styles.
  • the raster images are either mapped directly to video memory by the graphics display hardware, or are exact images which can be block copied directly to the video memory.
  • the raster images have the following characteristics:
  • overlying objects have been rendered after underlying objects, so that pixels rendered for the overlying objects modify or replace those of underlying objects.
  • the renderer establishes and maintains these characteristics.
  • FIG. 11 depicts the algorithm used to update areas beneath the transparent user windows.
  • An application-oriented object behind a transparent window is updated through a change in logical state 53 .
  • the presentation manager updates the object representation in the display list by modifying the graphical primitives and attributes associated with that object to reflect its new state 54 .
  • the renderer then traverses the hierarchical display list structure as follows.
  • the current display list is set to the top level display list 55 . While the end of the current display list has not been reached 56 , the next item in the display list is processed 57 . If this item is not an embedded display list 58 , the renderer determines the rendered pixel set, pixel values, and logical functions for the graphical data associated with the item 59 .
  • the renderer updates the raster images from the rendered pixels 60 . This continues until the end of the current display list has been reached 56 . If an item in the display list is itself an embedded display list 58 , the renderer pushes the current display list onto a LIFO stack 61 , and sets the current display list to the embedded display list 62 . The renderer continues processing with this display list 56 . When the current display list has been completely processed 56 , and it is not the top level display list 63 , the renderer sets the most recently pushed display list as the current display list 64 , and continues the processing of that display list 56 . If the completed display list is the top level display list 63 , rendering is complete. The renderer copies the updated raster images to video memory 65 .
  • all graphical items in the display list are rendered 59 , 60 , regardless if they are overlain by an opaque or transparent object.
  • the rendered pixels of the underlying object are replaced by the rendered pixels of the overlying object 60 .
  • the rendered pixels of the underlying item are unaffected by the rendered pixels of the overlying item 60 .
  • FIG. 12 depicts the algorithm used to implement behavior for objects which are invisible.
  • the operator moves a tracking device connected to the system hardware.
  • the operating system sends a notification of the motion 66 and a report on the new tracking position to the presentation manager 67 .
  • the presentation manager invokes the renderer to determine which primitives in the display lists, searched from uppermost to lowermost layers, contain the current tracking pixel in their rendered pixel set 68 . Note that the rendered pixel set also contains all transparent pixels for any primitive. If no primitives are found by the renderer 69 , the presentation manager awaits the next operating system event 66 . If the list contains at least one primitive, the presentation manager accesses the application-oriented object associated with the first primitive in the list 70 .
  • the operating system event If it can map the operating system event to a symbolic object event for the application-oriented object 71 , it invokes the UIMS actions linked to the object event through its behavior definition 72 .
  • the object behavior definition either terminates the input event processing or instructs the presentation manager to propagate it through to the next underlying object 73 . If processing is complete, the presentation manager awaits the next operating system event 66 . If the event is to be propagated 73 , or the event cannot be mapped to a symbolic object event 71 , the presentation manager deletes the primitive from the list 74 , and continues processing while there are primitives remaining in the list 69 .

Abstract

A system provides a user interface for maximizing an amount of information presented on a computer generated display. The system includes a user interface management system (UIMS) that works with an operating system that manages the computer resources including a display screen and a user input device for tracking position. The UIMS is responsive to the user input device to effect changes in the computer generated display. The UIMS communicates with an application program using the user interface. The user interface has at least a first layer for displaying a primary dynamic image and a second layer for displaying a secondary dynamic image. The second layer has a plurality of display modes including a first mode corresponding to at least a portion of the second layer assuming an invisible state in the computer generated display. Selection of the display modes is effected by signals received from the user input device. Both the first and second layers are updated regardless of the mode of the second layer. The user interface is particularly applicable to air traffic control where the first layer is used for displaying a map plotting aircraft locations and the second layer is used for displaying various data concerning the aircraft, both being updated continuously.

Description

  • The present invention generally relates to methods for displaying graphical information on a computer system, and more particularly, the present invention relates to a computer controlled display system for organizing the display of a high volume of information and a user interface to allow the operator to readily view all sets of information. [0001]
  • BACKGROUND OF THE INVENTION
  • A windowing environment is system software that manages interactions between a user and an application program executing on a computer through a graphical display monitor. Typically, the graphical display is arranged to resemble an electronic “desktop”, and each sheet of information on the “desktop” is displayed in a rectangular region of the screen called a “window”. The windows on the “desktop” can be organized in a variety of different ways. They can be tiled so the contents of each window are totally visible to the operator, they can be overlapped so that the contents of a window partially overlays another window, or they can be stacked so that one window completely overlays another window. The windows on the desktop can be used to contain any object, including simple objects such as menus, forms and tables and complex objects such as spreadsheets and radar displays for air traffic control. [0002]
  • In a typical window-based Graphical User Interface (GUI) system (such as Microsoft Windows® or OSF Motif®), a variety of techniques are provided to the operator to manage the windows on the display. The windows can be made larger or smaller, they can be expanded to be the full screen size, they can be moved to a different position on the screen, or they can be reduced to an icon. An icon is a small, visually distinct display object which represents the window. [0003]
  • In a traditional office application, the windows are used to represent static information such as documents and spreadsheets. The content of a window changes only when a change is effected by the operator. However, there is a class of applications where the information in the windows changes dynamically independently of operator intervention. For example, in an Air Traffic Control display, one window may contain a geographic view of the airspace in which aircraft are plotted on the display according to their current position based on radar reports. Another window may have a dynamically changing table summarizing details about each aircraft including information such as current speed and altitude, which is updated based on radar reports. [0004]
  • One of the problems associated with window based graphical user interfaces is the necessity of carefully managing the display screen space. In many complex applications there is a great deal of information which must be displayed to the operator in multiple windows. However, with multiple windows, there is often not enough screen space (screen “real estate”) to concurrently view all the important information displayed in various windows. For example, in Air Traffic Control, the focus of the radar operator is on the main situation display window where the operator is tracking the movement of aircraft through the radar plots displayed in the window. The operator also needs to regularly be able to view additional information about the aircraft, weather conditions, etc., as displayed in other windows. However, at the same time, the operator needs to maintain full awareness of the main situation window which reflects the position of all aircraft. The ability to maintain a great number of windows on the screen without obscuring the main window of interest is desired. In these situations, it is too cumbersome and time consuming to use standard window manipulation techniques such as resizing or moving windows. [0005]
  • Other attempts to solve this problem usually involve one of two techniques. The first is to provide either a larger screen surface or multiple screen surfaces to provide enough space to display all of the required data. The drawbacks of this solution are that the additional screen space require more expense and the necessary room to accommodate larger or multiple screens may not be available. The other technique is to dedicate areas of the screen at which to place menus and tables. This reduces the amount of screen space for radar data and for other menus and/or tables which may be required and the operator no longer has the flexibility of deciding for himself the best mix of data for the situation at hand. [0006]
  • A still further problem is that the windowing systems on most modern computers (for X11 windows in the Unix environment) do not update data that lie directly beneath a window. Even if such a window is transparent, it will not be updated. Modern window systems typically cannot process input events on objects that are not drawn. [0007]
  • As will be disclosed, the present invention provides a method of designating windows as invisible so that information in background windows is not obscured, a user interface for viewing and hiding the data in the foreground window on demand, and a method for managing and rendering the displays when working with invisible windows. [0008]
  • SUMMARY OF THE INVENTION
  • One aspect of the present invention seeks to provide the operator with a rapid means of exposing/hiding information in windows. Another aspect of the invention seeks to provide a method and system for updating images which reside beneath a window. [0009]
  • With regard to the first aspect, the present invention provides a method and user interface technique that allows the operator to maintain a large number of windows all containing information necessary for the operator to perform his task, while at the same time not obscuring other windows which are essential to perform the task. This approach significantly increases operator productivity and also increases safety when employed in safety critical applications since it permits the operator to maintain maximum awareness of the main safety critical situation window, while still providing immediate access to the other information necessary for the operator to perform his task. [0010]
  • The invention operates in a standard environment of computer workstation with a graphical display. Information is displayed in “windows” on the graphical display, and the operator interacts with the display with standard input devices such as a keyboard and a mouse. This invention may be embodied in an application program that executes on the workstation or any other type of program, including the Operating System which controls the workstation. [0011]
  • This invention consists of a user interface which provides the operator with a rapid means to expose and hide information in invisible windows. When the information in windows is hidden, the “invisible” windows can be totally invisible (i.e., there is no visual indication of their location), the windows may have a title bar that is visible, the: windows may have a window border that is visible, or the windows may have a title bar and window border that is visible. These latter states provide the operator with a visual clue as to the location of the hidden window. In all these cases, the contents of the invisible window are not displayed and the background window is fully visible through the invisible window. [0012]
  • The user is provided the ability to designate each invisible window as “normal”, “timed”, “locked”, or “timed icon”. The user is also able to reduce an invisible window to an icon at any time. When an invisible window is reduced to an icon no window operations can be performed on the window until the icon is raised back into an invisible window. [0013]
  • When in “normal” mode, the contents of the window are exposed when the cursor moves into the area of the window. The window contents can be exposed either by allowing the window to be displayed on an opaque background, which enhances legibility of the window contents, or on a transparent background, which enables the contents of the background windows to be visible underneath the invisible window. The window contents are hidden again by simply moving the cursor away from the window. [0014]
  • In “timed” mode, the contents of the window are exposed in the manner described above for a specified period of time, at which time the window automatically returns to its invisible state. In the “locked” mode, the contents of the window are exposed in the opaque manner described above until another mode is selected for the window. In the “timed icon” mode, the contents of the window are exposed in the manner described above for a specified period of time, at which time the window is automatically reduced to an icon. [0015]
  • With regard to the second aspect, the invention can render windows which are not directly contained in the computer's native windows and provides unique drawing strategies to ensure that updates occur to data that lay beneath a given window. [0016]
  • Thus, windows can occupy the same display area, yet the operator can rapidly select which objects to view without losing situational awareness. The expense of larger screen surface area and the restriction of dedicated table/menu areas is eliminated.[0017]
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • These and other features of the invention will become more apparent from the following description in which reference is made to the appended drawings in which: [0018]
  • FIG. 1 is a pictorial front view of a typical computer; [0019]
  • FIG. 2 is a display presentation of an opaque window technique; [0020]
  • FIG. 3 is the display presentation of FIG. 2, using a transparent window technique according to the invention; [0021]
  • FIG. 4, illustrates the display of FIG. 2 when the cursor is moved over the transparent window; [0022]
  • FIG. 5 shows the display mode menu; [0023]
  • FIG. 6 shows the general software architecture of a transparent window system according to the invention; [0024]
  • FIG. 7 is a flowchart illustrating the logic used to process a motion event detected on a window; [0025]
  • FIG. 8 is a flowchart illustrating the logic used to process a transparent time out event; [0026]
  • FIG. 9 is a flowchart illustrating the logic used to process a timed icon time out event; [0027]
  • FIG. 10 shows application oriented objects contained in the system of FIG. 6; [0028]
  • FIG. 11 is a flowchart illustrating the logic used to update areas located under a transparent window; [0029]
  • FIG. 12 is a flowchart illustrating the logic used to implement behavior for objects which are invisible.[0030]
  • Some numeral references will denote same parts throughout the description. [0031]
  • DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS OF THE INVENTION
  • FIG. 1 depicts a typical computer system suitable for supporting the present invention. FIG. 1 is but one of many computer configurations that can support the present invention. FIG. 1 shows a computer system consisting of an output device I (display monitor), input devices ([0032] mouse 5 and keyboard 6) and a system chassis 3. Other configurations might include flat screen displays, X-terminals, trackballs, touch screens and other devices.
  • The [0033] system chassis 3 contains components such as the Central Processing Unit (CPU), memory, hard disk storage, power supply, local area network, parallel printer I/O, serial I/O, and video generation hardware. The system chassis 3 may contain optional items such as CDROMs, tape drives, sound generation facilities and others.
  • The present invention provides a means to efficiently manage screen space when there are conflicting demands of high priority information in background windows which occupy large portions of the [0034] display surface 2 and numerous information windows overlaying it. The present invention can be implemented at four different levels in a computer system. It can be applied in the graphics generation hardware, the operating system graphics subsystem software (X Windows, OpenGL®, Microsoft Windows®, Apple MacO/S®, etc.), a User Interface Management System (UIMS), or in application software. The discussion below deals mostly with implementation of the present invention in a UIMS and associated application programs. A UIMS is a layer of software which manages all display and user device input activities for a specific application. The description is divided into three parts: Part 1 describes the invention as manipulated by the operator; Part 2 describes the invention in terms of the software algorithms which describe its operation; Part 3 describes the features of the UIMS to support the event capture and drawing techniques necessary.
  • Part 1
  • FIG. 2 depicts a typical application display presentation where the present invention would greatly enhance operator usability and operator access to important data. In this view, normal windowing techniques are in force. The high importance background data [0035] 8 (radar return information in this case) is being obscured by multiple overlapping user interface windows 7.
  • These overlapping [0036] windows 7 are a necessary part of the user's displayed information set. They are explicitly requested by the user and necessarily appear on top of the background data 8. The present invention provides the operator with techniques to control their property of covering underlying data.
  • FIG. 3 depicts the same application with the invisible window feature operating. Notice now that the overlapping [0037] windows 10 no longer obscure the background radar data 9. The overlapping windows' title bars and window frames 11 are still visible giving the user visible cues as to where the windows will be when opaque. The view of the background radar in FIG. 3 is vastly improved over that in FIG. 2.
  • The technique which the operator uses to toggle between opaque and invisible is as simple as moving the [0038] cursor 12 over the invisible window which the operator wishes to view. In FIG. 3 the cursor 12 is over the background data 9, not an overlapping window 10. This causes all overlapping windows 10 to be invisible.
  • FIG. 4 demonstrates the system's reaction to moving the cursor over an invisible window. Notice that the [0039] cursor 16 is now over the table titled “Category Select—CATEGORY” 15. This table is now opaque while the others 14 remain invisible. The background data 13 is covered by tables 15 but remains unaffected by tables 14.
  • Further control of the invisible effect is afforded the operator through a button in the title bar of the tables [0040] 17. Activating this button causes the display mode menu 18 to be activated. FIG. 5 depicts the display mode menu. The menu consists of four buttons 19, 20, 21, 22. Each button has a graphical icon and textual label. When a button is selected, its icon is placed in the display mode menu 18 as seen in buttons 17 of FIG. 4. Each window can be placed in a separate mode.
  • [0041] Button 19 is used to activate the Normal display mode. In this mode all overlapping windows are invisible by default. A window becomes opaque when the cursor is placed within its extent. When the cursor leaves its extent the window becomes invisible again.
  • [0042] Button 20 is used to activate the Timed display mode. In this mode all overlapping windows are invisible by default. A window becomes opaque when the cursor is placed within its extent. When the cursor leaves its extent the window becomes invisible only after a time-out has occurred. This time-out is programmable but is typically 10 seconds. The time-out is terminated if the cursor is placed over the window before it turns invisible.
  • [0043] Button 21 is used to activate the Locked display mode. In this mode the overlapping windows are always opaque.
  • [0044] Button 22 is used to activate the Timed-Icon display mode. In this mode all overlapping windows are invisible-by default. A window becomes opaque when the cursor is placed within its extent. When the cursor leaves its extent a two step time-out process begins. After the first time-out, the window goes invisible and the second timeout begins. After the second time-out, the window automatically iconifies. Window 23 in FIG. 4 illustrates an iconified window. These time-outs are configurable but are typically ten seconds. The time-outs are terminated if the cursor is placed over the window before the operation completes.
  • The activation of any of the Normal, Locked, Timed, or Timed-Icon buttons causes the mode data field on the associated window to be updated to the appropriate mode. [0045]
  • Part 2
  • FIG. 6 illustrates the general software architecture of the invisible window system. A window has three pieces of data associated with it for the purposes of this discussion. Each window has a unique identity stored in window id. Each window can operate in one of four modes: Normal, Locked, Timed, or Timed-Icon. Finally, each window can be in one of three states: invisible, opaque or iconified. [0046]
  • The following steps describe the action of moving the mouse from an opaque state window onto the background data. [0047]
  • The user moves the [0048] mouse 26 pointer from an opaque state window to the background which generates a hardware event 32. The operating system 25 services the hardware mouse event 32 and passes a message 29 to the UIMS 24. The UIMS 24 maintains the extent of all objects it manages. It traverses this list examining each window's extent to determine if the cursor now lies within the same window as the previous event if the UIMS 24 does not find a match, the UIMS checks if the cursor was previously on an opaque window. If true, the UIMS 24 next determines if that window has been designated as a potentially invisible window. If the window is designated as potentially invisible the application defined invisible state 30 is applied to the window by the UIMS 24. The user may specify the invisible state 30 to the UIMS such that the entire window becomes invisible or just user specified portions of it become invisible. The application of this state causes the UIMS 24 to redraw the window on the display 28 according to the invisible state specifications.
  • The following steps describe the action of moving the mouse from the background data onto a window which is currently invisible. [0049]
  • The user moves the [0050] mouse 26 pointer over an invisible window which generates a hardware event 32. The operating system 25 services the hardware mouse event 32 and passes a message 29 to the UIMS 24. The UIMS 24 maintains the extent of all objects it manages. It traverses this list examining each window's extent to determine if the cursor now lies within that extent. If the UIMS 24 finds a match, it next determines if that window has been designated as an invisible window. If the window is designated as potentially opaque the application defined normal state 30 is applied from the window by the UIMS 24. The application of this state causes the UIMS 24 to redraw the window on the display 28 according to the normal state specifications. The UIMS 24 notes the fact that the cursor is over a particular window which is now opaque.
  • The details of how the UIMS searches input matches on windows and how data beneath invisible windows is updated are detailed in [0051] PART 3.
  • FIGS. 7 through 10 depict flow chart views of the logic within the [0052] UIMS 24. When the lower levels of the UIMS (see Part 3) detect a motion event on a window, an algorithm depicted in FIG. 7 is initiated 33. The algorithm compares 34 the window id in the event message with the stored previous window id. If the window ids are the same, the algorithm terminates 44.
  • If the current and previous window ids do not match, the mode of the window is tested [0053] 35. If the window is in normal mode then apply the invisible state to the window 36. If the window is not in normal state then test to see if it is in Timed mode 37. If the window is in Timed mode then schedule a “timed invisible” time out event to start 39. If the window is not in Timed mode then test to see if it is in Timed-Icon mode 38. If the window is in Timed-Icon mode then schedule a “timed invisible” time out event to start 39. Regardless of which mode the current window is in the state of the previous window is now tested 40. If the current window is invisible, remove the invisible state 41 to make the window opaque. Next, store the current window id as the previous window id 42 and remove any time outs that may be pending on the window from previous cursor movement 43. This algorithm now terminates and regular processing continues.
  • FIG. 8 depicts the algorithm used to process “timed invisible” time out events. The algorithm is initiated when a time out of type “timed invisible” is received [0054] 45. The window state is set to invisible and the window is checked to see if it is in Timed-Icon mode 48. If it is a new time out of type “timed icon” is initiated 47. The algorithm now terminates 49.
  • FIG. 9 depicts the algorithm used to process “timed icon” time out events. The algorithm is initiated when a time out of type “timed icon” is received [0055] 50. The window state is set to iconified 51. The algorithm now terminates 52.
  • Part 3
  • To support the above described behavior the invention embodies the capabilities described below. [0056]
  • The UIMS of FIG. 6 contains application-oriented objects, hierarchical InterMAPhics display lists, and one or more rasterized images. Representations of the objects are maintained in the display lists by the presentation manager, and the rasterized images are created from the display lists by the renderer. This is shown in detail in FIG. 10. [0057]
  • The application oriented objects include the user interface windows used to present information to the operators. Each object has the following properties: [0058]
  • a number of representations each defined by an overall display layer and position, individually layered and positioned object components, and symbolic references to UIMS graphical constructs for each component; [0059]
  • a number of logical states defined by UIMS keys linked to representation changes; and [0060]
  • a number of behaviors defined by UIMS actions linked to symbolic object events. [0061]
  • The specification of object properties is via UIMS configuration data, typically loaded at system startup. [0062]
  • The presentation manager maintains the hierarchical display lists according to the current properties of the application-oriented objects. The presentation manager provides the following functionality: [0063]
  • inserts, modifies, and deletes graphical data in the display lists to reflect the representation properties of the application-oriented objects [0064]
  • maintains a hierarchical ordering among and within the display lists to reflect the layering properties of the application-oriented objects [0065]
  • maintains a mapping from all graphical data in the display lists to the application-oriented object with which the data is associated [0066]
  • translates operating system input events to symbolic object events on an object-by-object basis [0067]
  • invokes UIMS actions as required to implement the behavior of the objects. [0068]
  • Updates to application-oriented objects and operating system inputs invoke this functionality Operating system inputs are translated to symbolic object events via UIMS configuration data, typically loaded at system startup. [0069]
  • The hierarchical UIMS display lists contain graphical data describing the appearance of the display. The display lists have the following characteristics: [0070]
  • graphical data consisting of vector-based graphical primitives and symbolic graphical attributes such as color, drawing style, and text characteristics; [0071]
  • a hierarchical structure, whereby any display list may contain other display lists as well as graphical data; [0072]
  • the display lists, their contained display lists, and the graphical data are sorted from lowest layer (underlying) to highest layer (overlying) relative to the containing display list. [0073]
  • The presentation manager establishes and maintains these characteristics, which are referenced by the renderer. [0074]
  • The renderer maintains rasterized images according to the contents of the display lists. The renderer provides the following functionality: [0075]
  • traverses the display list hierarchy in either ascending and descending sort order performing vector-by-vector conversion of graphical primitives to raster images (rendering). This traversal can be constrained by an image extent or distance from a specific image pixel; [0076]
  • determines a set of rendered pixels for each primitive. This is based on the primitive vectors and a translation of the symbolic graphic attributes for drawing styles and/or text characteristics; [0077]
  • determines a value to be applied against the raster image for each rendered pixel. This is based on a translation of the symbolic graphic attributes for color [0078]
  • determines a logical function for each rendered pixel specifying how the pixel value is to be applied against the raster image. This is based on a translation of the symbolic attributes for color, drawing styles, and/or text characteristics. For transparent pixels, the logical function leaves the corresponding pixel in the raster image unchanged, while for opaque pixels the logical function replaces the corresponding pixel in the raster image. Other logical functions provide different visual effects; [0079]
  • updates one or more raster images from the rendered pixel set, values, and functions determined from a primitive; [0080]
  • copies some or all of one or more raster images to the hardware video memory. [0081]
  • The presentation manager invokes this functionality to request visual updates or to determine which primitives in the display list contain specific pixels in their rendered pixel set. Symbolic graphical attribute translation to pixel sets, values, and logical functions is through a mapping specified by UIMS configuration data, typically loaded at system startup. This mapping supports transparency through transparent colors and hollow fill drawing styles. [0082]
  • The raster images are either mapped directly to video memory by the graphics display hardware, or are exact images which can be block copied directly to the video memory. The raster images have the following characteristics: [0083]
  • an array of pixel values arranged exactly as required for video display; [0084]
  • overlying objects have been rendered after underlying objects, so that pixels rendered for the overlying objects modify or replace those of underlying objects. [0085]
  • The renderer establishes and maintains these characteristics. [0086]
  • FIG. 11 depicts the algorithm used to update areas beneath the transparent user windows. An application-oriented object behind a transparent window is updated through a change in [0087] logical state 53. The presentation manager updates the object representation in the display list by modifying the graphical primitives and attributes associated with that object to reflect its new state 54. The renderer then traverses the hierarchical display list structure as follows. The current display list is set to the top level display list 55. While the end of the current display list has not been reached 56, the next item in the display list is processed 57. If this item is not an embedded display list 58, the renderer determines the rendered pixel set, pixel values, and logical functions for the graphical data associated with the item 59. The renderer updates the raster images from the rendered pixels 60. This continues until the end of the current display list has been reached 56. If an item in the display list is itself an embedded display list 58, the renderer pushes the current display list onto a LIFO stack 61, and sets the current display list to the embedded display list 62. The renderer continues processing with this display list 56. When the current display list has been completely processed 56, and it is not the top level display list 63, the renderer sets the most recently pushed display list as the current display list 64, and continues the processing of that display list 56. If the completed display list is the top level display list 63, rendering is complete. The renderer copies the updated raster images to video memory 65. Note that all graphical items in the display list are rendered 59, 60, regardless if they are overlain by an opaque or transparent object. In the opaque case, the rendered pixels of the underlying object are replaced by the rendered pixels of the overlying object 60. In the transparent case, the rendered pixels of the underlying item are unaffected by the rendered pixels of the overlying item 60.
  • FIG. 12 depicts the algorithm used to implement behavior for objects which are invisible. The operator moves a tracking device connected to the system hardware. The operating system sends a notification of the [0088] motion 66 and a report on the new tracking position to the presentation manager 67. The presentation manager invokes the renderer to determine which primitives in the display lists, searched from uppermost to lowermost layers, contain the current tracking pixel in their rendered pixel set 68. Note that the rendered pixel set also contains all transparent pixels for any primitive. If no primitives are found by the renderer 69, the presentation manager awaits the next operating system event 66. If the list contains at least one primitive, the presentation manager accesses the application-oriented object associated with the first primitive in the list 70. If it can map the operating system event to a symbolic object event for the application-oriented object 71, it invokes the UIMS actions linked to the object event through its behavior definition 72. The object behavior definition either terminates the input event processing or instructs the presentation manager to propagate it through to the next underlying object 73. If processing is complete, the presentation manager awaits the next operating system event 66. If the event is to be propagated 73, or the event cannot be mapped to a symbolic object event 71, the presentation manager deletes the primitive from the list 74, and continues processing while there are primitives remaining in the list 69.

Claims (32)

We claim:
1. A graphical user interface, comprising:
a first display layer for presenting a primary dynamic image;
a display position indicator responsive to a user input device; and
a second display layer for presenting a secondary dynamic image related to the primary dynamic image and positionable relative thereto, the second display layer having visible or invisible modes and assuming a visible mode in dependence upon a predetermined user selection and the primary and secondary dynamic images being updated regardless of position or mode of the second display layer.
2. A graphic user interface as claimed in claim 1, wherein the mode of the second display layer is affected when the display position indicator is coincident therewith.
3. A graphic user interface as claimed in claim 1, wherein the user selection is one of a normally invisible mode, the timed mode, a locked mode or the timed-icon mode wherein for the normally visible mode the second display layer is normally invisible, for the timed mode the second display layer is visible for a predetermined time, then becomes invisible, for the locked mode, second display layer is locked in a visible mode and for the time-icon mode the second display layer is visible for a predetermined time then changes to an icon.
4. A graphical user interface as claimed in claim 3, wherein the user selection method is by button depression using the user input device.
5. A graphical user interface as claimed in claim 4 wherein the buttons are labeled normal, timed, locked and timed-icon.
6. A system for providing a user interface for maximizing an amount of information presented on a computer generated display, said system comprising:
a user interface management system for receiving messages, from an operating system that manages the computer resources including a display screen and a user input device for tracking position, and in particular, messages in response to the user input device and for sending messages to the operating system effecting changes in the computer generated display and for receiving messages from and sending messages to an application program using the user interface;
the user interface having at least a first layer for displaying a primary dynamic image and a second layer for displaying a secondary dynamic image, the second layer having a plurality of display modes including a first mode corresponding to at least a portion of the second layer assuming an invisible state in the computer generated display, selection of the display modes being in dependence upon signals received from the user input device.
7. A system as claimed in claim 6, wherein the mode of the second display layer is affected when the display position indicator is coincident therewith.
8. A system as claimed in claim 6 wherein the user selection is one of a normally invisible mode, the timed mode, a locked mode or the timed-icon mode wherein for the normally visible mode the second display layer is normally invisible, for the timed mode the second display layer is visible for a predetermined time, then becomes invisible, for the locked mode, second display layer is locked in a visible mode and for the time-icon mode the second display layer is visible for a predetermined time then changes to an icon.
9. A system as claimed in claim 8, wherein the user selection method is by button depression using the user input device.
10. A system as claimed in claim 9, wherein the buttons are labeled normal, timed, locked and timed-icon.
11. A graphical user interface for air traffic control comprising:
a first display layer for presenting an aircraft tracking display;
a second display layer for presenting auxiliary data related to the first display layer;
a display position indicator responsive to the user interface device; and
the second display layer having a plurality of display modes including a mode in which a portion of the second display layer is in an invisible state.
12. A graphical user interface as claimed in claim 11, wherein the plurality of display modes includes a thermally invisible mode in which the portion of the second display layer is in an invisible state until the display position indicator is coincident with the second display layer.
13. A graphical user interface as claimed in claim 11, wherein the plurality display modes includes a timed mode in which the portion of the second display layer is in an invisible state until the display position indicator is coincident with the second display layer which then remains in the invisible state for a predetermined time after the display position indicator is no longer coincident therewith, then the portion of the second display layer returns to an invisible state.
14. A graphical user interface as claimed in claim 11, wherein the plurality of display modes includes a locked mode in which the second display layer is locked in an invisible state.
15. A graphical user interface as claimed in claim 11, wherein the plurality of display modes includes a timed icon mode in which the second display layer is normally displayed as a visible icon and is in a visible state when the position indicator is coincident with the icon, then returns to an invisible state after a predetermined time.
16. A graphical display system for an application program, comprising:
a user interface manager for storing application oriented objects associated with said application program, hierarchical display lists of said objects, and raster images of said objects, said objects including representations each defined by an overall display layer and position, individually layered and positioned object components, and symbolic references to graphical constructs for each said component, a plurality of logical states defined by keys linked to representation changes and a plurality of behaviors defined by actions linked to symbolic object events;
a renderer module responsive to a presentation manager for maintaining said raster images according to the contents of said display lists and copying one or more of said raster images to hardware video memory for display on a display device; and
a presentation manager responsive to a motion event or user input for invoking said user interface module and said renderer.
17. A graphical display system as defined in claim 16, said presentation manager being operable to insert, modify, and delete graphical data in said display lists to reflect the representation properties of said application-oriented objects; maintain the hierarchical ordering of said display lists to reflect layering properties of said application-oriented objects; maintain a mapping from all graphical data in said display lists to application-oriented objects with which data is associated; translate operating system input events to symbolic object events on an object-by-object basis; and invoke user interface manager actions as required to implement predetermined behaviors of said objects.
18. A graphical display system as defined in claim 16, said display lists containing graphical data describing the appearance of the display and including graphical data consisting of vector-based graphical primitives and symbolic graphical attributes including color, drawing style, and/or text characteristics, a hierarchical structure in which any display list may contain other display lists and graphical data and in which the display lists, their contained display lists, and graphical data are sorted from a lowest underlying layer to highest overlying layer relative to a containing display list.
19. A graphical display system as defined in claim 16, said renderer being operable to traverse the display list hierarchy in either ascending or descending sort order and perform vector-by-vector conversion of graphical primitives to raster images constrained by an image extent or distance from a specific image pixel; determine a set of rendered pixels for each primitive based on primitive vectors and a translation of the symbolic graphic attributes for drawing styles and/or text characteristics; determine a value to be applied against a raster image for each rendered pixel based on a translation of the symbolic graphic attributes for color; determine a logical function for each rendered pixel specifying the manner in which a pixel value is to be applied against a raster image based on a translation of symbolic attributes for color, drawing styles, and/or text characteristics such that for transparent pixels, said logical function leaving the corresponding pixel in the raster image unchanged; for opaque pixels, said logical function replacing the corresponding pixel in the raster image and other logical functions provide different visual effects; updating one or more raster images from the rendered pixel set, values, and functions determined from a primitive; and copying some or all of one or more raster images to the hardware video memory.
20. A graphical display system as defined in claim 16, said renderer being operable to either map said raster images directly to video memory to graphics display hardware or block copy said raster images directly to the video memory, said raster images being comprising an array of pixel values arranged exactly as required for video display, said renderer being further operable to render overlying objects after rendering underlying objects so that pixels rendered for the overlying objects modify or replace those of underlying objects.
21. A graphical display system as defined in claim 17, said display lists containing graphical data describing the appearance of the display and including graphical data consisting of vector-based graphical primitives and symbolic graphical attributes including color, drawing style, and/or text characteristics, a hierarchical structure in which any display list may contain other display lists and graphical data and in which the display lists, their contained display lists, and graphical data are sorted from a lowest underlying layer to highest overlying layer relative to a containing display list.
22. A graphical display system as defined in claim 21, said renderer being operable to traverse the display list hierarchy in either ascending or descending sort order and perform vector-by-vector conversion of graphical primitives to raster images constrained by an image extent or distance from a specific image pixel; determine a set of rendered pixels for each primitive based on primitive vectors and a translation of the symbolic graphic attributes for drawing styles and/or text characteristics; determine a value to be applied against a raster image for each rendered pixel based on a translation of the symbolic graphic attributes for color; determine a logical function for each rendered pixel specifying the manner in which a pixel value is to be applied against a raster image based on a translation of symbolic attributes for color, drawing styles, and/or text characteristics such that for transparent pixels, said logical function leaving the corresponding pixel in the raster image unchanged; for opaque pixels, said logical function replacing the corresponding pixel in the raster image and other logical functions provide different visual effects; updating one or more raster images from the rendered pixel set, values, and functions determined from a primitive; and copying some or all of one or more raster images to the hardware video memory.
23. A graphical display system as defined in claim 22, said renderer being operable to either map said raster images directly to video memory to graphics display hardware or block copy said raster images directly to the video memory, said raster images being comprising an array of pixel values arranged exactly as required for video display, said renderer being further operable to render overlying objects after rendering underlying objects so that pixels rendered for the overlying objects modify or replace those of underlying objects.
24. A method of managing a graphical user interface associated with an application program operable on a computing device having a visual display device, a user input device for controlling a pointer on said display device, said application having a plurality of windows including a primary background window and one or more secondary windows overlying said background window, each said secondary window being configurable in normal, locked, timed and timed icon modes and in invisible, opaque, and iconified states, comprising the steps of:
a) storing predetermined data with respect to each said window;
b) storing hierarchical display lists of said windows;
c) storing raster images of said windows;
d) storing the identity of an window underlying said pointer as a current window;
e) responding to movement of said pointer over said windows by:
i. comparing the identity of the window immediately underlying said pointer against the identity of a previous window;
ii. determining the mode of the previous window and
a. placing said previous window in an invisible state when said previous window is in a normal mode; and
b. initiating an invisible time out when said previous window is in a timed or timed icon mode;
iii. removing an invisible state from said current window;
iv. storing the identity of said current window as said previous window; and
v. removing any pending time outs respecting said current window.
25. A method as defined in claim 24, said step of storing predetermined data with respect to each said window including storing representations each defined by an overall display layer and position, individually layered and positioned object components, and symbolic references to graphical constructs for each said component, and the mode and state of said windows.
26. A method as defined in claim 24, said step of initiating an invisible time out further including “setting” said previous window in an said invisible when a time out event occurs when said previous window was in a timed mode and setting said previous window in an said iconized state when a time out event occurs when said previous window was in a timed icon mode.
27. A method as defined in claim 24, wherein in said normal mode the contents of the window are exposed when said pointer moves into the area of said window, said window contents being exposed either by displaying the window displayed on an opaque background to enhances legibility of the window contents, or by displaying said window on a transparent background to enable the contents of background windows to be visible underneath the invisible window.
28. A method as defined in claim 24, wherein, in said “timed” mode, the contents of the window are exposed a predetermined period of time when said pointer moves into the area of said window, said window contents being exposed either by displaying the window displayed on an opaque background to enhances legibility of the window contents, or by displaying said window on a transparent background to enable the contents of background windows to be visible underneath the invisible window, and at the end of said predetermined period of time, returning the window to said invisible state.
29. A method as defined in claim 24, wherein, in said “timed icon” mode, the contents of the window are exposed a predetermined period of time when said pointer moves into the area of said window, said window contents being exposed either by displaying the window displayed on an opaque background to enhances legibility of the window contents, or by displaying said window on a transparent background to enable the contents of background windows to be visible underneath the invisible window, and at the end of said predetermined period of time, reducing the window to said icon state.
30. A method as defined in claim 24, further including the step of updating windows disposed beneath transparent windows including the steps of:
a) setting a current display list to a top level display list;
b) for each item in said display list:
i. if said item is not an embedded display list, determining the rendered pixel set, pixel values and logical functions associated with said item, and updating raster images from the rendered pixels associated with said item;
ii. if said item is an embedded display list, repeating steps a) and b) with respect to said embedded display list; and
c) when all items in all display lists have been processed, copying updated images to video memory.
31. A method as defined in claim 24, further including the step of implementing the behavior of objects which are invisible, in response to movement of a tracking device,
a) determining the pixel coordinates of said tracking device from a tracking event;
b) determining which primitives in the display lists, searched from uppermost to lowermost layers, contain said pixel coordinates in their rendered pixel set;
c) if said lists contain at least one primitive, for each such primitive:
i. accessing the application-oriented object associated with said at least one primitive;
ii. invoking the actions linked to the object event according to a predetermined behavior definition;
iii. if said event allows event propagation, propagating said event to the next underlying object;
d) If said event is to be propagated or if said event cannot be mapped to a symbolic object event, deleting the primitive from the list.
32. A computer readable memory or article of manufacture for storing the instructions or statements for use in the execution of the method of claim 24.
US10/322,628 1997-02-19 2002-12-19 User interface and method for maximizing the information presented on a screen Abandoned US20030098886A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US10/322,628 US20030098886A1 (en) 1997-02-19 2002-12-19 User interface and method for maximizing the information presented on a screen

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
CA002197953A CA2197953C (en) 1997-02-19 1997-02-19 User interface and method for maximizing the information presented on a screen
CA2,197,953 1997-02-19
US09/367,677 US6512529B1 (en) 1997-02-19 1998-02-19 User interface and method for maximizing the information presented on a screen
US10/322,628 US20030098886A1 (en) 1997-02-19 2002-12-19 User interface and method for maximizing the information presented on a screen

Related Parent Applications (2)

Application Number Title Priority Date Filing Date
PCT/CA1998/000125 Division WO1998037483A1 (en) 1997-02-19 1998-02-19 User interface and method for maximizing the information presented on a screen
US09/367,677 Division US6512529B1 (en) 1997-02-19 1998-02-19 User interface and method for maximizing the information presented on a screen

Publications (1)

Publication Number Publication Date
US20030098886A1 true US20030098886A1 (en) 2003-05-29

Family

ID=4159983

Family Applications (2)

Application Number Title Priority Date Filing Date
US09/367,677 Expired - Lifetime US6512529B1 (en) 1997-02-19 1998-02-19 User interface and method for maximizing the information presented on a screen
US10/322,628 Abandoned US20030098886A1 (en) 1997-02-19 2002-12-19 User interface and method for maximizing the information presented on a screen

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US09/367,677 Expired - Lifetime US6512529B1 (en) 1997-02-19 1998-02-19 User interface and method for maximizing the information presented on a screen

Country Status (5)

Country Link
US (2) US6512529B1 (en)
EP (1) EP0961963A1 (en)
AU (1) AU6202098A (en)
CA (2) CA2197953C (en)
WO (1) WO1998037483A1 (en)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070188408A1 (en) * 2004-03-16 2007-08-16 Siemens Aktiengesellschaft Method for displaying a graphic object and communications device
CN102110393A (en) * 2009-12-25 2011-06-29 三洋电机株式会社 Multilayer display device
US20120078445A1 (en) * 2010-09-27 2012-03-29 Honeywell International Inc. Computer assisted human machine interface display
TWI419041B (en) * 2008-06-06 2013-12-11 Hon Hai Prec Ind Co Ltd Control method for displaying icons of touch screen

Families Citing this family (82)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3478172B2 (en) * 1999-05-18 2003-12-15 日本電気株式会社 Multi-window display system and window display and deletion method
US8212893B2 (en) * 1999-06-08 2012-07-03 Verisign, Inc. Digital camera device and methodology for distributed processing and wireless transmission of digital images
US6683954B1 (en) 1999-10-23 2004-01-27 Lockstream Corporation Key encryption using a client-unique additional key for fraud prevention
US6745328B1 (en) 1999-10-23 2004-06-01 Lockstream Corporation Encryption using a user-known and personally valuable key to deter key sharing
US6670970B1 (en) 1999-12-20 2003-12-30 Apple Computer, Inc. Graduated visual and manipulative translucency for windows
US6778992B1 (en) * 1999-12-21 2004-08-17 Lockstream Corporation Flexible and hierarchical user interfaces defined using a data definition language
US6917373B2 (en) 2000-12-28 2005-07-12 Microsoft Corporation Context sensitive labels for an electronic device
US7030837B1 (en) * 2000-04-24 2006-04-18 Microsoft Corporation Auxiliary display unit for a computer system
US7227511B2 (en) * 2000-04-24 2007-06-05 Microsoft Corporation Method for activating an application in context on a remote input/output device
US6707476B1 (en) * 2000-07-05 2004-03-16 Ge Medical Systems Information Technologies, Inc. Automatic layout selection for information monitoring system
WO2002017156A1 (en) * 2000-08-25 2002-02-28 Xerts International Limited An interactive ordering and management system and method
US6828989B2 (en) * 2000-12-29 2004-12-07 Microsoft Corporation Graphically represented dynamic time strip for displaying user-accessible time-dependent data objects
US7003726B2 (en) * 2001-02-21 2006-02-21 Nanonation Incorporated Computer network having context sensitive and interactive multimedia applications and controls, forming dynamic user interfaces on local computer terminals
FI20010817A (en) * 2001-04-20 2003-02-14 Nokia Corp A method for displaying information on an electronic device display and an electronic device
US7010744B1 (en) * 2001-05-14 2006-03-07 The Mathworks, Inc. System and method of navigating and creating electronic hierarchical documents
US7620911B2 (en) * 2001-07-12 2009-11-17 Autodesk, Inc. Collapsible dialog window
US7478338B2 (en) 2001-07-12 2009-01-13 Autodesk, Inc. Palette-based graphical user interface
US20030023700A1 (en) * 2001-07-27 2003-01-30 Lightsurf Technologies, Inc. System and methodology providing on-board user interface
AU2002367588A1 (en) * 2001-10-10 2003-09-29 Mcloughlin Pacific Corporation Method and apparatus for tracking aircraft and securing against unauthorized access
US6995689B2 (en) * 2001-10-10 2006-02-07 Crank Kelly C Method and apparatus for tracking aircraft and securing against unauthorized access
GB2381725B (en) * 2001-11-05 2004-01-14 H2Eye Graphical user interface for a remote operated vehicle
US8015507B2 (en) 2001-11-05 2011-09-06 H2Eye (International) Limited Graphical user interface for a remote operated vehicle
US7146573B2 (en) * 2002-01-28 2006-12-05 International Business Machines Corporation Automatic window representation adjustment
US20030142141A1 (en) * 2002-01-28 2003-07-31 International Business Machines Corporation Displaying specified resource usage
US6954905B2 (en) * 2002-01-28 2005-10-11 International Business Machines Corporation Displaying transparency characteristic aids
US20030142133A1 (en) * 2002-01-28 2003-07-31 International Business Machines Corporation Adjusting transparency of windows to reflect recent use
US20030142143A1 (en) * 2002-01-28 2003-07-31 International Business Machines Corporation Varying heights of application images to convey application status
US20030142132A1 (en) * 2002-01-28 2003-07-31 International Business Machines Corporation Selectively adjusting the translucency of windows in response to a scroll wheel rotation
US20030142140A1 (en) * 2002-01-28 2003-07-31 International Business Machines Corporation Adjusting the tint of a translucent window to convey status
US20030142149A1 (en) * 2002-01-28 2003-07-31 International Business Machines Corporation Specifying audio output according to window graphical characteristics
US20030142137A1 (en) * 2002-01-28 2003-07-31 International Business Machines Corporation Selectively adjusting the order of windows in response to a scroll wheel rotation
US7724281B2 (en) * 2002-02-04 2010-05-25 Syniverse Icx Corporation Device facilitating efficient transfer of digital content from media capture device
JP2003276470A (en) * 2002-03-22 2003-09-30 Nissan Motor Co Ltd Information presentation control device
US6952630B2 (en) * 2002-07-08 2005-10-04 Hedrick Geoffrey S M Method and apparatus for facilitating ease of viewing and interpretation of data concurrently presented to the flight crew on a multifunction flat panel display in an aircraft
JP4412701B2 (en) * 2003-01-24 2010-02-10 日本電気株式会社 Screen information display method, system, and computer program
US8065614B2 (en) * 2003-04-09 2011-11-22 Ati Technologies, Inc. System for displaying video and method thereof
JP4086714B2 (en) * 2003-05-27 2008-05-14 キヤノン株式会社 Information processing apparatus, data display method thereof, and storage medium
US7734529B1 (en) 2003-05-29 2010-06-08 Chicago Mercantile Exchange, Inc. Trader station user interface
US7051282B2 (en) * 2003-06-13 2006-05-23 Microsoft Corporation Multi-layer graphical user interface
EP1491990B1 (en) * 2003-06-20 2010-02-17 Apple Inc. Graphical user interface system and method of displaying objects in a graphical user interface
US7568167B2 (en) * 2003-06-26 2009-07-28 Microsoft Corporation Non-persistent user interface for real-time communication
EP1683038A4 (en) * 2003-10-20 2012-06-06 Zoll Medical Corp Portable medical information device with dynamically configurable user interface
US20050091610A1 (en) * 2003-10-22 2005-04-28 International Business Machines Corporation Selective display of windows on an auxiliary output device
US8122361B2 (en) * 2003-10-23 2012-02-21 Microsoft Corporation Providing a graphical user interface in a system with a high-assurance execution environment
US20050114791A1 (en) * 2003-11-20 2005-05-26 International Business Machines Corporation Cueing mechanism that indicates a display is able to be scrolled
US20080109751A1 (en) * 2003-12-31 2008-05-08 Alias Systems Corp. Layer editor system for a pen-based computer
US7975240B2 (en) * 2004-01-16 2011-07-05 Microsoft Corporation Systems and methods for controlling a visible results set
US7719523B2 (en) 2004-08-06 2010-05-18 Touchtable, Inc. Bounding box gesture recognition on a touch detecting interactive display
US20060129948A1 (en) * 2004-12-14 2006-06-15 Hamzy Mark J Method, system and program product for a window level security screen-saver
US20060150108A1 (en) * 2005-01-06 2006-07-06 Canon Kabushiki Kaisha Information processing device, information processing method, storage medium, and program
JP2006244078A (en) * 2005-03-02 2006-09-14 Canon Inc Display control device and control method thereof
US7412661B2 (en) * 2005-03-04 2008-08-12 Microsoft Corporation Method and system for changing visual states of a toolbar
CN101292217B (en) 2005-10-15 2012-02-22 诺基亚公司 Improved text inputting method and device for electronic equipment
CN101268437B (en) * 2005-11-02 2010-05-19 松下电器产业株式会社 Display-object penetrating apparatus and method
US20070180390A1 (en) * 2006-01-31 2007-08-02 Honeywell International, Inc. Enhanced information display system and method
US20080046822A1 (en) * 2006-08-15 2008-02-21 Frank Meyer Apparatus and method for interactive user software interface design
FR2905191B1 (en) * 2006-08-23 2009-07-10 Airbus France Sas AIRCRAFT DIALOGUE DEVICE.
US8621373B2 (en) * 2006-08-31 2013-12-31 Microsoft Corporation Desktop assistant for multiple information types
US20080111822A1 (en) * 2006-09-22 2008-05-15 Yahoo, Inc.! Method and system for presenting video
US20130167024A1 (en) 2006-12-05 2013-06-27 Adobe Systems Incorporated Embedded document within an application
US8607167B2 (en) * 2007-01-07 2013-12-10 Apple Inc. Portable multifunction device, method, and graphical user interface for providing maps and directions
US7743339B1 (en) 2007-02-01 2010-06-22 Adobe Systems Incorporated Rendering text in a brew device
US8589779B2 (en) * 2007-03-08 2013-11-19 Adobe Systems Incorporated Event-sensitive content for mobile devices
US8302033B2 (en) 2007-06-22 2012-10-30 Apple Inc. Touch screen device, method, and graphical user interface for providing maps, directions, and location-based information
US8327272B2 (en) 2008-01-06 2012-12-04 Apple Inc. Portable multifunction device, method, and graphical user interface for viewing and managing electronic calendars
US20090199127A1 (en) * 2008-01-31 2009-08-06 Microsoft Corporation Previewing target display areas
CN101282532A (en) * 2008-05-14 2008-10-08 宇龙计算机通信科技(深圳)有限公司 Mobile communication terminal as well as parameter display method and system thereof
US20090319944A1 (en) * 2008-06-12 2009-12-24 Honeywell International Inc. Navigation display including multi-control window
GB2461058C (en) 2008-06-18 2017-01-18 Skype Audio device control method and apparatus
JP5371305B2 (en) * 2008-07-18 2013-12-18 京セラドキュメントソリューションズ株式会社 Computer program
US8464182B2 (en) * 2009-06-07 2013-06-11 Apple Inc. Device, method, and graphical user interface for providing maps, directions, and location-based information
US8862576B2 (en) * 2010-01-06 2014-10-14 Apple Inc. Device, method, and graphical user interface for mapping directions between search results
WO2011112533A1 (en) * 2010-03-08 2011-09-15 Stereotaxis, Inc. Method for managing non-overlapping windows
US20120102400A1 (en) * 2010-10-22 2012-04-26 Microsoft Corporation Touch Gesture Notification Dismissal Techniques
CN102622214B (en) * 2011-01-27 2015-09-30 腾讯科技(深圳)有限公司 One realizes plurality of display modes standard drawing calibration method and device
US10191641B2 (en) 2011-12-29 2019-01-29 Apple Inc. Device, method, and graphical user interface for navigation of information in a map-based interface
US9720890B2 (en) * 2013-08-06 2017-08-01 Educational Testing Service System and method for rendering an assessment item
US20160323351A1 (en) * 2015-04-29 2016-11-03 Box, Inc. Low latency and low defect media file transcoding using optimized storage, retrieval, partitioning, and delivery techniques
US10706821B2 (en) 2016-02-18 2020-07-07 Northrop Grumman Systems Corporation Mission monitoring system
US11853690B1 (en) 2016-05-31 2023-12-26 The Mathworks, Inc. Systems and methods for highlighting graphical models
US10929210B2 (en) 2017-07-07 2021-02-23 Box, Inc. Collaboration system protocol processing
US11470131B2 (en) 2017-07-07 2022-10-11 Box, Inc. User device processing of information from a network-accessible collaboration system

Citations (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4121283A (en) * 1977-01-17 1978-10-17 Cromemco Inc. Interface device for encoding a digital image for a CRT display
US4882577A (en) * 1985-06-07 1989-11-21 Hughes Aircraft Company Calligraphic control for image superimposition
US5390295A (en) * 1991-12-20 1995-02-14 International Business Machines Corporation Method and apparatus for proportionally displaying windows on a computer display screen
US5548515A (en) * 1990-10-09 1996-08-20 Pilley; Harold R. Method and system for airport control and management
US5625783A (en) * 1994-12-13 1997-04-29 Microsoft Corporation Automated system and method for dynamic menu construction in a graphical user interface
US5651107A (en) * 1992-12-15 1997-07-22 Sun Microsystems, Inc. Method and apparatus for presenting information in a display system using transparent windows
US5659694A (en) * 1994-06-30 1997-08-19 Canon Kabushiki Kaisha Method and system for displaying context sensitive child windows independently of their parent window
US5745714A (en) * 1996-07-19 1998-04-28 International Business Machines Corporation Method and system in a data processing system for the association and display of a plurality of objects
US6072489A (en) * 1993-05-10 2000-06-06 Apple Computer, Inc. Method and apparatus for providing translucent images on a computer display
US6246407B1 (en) * 1997-06-16 2001-06-12 Ati Technologies, Inc. Method and apparatus for overlaying a window with a multi-state window
US6429845B1 (en) * 1995-03-07 2002-08-06 Robert Bosch Gmbh Process for displaying several sets of information

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5046001A (en) * 1988-06-30 1991-09-03 Ibm Corporation Method for accessing selected windows in a multi-tasking system
DE69022210T2 (en) * 1990-01-29 1996-05-02 Ibm Data processing system.
JPH0651738A (en) * 1992-07-27 1994-02-25 Canon Inc Information display device of computer system
US5420968A (en) * 1993-09-30 1995-05-30 International Business Machines Corporation Data processing system and method for displaying dynamic images having visual appearances indicative of real world status
JPH08171476A (en) * 1994-12-16 1996-07-02 Canon Inc Window management system
US5675755A (en) * 1995-06-07 1997-10-07 Sony Corporation Window system preventing overlap of multiple always-visible windows

Patent Citations (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4121283A (en) * 1977-01-17 1978-10-17 Cromemco Inc. Interface device for encoding a digital image for a CRT display
US4882577A (en) * 1985-06-07 1989-11-21 Hughes Aircraft Company Calligraphic control for image superimposition
US5548515A (en) * 1990-10-09 1996-08-20 Pilley; Harold R. Method and system for airport control and management
US5390295A (en) * 1991-12-20 1995-02-14 International Business Machines Corporation Method and apparatus for proportionally displaying windows on a computer display screen
US5651107A (en) * 1992-12-15 1997-07-22 Sun Microsystems, Inc. Method and apparatus for presenting information in a display system using transparent windows
US6072489A (en) * 1993-05-10 2000-06-06 Apple Computer, Inc. Method and apparatus for providing translucent images on a computer display
US5659694A (en) * 1994-06-30 1997-08-19 Canon Kabushiki Kaisha Method and system for displaying context sensitive child windows independently of their parent window
US5625783A (en) * 1994-12-13 1997-04-29 Microsoft Corporation Automated system and method for dynamic menu construction in a graphical user interface
US6429845B1 (en) * 1995-03-07 2002-08-06 Robert Bosch Gmbh Process for displaying several sets of information
US5745714A (en) * 1996-07-19 1998-04-28 International Business Machines Corporation Method and system in a data processing system for the association and display of a plurality of objects
US6246407B1 (en) * 1997-06-16 2001-06-12 Ati Technologies, Inc. Method and apparatus for overlaying a window with a multi-state window

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070188408A1 (en) * 2004-03-16 2007-08-16 Siemens Aktiengesellschaft Method for displaying a graphic object and communications device
TWI419041B (en) * 2008-06-06 2013-12-11 Hon Hai Prec Ind Co Ltd Control method for displaying icons of touch screen
CN102110393A (en) * 2009-12-25 2011-06-29 三洋电机株式会社 Multilayer display device
US20110157051A1 (en) * 2009-12-25 2011-06-30 Sanyo Electric Co., Ltd. Multilayer display device
EP2348387A3 (en) * 2009-12-25 2011-10-12 Sanyo Electric Co., Ltd. Multilayer display device
US20120078445A1 (en) * 2010-09-27 2012-03-29 Honeywell International Inc. Computer assisted human machine interface display
US9377324B2 (en) * 2010-09-27 2016-06-28 Honeywell International Inc. Computer assisted human machine interface display

Also Published As

Publication number Publication date
US6512529B1 (en) 2003-01-28
EP0961963A1 (en) 1999-12-08
WO1998037483A1 (en) 1998-08-27
CA2483488A1 (en) 1998-08-19
AU6202098A (en) 1998-09-09
CA2197953A1 (en) 1998-08-19
CA2197953C (en) 2005-05-10

Similar Documents

Publication Publication Date Title
US6512529B1 (en) User interface and method for maximizing the information presented on a screen
US6664983B2 (en) Method and apparatus for configuring sliding panels
US5675755A (en) Window system preventing overlap of multiple always-visible windows
US8504937B2 (en) Computer interface having a single window mode of operation
EP0972253B1 (en) Method and apparatus for accessing information and items across multiple workspaces
EP0636971B1 (en) Method and apparatus for producing a composite second image in the spatial context of a first image
US6710788B1 (en) Graphical user interface
US5920313A (en) Method and system for associating related user interface objects
US6163317A (en) Method and apparatus for dynamically grouping objects
US5546529A (en) Method and apparatus for visualization of database search results
US5835919A (en) Computer-human interface system which manipulates parts between a desktop and a document
EP0698241B1 (en) Computer-human interface system for compound documents
US20070143324A1 (en) Graphical user interface icon for documents with status indicator
JPH06301505A (en) Computer-controlled display system
US20060107226A1 (en) Sidebar autohide to desktop
JPH0855002A (en) Method for display of open application on display screen andvirtual desktop system
US20170131874A1 (en) Software Design Tool For A User Interface And The Administration Of Proximity Responsive Information Displays In Augmented Reality Or Virtual Reality Environments
JP2003345488A (en) Method for displaying uneven graphic image indicating display object on a display surface and method for updating display of graphic image indicating display object on display surface
US5995984A (en) Apparatus and method for zoom-in entry of an element in a table
US6392662B1 (en) Draw order preservation in a computer-implemented graphics system
EP0548709A2 (en) Controlling display and direct manipulation of a plurality of windows
Van Dantzich et al. Application redirection: hosting Windows applications in 3D
US20040090459A1 (en) Graphical user interface for presenting and manipulating object attributes
Hopgood et al. Acronyms and Glossary
JPH0778243A (en) Operating method of machine

Legal Events

Date Code Title Description
AS Assignment

Owner name: 4340965 CANADA INC., CANADA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:GALLIUM SOFTWARE INC.;REEL/FRAME:018442/0667

Effective date: 20060609

Owner name: GALLIUM VISUAL SYSTEMS INC., CANADA

Free format text: CHANGE OF NAME;ASSIGNOR:4340965 CANADA INC.;REEL/FRAME:018442/0664

Effective date: 20060612

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION