Search Images Maps Play YouTube News Gmail Drive More »
Sign in
Screen reader users: click this link for accessible mode. Accessible mode has the same essential features but works better with your reader.

Patents

  1. Advanced Patent Search
Publication numberUS6384840 B1
Publication typeGrant
Application numberUS 09/398,183
Publication date7 May 2002
Filing date17 Sep 1999
Priority date15 Dec 1992
Fee statusPaid
Also published asDE69315969D1, DE69315969T2, EP0605945A1, EP0605945B1, US5651107, US5999191, US6694486, US20020171682
Publication number09398183, 398183, US 6384840 B1, US 6384840B1, US-B1-6384840, US6384840 B1, US6384840B1
InventorsEdward H. Frank, Patrick J. Naughton, James Arthur Gosling, John C. Liu
Original AssigneeSun Microsystems, Inc.
Export CitationBiBTeX, EndNote, RefMan
External Links: USPTO, USPTO Assignment, Espacenet
Method and apparatus for presenting information in a display system using transparent windows
US 6384840 B1
Abstract
A central processing unit (CPU) is provided and is coupled to a display for displaying graphic and other data in multiple overlapping windows. The CPU is further coupled to one or more input devices which permits a user to selectively position a cursor and input and manipulate data within each of the windows on the display. The windows include defined areas having window features such as text, icons and buttons corresponding to functions to be executed by the CPU. Multiple applications may be executed concurrently by the CPU such that each application is associated with one or more windows. Each display element (“pixel”) comprising the display is represented by multiple bits in a computer frame buffer memory coupled to the CPU. An alpha value (α) is associated with the intensity of each pixel of the display, such that multiple images may be blended in accordance with a predefined formula utilizing the alpha values. By setting the alpha values appropriately, transparency may be accomplished such that data associated with underlying windows may be rendered visible to the user. Effectively, the present invention merges multiple images through alpha “blending” such that several images appear transparently on top of one another. The present invention, through the selective use of alpha blending, permits underlying windows to display data visible to the user through windows which are overlaid above an underlying window.
Images(10)
Previous page
Next page
Claims(7)
We claim:
1. An apparatus for selectively displaying objects on a display, comprising:
means for storing a first display object and at least one corresponding transparency value;
means for storing a second display object and at least two corresponding transparency values, each of which is associated with a different portion of said second display object; and
means for displaying the first and second display objects on the display such that at least a portion of said first display object and at least a portion of said second display object are simultaneously visible in an overlapping area based on the transparency value of the first object and two or more transparency values of the second display object.
2. A method for selectively operating on data within at least one of a plurality of objects on a display, the plurality of objects including a first display object having a first depth value and at least one corresponding transparency value, and a second display object having a second depth value and at least two corresponding transparency values, each of which is associated with a different portion of said second display object, said method comprising:
displaying the first display object based on the first depth value and second display object based on the second depth value, wherein at least a portion of said first display object and at least a portion of said second display object are simultaneously visible in an overlapping area based on the transparency value of the first object and the two or more transparency values of the second display object;
selecting one of the first and second display objects; and
operating on data within the selected one of the first and second display objects without altering the transparency of the first and second display object.
3. An apparatus for selectively operating on data within at least one of a plurality of objects on a display, the plurality of objects including a first display object having a first depth value and at least one corresponding transparency value, and a second display object having a second depth value and at least two corresponding transparency values, each of which is associated with a different portion of said second display object, said apparatus comprising:
means for displaying the first display object based on the first depth value and second display object based on the second depth value, wherein at least a portion of said first display object and at least a portion of said second display object are simultaneously visible in an overlapping area based on the transparency value of the first object and the two or more transparency values of the transparency values of the second display object;
means for selecting one of the first and second display objects; and
means for operating on data within the selected one of the first and second display objects without altering the transparency of the first and second display object.
4. A computer readable medium for selectively operating on data within at least one of a plurality of objects on a display, the plurality of objects including a first display object having a first depth value and at least one corresponding transparency value, and a second display object having a second depth value and at least two corresponding transparency values, each of which is associated with a different portion of said second display object, said medium comprising:
code for displaying the first display object based on the first depth value and second display object based on the second depth value, wherein at least a portion of said first display object and at least a portion of said second display object are simultaneously visible in an overlapping area based on the transparency value of the first object and the two or more transparency values of the transparency values of the second display object;
code for selecting one of the first and second display objects; and
code for operating on data within the selected one of the first and second display objects without altering the transparency of the first and second display object.
5. A method for selectively operating on data within at least one of a plurality of objects on a display, the plurality of objects including a first display object having a first depth value and at least one corresponding transparency value, and a second display object having a second depth value and at least two corresponding transparency values, each of which is associated with a different portion of said second display object, said method comprising:
displaying the first display object based on the first depth value and second display object based on the second depth value, wherein at least a portion of said first display object and at least a portion of said second display object are simultaneously visible in an overlapping area based on the transparency value of the first object and the two or more transparency values of the transparency values of the second display object;
selecting one of the first and second display objects; and
operating on data within the selected one of the first and second display objects without altering the first and second depth values.
6. An apparatus for selectively operating on data within at least one of a plurality of objects on a display, the plurality of objects including a first display object having a first depth value and at least one corresponding transparency value, and a second display object having a second depth value and at least two corresponding transparency values, each of which is associated with a different portion of said second display object, said apparatus comprising:
means for displaying the first display object based on the first depth value and second display object based on the second depth value, wherein at least a portion of said first display object and at least a portion of said second display object are simultaneously visible in an overlapping area based on the transparency value of the first object and the two or more transparency values of the second display object;
means for selecting one of the first and second display objects; and
means for operating on data within the selected one of the first and second display objects without altering the first and second depth values.
7. A computer readable medium for selectively operating on data within at least one of a plurality of objects on a display, the plurality of objects including a first display object having a first depth value and at least one corresponding transparency value, and a second display object having a second depth value and at least two corresponding transparency values, each of which is associated with a different portion of said second display object, said medium comprising:
code for displaying the first display object based on the first depth value and second display object based on the second depth value, wherein at least a portion of said first display object and at least a portion of said second display object are simultaneously visible in an overlapping area based on the transparency value of the first object and the two or more transparency values of the second display object;
code for selecting one of the first and second display objects; and
code for operating on data within the selected one of the first and second display objects without altering the first and second depth values.
Description

This is a continuation of application Ser. No. 08/719,317, filed Sep. 25, 1996, now U.S. Pat. No. 5,999,191 which is a continuation of Ser. No. 08/291,079, filed Aug. 16, 1994, now U.S. Pat. No. 5,651,107 which is a continuation of 07/991,857, filed Dec. 15, 1992 now abandoned, which are incorporated herein by reference.

BACKGROUND OF THE INVENTION

1. Field of the Invention

The present invention relates to apparatus and methods for displaying and manipulating graphic information, and more particularly, the present invention relates to a computer controlled display system for displaying overlapping windows of data on a display.

2. Art Background

It is common for computer systems incorporating so-called “object oriented” display systems to utilize multiple “windows” on a display in which combinations of text and graphics are disposed to convey information to a user. The windows may take the form of a variety of objects such as a file folder, loose leaf binder, or simple rectangle, and the windows may overlap one another with the “top” window fully visible constituting the current work file.

It is generally believed that one origin of the object oriented display systems is a system known as “Smalltalk”. The Smalltalk approach is to replace many previously commonly coded programming commands with two-dimensional, or three-dimensional, graphics and animation on a computer display. It has been found that most people readily think in terms of images, and a person can absorb and manipulate information presented in a visual context faster than if represented by text. The particular type of graphic interface by which the user interacts with the machine may vary for any given application. For example, many of the object oriented display systems utilize various icons which symbolically indicate the type of operation the computer system will execute if the icon function is chosen. The icons are displayed in conjunction with the windows. In a window based display system, the user may delete information from the window, move data from one window to another, and generally operate on the window as if an actual file or the object is being manipulated. A variety of object oriented systems exist today, and are displayed on computers manufactured by the assignee, Sun Microsystems, Inc., as well as other manufacturers. The ability to operate on images which relate the user to actual objects on, for example, a desktop, results in a stronger manmachine interface. See, for example, D. Robson, “Object-Oriented Software Systems”, BYTE, August 1981, p.74, Vol. 6, No. 8; L. Tesler, “The Smalltalk Environment”, BYTE, August 1981, Vol. ; and Smith, et al, “Star User Interface; An Overview”, National Computer Conference, 1982.

Modern object oriented window based display systems are made possible, in part, through the use of bit-mapped frame buffer display memories. In a bit-map display system, a display element (referred to as a “pixel”) on the display screen is represented by one or more bits in a frame buffer memory. In its simplest form, a block of memory may be allocated in a data processing storage system with each memory bit (a 0 or 1) mapped onto a corresponding pixel on the display. Thus, an entire display screen full of data, in the form of images and/or text, is represented as either a 1 or a 0 in the frame buffer memory. In systems with multiple bits, typically at least eight, it is possible to vary the intensity and color of the pixels on the display.

Over the past ten years, a variety of systems have been developed to generate window based graphic user Interface (GUI) displays. Many systems permit multiple overlapping windows to be displayed, wherein each of the windows represents a different application software program being executed by a processor coupled to the display system. In some systems, the application programs may be executing simultaneously, although the user operates only on the application program represented by the top window. In addition, in many cases only the top window is fully visible to the user with the windows underneath being fully or partially obscured. Thus, although the lower obscured windows may represent active application programs, the user is unable to fully observe the execution of the program since the top window obscures those windows which it overlaps (See, for example, U.S. Pat. No. 4,555,775, Issued November 1985 for a system which utilizes concurrent execution of multiple windows).

As will be described, the present invention uses a graphic display technique known as “transparency” to increase the amount of information presented in a window based system. Using traditional overlapping window concepts, the present invention utilizes a transparency mechanism to present information , such that the user can “see through” certain windows to view underlying data and processes that would normally be obscured.

SUMMARY OF THE INVENTION

An apparatus and method is disclosed which has application for use in computer display systems, and in particular, display systems having object oriented graphic user interfaces with overlapping windows. A central processing unit (CPU) is provided and is coupled to a display for displaying graphic and other data in multiple overlapping windows. The CPU is further coupled to one or more input devices which permits a user to selectively position a cursor and input and manipulate data within each of the windows on the display. The windows include defined areas having window features suchs text, icons and buttons corresponding to functions to be executed by the CPU. Multiple applications may be executed concurrently by the CPU such that each application is associated with one or more windows. Each display element (“pixel”) comprising the display is represented by multiple bits in a computer frame buffer memory coupled to the CPU. An alpha value (α)is associated with the intensity of each pixel of the display, such that multiple images may be blended in accordance with a predefined formula utilizing the α values. By setting the α values appropriately, transparency may be accomplished such that data associated with underlying windows may be rendered visible to the user. Effectively, the present invention merges multiple images through α“blending” such that several images appear transparently on top of one another. The present invention, through the selective use of α blending, permits underlying windows to display data visible to the user through windows which are overlaid above an underlying window.

Accordingly, rather than all windows obscuring other underlying windows, each window (or “object”) of the display system of the present invention has an α value associated with it which may be selectively set. In this way, windows do not need to be clipped with respect to one another, as required in the prior art. The windows are “blended” using the α values to achieve a desired level of transparency. In one embodiment, a slider is displayed within each window which permits the α value to be set by a user through the use of a cursor control device. The α value may be set between the range of 0 and 1, where a setting of 1 results in the window being opaque, and a 0 setting resulting in the window being fully transparent. In addition, a window selection method is disclosed to permit a user to render a window “active” and operate on its contents without disturbing the current window order on the display.

BRIEF DESCRIPTION OF THE DRAWINGS

FIG. 1 illustrates a computer incorporating the teachings of the present invention.

FIG. 2 shows one arrangement of program storage for the system illustrated in FIG. 1.

FIG. 3 illustrates a prior art window based system requiring window clipping for overlapping windows.

FIGS. 4a and 4 b illustrate a prior art window based system in which working text is obscured by a pop-up menu.

FIG. 5 conceptually illustrates the present invention's use of overlapping transparent windows.

FIG. 6 illustrates an application of the present invention to the prior art system illustrated in FIGS. 4a and 4 b.

FIG. 7 illustrates an application of the present invention wherein certain data disposed in windows under the active top window are visible to the user through the selective use of transparency.

FIG. 8 illustrates an application of the present invention in which a user may select the transparency of each window.

FIG. 9 illustrates an application of the present invention wherein a window is selected, converted to a “top” window and rendered active.

FIG. 10 illustrates an application of the present invention where an underlying window is rendered active but operated upon through an overlying window.

NOTATION AND NOMENCLATURE

The detailed descriptions which follow are presented largely in terms of display images, algorithms, and symbolic representations of operations of data bits within a computer memory. These algorithmic descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art.

An algorithm is here, and generally, conceived to be a self consistent sequence of steps leading to a desired result. These steps are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated. It proves convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, images, terms, numbers, or the like. It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities.

In the present case, the operations are machine operations performed in conjunction with a human operator. Useful machines for performing the operations of the present invention include general purpose digital computers or other similar devices. In all cases, there should be borne in mind the distinction between the method operations of operating a computer and the method of computation itself. The present invention relates to method steps for operating a computer and processing electrical or other physical signals to generate other desired physical signals.

The present invention also relates to apparatus for performing these operations. This apparatus may be specially constructed for the required purposes or it may comprise a general purpose computer selectively activated or reconfigured by a computer program stored in the computer. The algorithms presented herein are not inherently related to any particular computer or other apparatus. In particular, various general purpose machines may be used with programs in accordance with the teachings herein, or it may prove more convenient to construct more specialized apparatus to perform the required method steps. The required structure for a variety of these machines will appear from the description given below. Machines which may perform the functions of the present invention include those manufactured by the Assignee, Sun Microsystems, Inc., as well as other manufacturers of computer systems.

DETAILED DESCRIPTION PRESENTLY PREFERRED AND ALTERNATE EMBODIMENTS

The present invention discloses apparatus and methods for displaying graphic information in a window based system on a computer display. In the following description, numerous specific details are set forth such as computer system configurations, window elements, icons, etc. in order to provide a thorough understanding of the present invention. However, it will be apparent to one skilled in the art that the present invention may be practiced without these specific details. In other instances, well known circuits and structures are not described in detail in order not to obscure the present invention unnecessarily.

FIG. 1 illustrates a computer based system for generating a window based graphic user interface in accordance with the teachings of the present invention. Shown is a computer 10 which comprises three major components. The first of these is an input/output (I/O) circuit 12 which is used to communicate information in appropriately structured form to and from other portions of the computer 10. In addition, computer 10 includes a central processing unit (CPU) 14 coupled to the I/O circuit 12 and a memory 16. These elements are those typically found in most general purpose computers and, in fact, computer 10 is intended to be representative of a broad category of data processing devices. Also shown in FIG. 1 is a keyboard 18 to input data and commands into computer 10, as is well known. A magnetic disk 20 is shown coupled to I/O circuit 12 to provide the additional storage capability for the computer 10. It will be appreciated that additional devices may be coupled to computer 10 for storing data such as magnetic tape drives, bubble memory devices, as well as networks which are in turn coupled to other data processing systems. As is well known, disk 20 may store other computer programs, characters, routines, etc., which may be accessed and executed by CPU 14. A raster display monitor 24 is shown coupled to the 1,0 circuit 12 and is used to display Images generated by CPU 14 in accordance with the present invention. Any well known variety of cathode ray tube (CRT), liquid crystal, or other displays may be utilized as display 24. A cursor control device 28 is also shown coupled to computer 10 through I/O circuit 12. Cursor control device 28 includes switches 30, 32 and 34 for signaling CPU 14 in accordance with the teachings of the present invention. Cursor control device 28 (commonly known as a “mouse”) permits a user to select various command modes, modify graphic data, and input other data utilizing switches 30, 32 and 34. More particularly, cursor control device 28 permits a user to selectively position a cursor 36 at any desired location on display 24 by movement of the cursor control device 28 over a surface 40. In the presently preferred embodiment, cursor control 28 utilizes a well known optical method for signaling CPU 14 of positional changes of cursor 36 by movement of cursor control over a grid disposed on surface 40. However, it will be appreciated that a variety of well known cursor control devices may be utilized by the present invention, including other control devices such as mechanical mice, track balls, joy sticks, etc.

FIG. 2 shows one arrangement of major programs contained within the memory 16 illustrated in FIG. 1. In particular, there is shown a frame buffer 50, which comprises a bit map of display 24. The frame buffer 50 represents the video memory for the display 24, wherein, each storage location comprising a plurality of bits in the frame buffer 50 corresponds to a pixel on the display 24. Thus, the frame buffer comprises a two dimensional array of points having known coordinates corresponding to the pixels on the raster display. In its simplest form, frame buffer 50 comprises a contiguous block of memory which is allocated such that each memory location is mapped onto the corresponding pixel on the rastor display 24. Memory 16 also includes a variety of other programs 54 for execution by the CPU 14. For example, a variety of control, display, and calculating programs implementing the operations and routines described in this Specification may be stored in memory 16, as well as monitor control programs and disk operating systems. Moreover, memory 16 further includes space for other programs and spare memory 56 which may be used for a variety of other well known functions and operations in data processing systems.

Referring now to FIG. 3, a conceptual illustration of a prior art window based display system is shown. As illustrated, a top active window 100 overlays a window 102, which in turn overlays a window 103. In certain computer systems, the only active window being updated by the CPU 14 of FIG. 1 would be window 100. Other systems concurrently execute multiple programs resulting in constant updates to data disposed within window 100, window 102, and window 103. However, in prior art window based systems, the windows have a spatial hierarchy such that the window on top (window 100) obscures all, or portions of, the windows below them (window 102 and window 103). As such, prior art display systems must incorporate the use of window clipping techniques to appropriately obscure, and thereby clip, the windows such that nonvisible data is not displayed since it is obscured by overlapping windows. A variety of methods have been devised over the years to achieve window clipping (See for example, U.S Pat. No. 4,622,545, Issued Nov. 11, 1986).

In traditional window based display systems, a user operating on data disposed in window 100 would have to select a window to operate upon. In many current generation window display systems, the user places the cursor 36 in the area comprising window 103, and momentarily depresses (“clicks”) switch 34 on mouse 28, to bring that window to the top and operate on data within window 103. In prior art based window systems, the user is unable to view data obscured by overlapping windows, and thereby monitor the progress or operate on programs represented by the underlying windows while actively operating on data in the top window 100. For example, as shown in FIG. 3, areas of windows 102 and 103 are obscured, rendering data in these areas unusable to the user.

Referring now to FIGS. 4a and 4 b, an example of the problem of obscured windows in a prior art system is illustrated. FIG. 4a illustrates a portion of a prior art word processing system in which the user desires to operate upon the word “text”. The user highlights the word “text” using a cursor control device, such as mouse 28 of FIG. 1. In certain word processing systems, the selection of a word such as “text” of FIG. 4a results in a pop-up menu 110 being displayed. The pop-up menu 110 identifies the operations on sub-commands available to a user. As illustrated in FIG. 4b, pop-up menu 110 obscures the word “text” being operated upon. In the example illustrated, the pop-up menu 110 constitutes a (albeit a small) window which obscures a portion of the text disposed in the underlying word processing window 109.

For purposes of this patent and invention, a “window” may be a traditional rectangular region on a display in which data is displayed, as well as smaller sub-regions, such as pop-up, pull-down or other menus, icons, symbols or other display elements, and objects, generally. In the case of objects such as icons, the “data” displayed in the object may comprise only the pixels defining the icon. In objects such as rectangular windows, menus or sub-menus, the data displayed in such objects may include alpha numeric and/or graphic data. Accordingly, it will be appreciated that the apparatus and method of the present invention has application to any object displayed on the display 24, regardless of the shape, size or function of the object in any particular computer display system.

Referring now to FIG. 5, the present invention is conceptually Illustrated with reference to a display 150 having a top window 155 and a window disposed “under” window 155 identified by the numeral 158. As previously discussed, each pixel of the display 150 is represented by multiple bits in the frame buffer 50. A common technique for blending images is referred to as “α blending”, in which two images may be blended on a pixel by pixel basis according to the formula:

α*X+(1−α)*Y

where α is a number that ranges from 0 to 1. When α is a 1, the pixel will contain only the X input value, when α is a 0, the pixel will contain only Y image input. When α is disposed between 1 and 0, it will contain both X and Y image information. For example, if α is 0.1, then the image on the screen will appear to be the Y image with the faint image of the X image. The visual look and feel is that the X image appears as though it is transparent, and that one can see through X and also see the Y image.

Referring once again to FIG. 5, in a two window display system, where window 155 represents the A window, window 158 represents a B window, and where C represents the entire display area 150 of the display screen:

for all pixels where

A∩B{C←B(1−α)+Aα}

where α =the transparency of A

Accordingly, multiple images can be merged, and appear transparently on top of one another. In addition, it will be appreciated by one skilled in the art that the exact nature of the α blend operation will depend on the visual effect desired, as well as the number of bits per pixel in the intensity domain available (See also, Foley, VanDam et al. “Computer Graphics Principles and Practice”, 2nd Edition (Addison Wesley 1990) for additional information on transparency techniques).

In addition, the images within each window 155 and 158 need not have the same α value for every pixel. In fact, the center of a graphic object within, for example window 155, may have an α value of 1 (i.e., it fully obscures the object it is blended with), while the edges may have an α value less than 1. The effect is that the edges of the graphic object within window 155 are blurred with what is “behind” them, and thus appear smoother.

Using the teachings of the present invention, it is possible to define different α values on an object by object basis. For example, within a window objects can be identified, and their transparency can be defined, using a pixel based mask α table. In the example below, four pixels are associated with each source (source 1 and source 2), wherein each pixel has an α value which can be independently set. The pixel mask includes α values, m1,m2,m3, and m4. The results d1,d2,d3, and d4 represent the pixel mixing of source1 and source2, on a pixel by pixel basis, as described below.

Example

source 1 source 2 mask source 1
|x1 x2| |y1 y2| |m1 m2| |d1 d2|
|x3 x4| |y3 y4| |m3 m4| |d3 d4|

source 1 has 4 pixels: x1, x2, x3 and x4

source 2 has 4 pixels: y1, y2, y3 and y4

a two-dimensional array mask also defines the weighting for each pixel

where d1 = x1 * m1 + y1 * ( 1 - m1 ) d3 = x3 * m3 + y3 * ( 1 - m3 ) d2 = x2 * m2 + y2 * ( 1 - m2 ) d4 = x4 * m4 + y4 * ( 1 - m4 )

It will be appreciated that the above example for pixel mixing uses the case of four pixels for simplicity of description. The present invention's method may be used with N pixels for each source, wherein each source is provided with an α mask table having the same pixel resolution as the source. In the case of N sources, there will be a corresponding N masks.

Furthermore, since each pixel from a source has associated with it an a value in the mask, it is possible to group pixels representing an object and selectively vary the object's degree of transparency. An example of the grouping of pixels to represent an object is illustrated with respect to the file folder 225, and the airplane 220, in FIG. 7, described below.

Using the teachings of the present invention In a window system running on a multiple bit per pixel display, and where a multitude of intensities are available per pixel, each window has an α value associated with it. In this way, windows need not be clipped with respect to one another, but rather, they are simply blended using a technique as noted above with respect to FIG. 5. Of course, the windows may still need to be clipped with respect to the edge of the display screen. In accordance with the present invention, if a traditional window system is desired, wherein the top window obscures windows which it overlays, the α value of a window is set to 1 whenever a window is visible, and a 0 where it is obscured. To implement windows that are fully or partially transparent, the user, or alternatively an automatic routine within the program, sets the α value as appropriate for the desired level of transparency. It will be noted that the α value may represent any arbitrary function, and the value may be scaled to any integer (in the present example 0 to 1).

Referring now to FIG. 6, a simple example of the present invention's use of transparency and overlapping windows is illustrated. In FIG. 6, a window 120 containing word processing text is illustrated. As in the example illustrated in FIGS. 4a and 4 b, the word “text” is selected by a user using a cursor control or other input device. A popup menu 125 is generated and displayed which contains a variety of word processing options or sub-commands the user may use to operate on the selected word. However, in accordance with the teachings of the present invention, the α value for the popup window 125, is set such that window 125 is partially transparent, thereby permitting the user to see both the popup window 125 as well as the underlying words within the word processing document which would otherwise be obscured. By allowing the menu 125 to have an α value less than 1, for example0.3, the menu 125 will remain readable to the user, while the information “behind” the popup menu 125 is still visible.

Referring now to FIG. 7, another example of the present invention is illustrated. A display 200 includes three windows, namely, a top window 205, an intermediate window 210 and a bottom window 215 all overlapping as shown in the figure. As can be seen, window 215 includes a graphic representation of an airplane 220 and an icon 225 in the shape of a file folder. The α value for the pixels comprising the graphic representation of the airplane 220 has been set to a value of 1. Therefore, that portion of window 215 comprising the graphic representation of the airplane 220 implements a traditional window system while pixels in peripheral areas of window 215 have been set to a value less than 1. As illustrated, the icon 230 identified as “HD” represents an icon which is not obscured by any window and has also been given an α value set equal to 1. However, the icon 225 is “behind” and obscured by window 215, but the icon 225 is still visible to the user through window 215 since the pixels in the periphery of window 215 have α values less than 1. In other words, to achieve transparency, the α value for window 215 over that portion of the display obscuring icon 225 has been set to a value less than 1 (for example 0.3). Thus, the icon 225 is visible since that portion of window 215 has been rendered transparent through the appropriate setting of the α value.

Referring now to window 205 of FIG. 7, this window conceptually illustrates a window in which word processing application is being executed. As shown, the text of the window is clearly visible and being operated upon by the user. Since window 205 is on “top” of windows 210 and 215, window 205 is designated as the “active” window in this example. As illustrated, window 210 is disposed immediately “below” active window 205. In FIG. 7, window 210 represents an electronic mail program which lists current mail messages being stored and identifies new mail messages received. In prior art systems, the mail list comprising the list of mail messages would be obscured by window 205. In order for a user to view the mail list in window 210, the user would have to render the window 210 the “active” window and bring it to the “top” such that it overlaid window 205. However, by appropriately setting the α value for the pixels comprising window 205, the mail list displayed in window 210 is visible as a “ghost” image through the window 205. As such, a user may operate upon the data displayed in the word processing window 205 while viewing the mail list displayed in window 210. If an incoming message is of interest to the user, the user may view, and thereby identify, the incoming message in the mail list of window 210 without the necessity of dismissing window 205 or bringing window 210 to the “top” of the desktop.

Accordingly, it will be appreciated by one skilled in the art that through the selective setting of α values for pixels comprising windows on a display that data in desired windows may be rendered visible, even If obscured by overlaying windows. The setting of the α value may be under program or user control depending on how the invention is utilized, as will be described more fully below.

Referring now to FIG. 8, there is shown a display 250 having windows 255 and 260 displayed therein. As shown, window 260 overlays window 255 in FIG. 8. Window 260 includes a slider 262 which permits the setting of the α value for window 260 between 0 and 1. In operation, a slider bar 264 is moved selectively by a user using a cursor control device, such as cursor control device 28 of FIG. 1. Similarly, window 255 includes a slider control 270 with a slider bar 272. In the present example, window 260 comprises a window displaying the names of files accessible to a word processing document such as “Olient Names”, “November 1992 time”, and the like. Window 255 is a clock program to provide the current time to a user through the display of an analog clock face. It will be appreciated that in prior art window based systems, window 260 would obscure a portion of a clock face 275 displayed within window 255. Thus, it is very inconvenient if the user desires to read the current time from clock face 275, since window 255 would be partially obscured by window 260. Only by dismissing window 260, or rearranging the position of the windows on the display 250, could the user read the time.

Utilizing the teachings of the present invention, the prior art problem of obscured windows is eliminated. In the example illustrated in FIG. 8, the α value for window 260 is set to a value of less than 1 (approximately 0.8) by the user positioning the slide bar 264 using, for example, the mouse 28. It is contemplated that the user may set the slide bar 264 by placing a cursor 265 in FIG. 8 over a portion of the slide bar 264, depressing a switch, such as switch 34 on the mouse 28 (See FIG. 1), move the slide bar to an appropriate position on the slider 262, and release switch 34. As shown in FIG. 8, since the α value for window 260 has been set less than 1, window 260 is rendered partially transparent, thereby allowing a user to view the entire clock face 275 displayed in window 255. As shown, slide bar 272 has been set such that the α value for window 255 is equal to 1. Accordingly, window 255 comprises a traditional window which is not transparent.

Assume for sake of example that an alarm associated with clock 275 sounds which the user desires to shut off. As shown in FIG. 8, window 255 includes a shut off alarm box 277 which is visible to the user through window 260. In one embodiment of the present invention, to obtain access to the shut off alarm box 277, it is necessary for the user to render window 255 the top “active” window. Using a common window selection technique, the cursor 265 is placed within the region of window 255 using mouse 28, and the user signals the CPU 14 of the window selection. In many window based systems, the user signals CPU 14 by clicking a switch, such as switch 34, on mouse 28, and the CPU 14 then re-renders windows 255 and 260 in display 250, such that window 255 now overlays window 260 as shown in FIG. 9. The user then has full access to window 255, and can place the cursor 265 over the shutoff alarm box 277 and “click” to terminate the alarm.

Although it is traditional to bring all active windows to the top in a window based system prior to operating upon them, utilizing the teachings of the present invention, it is not necessary.

Referring now to FIG. 10, windows 255 and 260 are once again Illustrated as being displayed in display 250. However, it will be noted that active window selection buttons 280, 281, 282 and 283 have been added to the four corners of window 255. Similarly, buttons 285, 286, 287 and 288 have been added to the four corhers of window 260, as shown. By placing cursor 265 over one of the buttons 280 to 283 in window 255, or one of buttons 285 to 288 for window 260, and momentarily depressing switch 34 on mouse 28 as previously described, either window 255 or window 260 may be selected without altering the relative position of the windows on the display 250. For example, if a user desires access to shut off alarm box 277 but does not wish to bring window 255 to the top, the user simply places cursor 265 over one of buttons 280 through 283, and signals the CPU 14 by “clicking” switch 34 on mouse 28. The selection of window 255 through the use of buttons 280 to 283 permits the user to access shut off alarm box 277 “through” window 260. Thus, the window 260 not having been rendered “active” is transparent to the actions of the user, thereby permitting the user to operate on data disposed in an underlying window such as, for example, accessing the shut off alarm box 277 in the example of FIG. 10. It will be noted that although buttons 285 to 288 and 280 to 283 have been shown to illustrate one method for designating a window as active, a variety of other methods such as icons, highlighted title bars, and mechanisms may be used to accomplish similar results.

In addition to the above described features of the present invention, it will be appreciated that the present invention's use of α values allows windows to be sorted such that the most transparent window is above less transparent windows. By sorting and subsequently displaying windows based on α values, the top window will always be the most transparent (See FIG. 10), with progressively less transparent windows displayed thereunder.

Accordingly, the present invention's use of transparency in a window based system increases the usable area of a display by permitting otherwise obscured window data to be visible to, and operated on, by the user. By appropriately setting the α value, features such as scroll bars, window headers, boarders, icons and other general window data may be rendered fully or partially transparent for the particular application. While the invention has been described with reference to FIGS. 1 through 10, it will be appreciated that the figures are for illustration only and do not limit the spirit and scope of the invention.

Patent Citations
Cited PatentFiling datePublication dateApplicantTitle
US45339102 Nov 19826 Aug 1985Cadtrak CorporationGraphics display system with viewports of arbitrary location and content
US45557757 Oct 198226 Nov 1985At&T Bell LaboratoriesDynamic generation and overlaying of graphic windows for multiple active program storage areas
US462254530 Sep 198211 Nov 1986Apple Computer, Inc.Method and apparatus for image compression and manipulation
US464545930 Jul 198224 Feb 1987Honeywell Inc.Computer generated synthesized imagery
US474861821 May 198631 May 1988Bell Communications Research, Inc.Telecommunications interface
US477288218 Jul 198620 Sep 1988Commodore-Amiga, Inc.Cursor controller user interface system
US478540811 Mar 198515 Nov 1988AT&T Information Systems Inc. American Telephone and Telegraph CompanyMethod and apparatus for generating computer-controlled interactive voice services
US48067765 Aug 198521 Feb 1989Kley Victor BElectrical illumination and detecting apparatus
US48128341 Aug 198514 Mar 1989Cadtrak CorporationGraphics display system with arbitrary overlapping viewports
US48687652 Jan 198619 Sep 1989Texas Instruments IncorporatedPorthole window system for computer displays
US488422322 Mar 198828 Nov 1989Hybond, Inc.Dynamic force measurement system
US489311616 Nov 19879 Jan 1990Ncr CorporationLogical drawing and transparency circuits for bit mapped video display controllers
US489629120 May 198823 Jan 1990International Business Machines CorporationValuator menu for use as a graphical user interface tool
US489913628 Apr 19866 Feb 1990Xerox CorporationData processor having a user interface display with metaphoric objects
US49147328 Sep 19893 Apr 1990Supra Products, Inc.Electronic key with interactive graphic user interface
US491862518 Jul 198917 Apr 1990Cae-Link CorporationMethod and apparatus for processing translucent objects
US493178326 Jul 19885 Jun 1990Apple Computer, Inc.Method and apparatus for removable menu window
US493950715 Aug 19883 Jul 1990Xerox CorporationVirtual and emulated objects for use in the user interface of a display screen of a display processor
US50619191 May 198929 Oct 1991Evans & Sutherland Computer Corp.Computer graphics dynamic control system
US506206017 May 198929 Oct 1991Motorola Inc.Computer human interface comprising user-adjustable window for displaying or printing information
US507241225 Mar 198710 Dec 1991Xerox CorporationUser interface with multiple workspaces for sharing display system objects
US50917171 May 198925 Feb 1992Sun Microsystems, Inc.Apparatus for selecting mode of output in a computer system
US51013657 Nov 199031 Mar 1992Sun Microsystems, Inc.Apparatus for extending windows using Z buffer memory
US510948124 Jul 198728 Apr 1992Hewlet-Packard CompanyQuadratic interpolation for shaded image generation
US51504572 May 199022 Sep 1992International Business Machines CorporationEnhanced visualization using translucent contour surfaces
US515580629 Dec 198913 Oct 1992Sun Microsystems, Inc.Method and apparatus for displaying context sensitive help information on a display
US515776817 May 199120 Oct 1992Sun Microsystems, Inc.Method and apparatus for displaying context sensitive help information on a display
US517044311 Dec 19908 Dec 1992International Business Machines CorporationImage processor for processing source pixel intensity values
US51858086 Jun 19919 Feb 1993Eastman Kodak CompanyMethod for merging images
US521675520 Jun 19911 Jun 1993Quantel LimitedVideo image creation system which proportionally mixes previously created image pixel data with currently created data
US52222034 May 199222 Jun 1993Daikin Industries, Ltd.Method and apparatus for displaying translucent surface
US52278637 Aug 199013 Jul 1993Intelligent Resources Integrated Systems, Inc.Programmable digital video processing system
US52376534 Jun 198717 Aug 1993Hitachi, Ltd.Multiwindow control method and apparatus for work station having multiwindow function
US52606952 Sep 19929 Nov 1993Hewlett-Packard CompanyColor map image fader for graphics window subsystem
US526520228 Aug 199223 Nov 1993International Business Machines CorporationMethod and system for accessing visually obscured data in a data processing system
US528356025 Jun 19911 Feb 1994Digital Equipment CorporationComputer system and method for displaying images with superimposed partially transparent menus
US53393868 Aug 199116 Aug 1994Bolt Beranek And Newman Inc.Volumetric effects pixel processing
US535106722 Jul 199127 Sep 1994International Business Machines CorporationMulti-source image real time mixing and anti-aliasing
US53634755 Dec 19898 Nov 1994Rediffusion Simulation LimitedImage generator for generating perspective views from data defining a model having opaque and translucent features
US54043163 Aug 19924 Apr 1995Spectra Group Ltd., Inc.Desktop digital video processing system
US547960321 Jul 199326 Dec 1995Xerox CorporationMethod and apparatus for producing a composite second image in the spatial context of a first image
US556181110 Nov 19921 Oct 1996Xerox CorporationMethod and apparatus for per-user customization of applications shared by a plurality of users on a single display
US558167021 Jul 19933 Dec 1996Xerox CorporationUser interface having movable sheet with click-through tools
US561711424 May 19951 Apr 1997Xerox CorporationUser interface having click-through tools that can be composed with other tools
US565110716 Aug 199422 Jul 1997Sun Microsystems, Inc.Method and apparatus for presenting information in a display system using transparent windows
US572970416 Jan 199617 Mar 1998Xerox CorporationUser-directed method for operating on an object-based model data structure through a second contextual image
USRE3263220 Dec 198529 Mar 1988Apple Computer, Inc.Display system
EP0159400A14 Dec 198430 Oct 1985International Business Machines CorporationDisplay terminal with a cursor responsive virtual distributed menu
EP0239884A120 Mar 19877 Oct 1987International Business Machines CorporationInteractive video composition and presentation systems
EP0280582A229 Feb 198831 Aug 1988Axiom Innovation LimitedImprovements in computer graphics systems
EP0344082A225 Apr 198929 Nov 1989International Business Machines CorporationMethod for accessing visually obscured data in a multi-tasking system
EP0524461A22 Jul 199227 Jan 1993International Business Machines CorporationMulti-source image real time mixing and anti-aliasing
Non-Patent Citations
Reference
1"Microsoft Windows User's Guide for the Windows Graphical Environment Version 3.0," Microsoft Corp. (1990), pp. 34-55.
2"Microsoft Windows User's Guide for the Windows Graphical Environment Version 3.0," Microsoft Corp. (1990), pp. 54, 55, and 84-86.
3Alexander, "Visualizing cleared-off desktops," Computer=World, May 6, 1991, p. 20.
4Article entitled: Browsing Within Time-Driven Multimedia Documents; authors: Stavros Christodoulakis and Steven Graham; publication of the Institute for Computer Research, University of Waterloo, Waterloo, Ontario, Canada, Jul. 1988.
5Article entitled: Creation/Modification of the Audio Signal Processor Setup for a PC Audio Editor; publication of International Business Machines, IBM Technical Disclosure Bulletin, vol. 30, No. 10, Mar. 1988.
6Blatt, Jeffrey J., "A Printer on User Interface Software Patents," The Computer Lawyer, vol. 9, No. 4 (Apr. 1992).
7Hiroshi Ishii, Kazuho Arita, "Clearface: Translucent Multiuser Interface for Team Work Station," ECSCW, Sep. 1991, pp. 6-10.
8Hiroshi Ishii, Naomi Miyaka, "Toward an Open Shared Workspace," Communications of the ACM, Dec. 1991, vol. 34, No. 12, pp. 37-50.
9IBM Technical Disclosure Bulletin, vol. 15, No. 9, Feb. 1973, New York, US, pp. 2721-2722.
10IBM Technical Disclosure Bulletin, vol. 30, No. 1, Apr. 1988, New York, pp. 268-270.
11N. Meyrowitz & M. Moser, "Bruwin: An Adaptable Design Strategy for Window Manager/Virtual Terminal Systems," 1981 ACM 0-89791-062-1-12/81-0180.
12Patrick P. Chan, "Learning Considerations in User Interface Design: The Room Model," Software Portability Laboratory, University of Waterloo, Waterloo, Ontario, Canada, Jul. 1984.
13R. Pike, "Graphics in Overlapping Bitmap Layers," ACM Transactions on Graphics, vol. 2, No. 2 (Apr. 1983).
14Software Practice & Experience, vol. 21, No. 4, Apr. 1991, Chichester, GB, pp. 375-390.
15The Third International Conference on Industrial and Engineering Applications of Artificial Intelligence and Expert Systems, vol. 1, Jul. 15, 1990, Charleston, SC, pp. 341-349.
16W. Teitelman, "Ten Years of Window Systems-A Retrospective View," Methodology of Window Management (Springer-Verlag, New York 1986), pp. 35-46.
17W. Teitelman, "Ten Years of Window Systems—A Retrospective View," Methodology of Window Management (Springer-Verlag, New York 1986), pp. 35-46.
Referenced by
Citing PatentFiling datePublication dateApplicantTitle
US6476831 *11 Feb 20005 Nov 2002International Business Machine CorporationVisual scrolling feedback and method of achieving the same
US6579324 *30 Apr 199917 Jun 2003Microsoft CorporationMethod for indicating a selected region on a computer display while allowing the user to see the formatting of the background and content items within the selected region
US6630945 *9 Nov 19997 Oct 2003Broadcom CorporationGraphics display system with graphics window control mechanism
US6694486 *7 May 200217 Feb 2004Sun Microsystems, Inc.Method and apparatus for presenting information in a display system using transparent windows
US6727921 *20 Mar 200027 Apr 2004International Business Machines CorporationMixed mode input for a graphical user interface (GUI) of a data processing system
US6928624 *6 Mar 20009 Aug 2005Intel CorporationMethod and apparatus to display video
US6971071 *8 Mar 200029 Nov 2005Microsoft CorporationSystem and method for implementing an image ancillary to a cursor
US72315884 May 200512 Jun 2007Via Technologies Inc.Video display apparatuses and display methods thereof
US7232058 *1 Sep 200419 Jun 2007Samsung Electronics Co., Ltd.Data displaying apparatus and method
US726979411 Sep 200311 Sep 2007International Business Machines CorporationMethod and apparatus for viewpoint collaboration
US727810710 Dec 20022 Oct 2007International Business Machines CorporationMethod, system and program product for managing windows in a network-based collaborative meeting
US74633071 Apr 20059 Dec 2008Mstar Semiconductor, Inc.Display controlling device capable of displaying multi-windows and related method
US7530027 *18 Jul 20035 May 2009Broadcom CorporationGraphics display system with graphics window control mechanism
US7533351 *13 Aug 200312 May 2009International Business Machines CorporationMethod, apparatus, and program for dynamic expansion and overlay of controls
US7554581 *27 Oct 200330 Jun 2009Samsung Techwin Co., Ltd.Method of controlling a camera for users having impaired vision
US76677173 Jun 200423 Feb 2010Microsoft CorporationSystem and method for displaying images utilizing multi-blending
US7746358 *3 Jan 200729 Jun 2010Vistaprint Technologies LimitedIndirect image control using a surrogate image
US7843469 *21 Jul 200630 Nov 2010The Boeing CompanyOverlaying information onto a view for electronic display
US785360614 Sep 200414 Dec 2010Google, Inc.Alternate methods of displaying search results
US8078981 *10 Nov 200813 Dec 2011Broadcom CorporationGraphics display system with graphics window control mechanism
US8156444 *31 Dec 200310 Apr 2012Google Inc.Systems and methods for determining a user interface attribute
US8203742 *18 May 200619 Jun 2012Xerox CorporationProducing postscript bitmap images with varying degrees of transparency
US82906422 Mar 200716 Oct 2012The Boeing CompanyElectronic flight bag having filter system and method
US832727714 Jan 20084 Dec 2012Microsoft CorporationTechniques to automatically manage overlapping objects
US837011127 Mar 20095 Feb 2013The Boeing CompanySystem and method for forming optimized perimeter surveillance
US859521431 Mar 200426 Nov 2013Google Inc.Systems and methods for article location and retrieval
US86128615 Jun 200717 Dec 2013International Business Machines CorporationViewpoint collaboration
US863132725 Jan 201214 Jan 2014Sony CorporationBalancing loudspeakers for multiple display users
US20070268505 *18 May 200622 Nov 2007Smith Glenn KProducing postscript bitmap images with varying degrees of transparancy
US20110107212 *2 Nov 20105 May 2011Pantech Co., Ltd.Terminal and method for providing see-through input
CN100390825C3 Jun 200428 May 2008微软公司Method for mxing multi-images
Classifications
U.S. Classification345/634, 345/629, 715/788
International ClassificationG06T3/00, G06F3/14, G06F3/048, G06T11/00, G06F3/033, G09G5/14
Cooperative ClassificationG06F3/0481, G09G2310/02, G09G2340/10, G06F2203/04804, G09G5/14
European ClassificationG06F3/0481, G09G5/14
Legal Events
DateCodeEventDescription
9 Oct 2013FPAYFee payment
Year of fee payment: 12
7 Oct 2009FPAYFee payment
Year of fee payment: 8
14 Oct 2005FPAYFee payment
Year of fee payment: 4