This disclosure generally relates to displaying windows on a graphical user interface.
Modern operating systems employ windows for displaying information in graphical user interfaces. When multiple windows are displayed in a graphical user interface, the windows can be displayed in an overlapping manner to indicate a relative height or depth (e.g., z-order) of the windows. For example, a window that obscures another window can appear to be displayed over the obscured window.
Some operating systems provide for multiple workspaces. A workspace can be associated with one or more windows. For example, to increase the amount of space on an operating system desktop, the desktop can be expanded and divided up into multiple workspaces that can be viewed independently. A user can assign different windows to different workspaces and move between workspaces to view the different windows.
In some implementations, windows can be displayed based on a global z order. The global z-order can be maintained for all windows and can include windows that are not currently displayed. The global z-order can define a display order of windows across multiple workspaces. In some implementations, workspaces can be associated with levels. The workspace levels can be used to determine how to display windows associated with each workspace when multiple workspaces are displayed simultaneously.
Particular implementations provide at least the following advantages: Displaying windows based on a global z-order can provide a consistent window display across workspaces thereby reducing user confusion and improving ease of use. Displaying workspace windows based on workspace levels allows users to prioritize workspaces. Windows associated with high priority workspaces to be viewed and accessed more quickly than lower priority workspace windows.
Details of one or more implementations are set forth in the accompanying drawings and the description below. Other features, aspects, and potential advantages will be apparent from the description and drawings, and from the claims.
Like reference symbols in the various drawings indicate like elements.
In some implementations, windows can be displayed based on an elevation or z-order. The z-order can define an elevation display order (e.g., between a user and the desktop) of windows relative to other displayed windows. For example, window elevation or z-order can be shown by a window overlapping or obscuring another window. For example, window 106 partially obscures window 104 indicating that window 106 has a higher elevation (e.g., higher z-order) than window 104. Window 108 partially obscures window 108 indicating that window 108 has a higher elevation (e.g., z-order) than window 106.
In some implementations, the z-order for windows 104-108 is workspace specific. For example, the z-order (e.g., the display order) for windows within workspace 102 can be determined independently of windows associated with other workspaces.
In some implementations, each workspace can be associated with one or more windows. Workspace 302 can be associated with windows 304-308, for example. Workspace 322 can be associated with windows 308 and 310. Workspace 342 can be associated with windows 304 and 306. A window can be associated with one workspace, many workspaces, all workspaces, or no workspaces, for example. In some implementations, graphical interface 300 can switch between workspaces 302, 322 and 342. For example, a user can provide input to cause graphical interface 300 to switch between displaying workspace 302 (e.g., windows 304-308), displaying workspace 322 (e.g., windows 308 and 310) and displaying workspace 342 (e.g., windows 304 and 306).
In some implementations, the windows associated with each workspace can be displayed based on a global z-order (e.g., a system-wide z-order for windows). For example, instead of ordering windows according to workspace (e.g., a workspace z-order), every window in every workspace (e.g., visible or hidden) can be included in the global z-ordering. In some implementations, windows 304-310 can each be associated with a global z-order value (e.g., array index, position in list, assigned value, etc.). For example, window 304 can be assigned a global z-order value of one, window 306 can be assigned a global z-order value of two, window 308 can be assigned a global z-order value of three and window 310 can be assigned a global z-order value of four. The global z-order value can be used to determine the global z-order of windows across all workspaces. In some implementations, the global z-order can include both visible and hidden windows. For example, if workspace 302 is displayed and workspaces 322 and 342 are hidden, the global z-order can include windows 304-310 even though window 310 is hidden with hidden workspace 322. Thus, as a user switches between visible and hidden workspaces, the relative display order of windows in each workspace can be maintained thereby presenting a consistent and predictable window display ordering.
In some implementations, the global z-order can be updated as windows are manipulated within a workspace. For example, if workspace 302 is displayed and a user selects window 304, window 304 can be moved above windows 306 and 308 in workspace 302. When window 304 is selected, the global z-order of windows can be updated to reflect the movement of window 304. For example, window 304 can be assigned a global z-order value of four, window 310 can be assigned a global z-order value of three, window 308 can be assigned a global z-order value of two and window 306 can be assigned a global z-order value of one in response to the selection of window 304. Thus, when workspace 342 is subsequently displayed, window 304 can be displayed above window 306 based on the adjusted global z-order, for example.
In some implementations, workspaces can be associated with different levels. For example, workspace 302 can have a workspace level of one and workspace 322 can have a workspace level of zero. Thus, based on the assigned workspace level, workspace 302 can be determined to be at a higher (or lower) level than workspace 322. In some implementations, when workspace 302 has a higher workspace level than workspace 322, workspace 302 can be displayed overlaid on workspace 322, as illustrated by
In some implementations, windows associated with a higher level workspace are given priority. For example, when multiple workspaces are displayed simultaneously, the union set of windows from the displayed workspaces is determined and displayed. Thus, when displaying workspace 302 and workspace 322, window 308 is only displayed once even though window 308 is in both workspaces. However, as illustrated by
In some implementations, when a window is associated with multiple simultaneously displayed workspaces having different workspace levels, the window can be displayed based on the workspace having the highest level. Thus, because workspace 302 has a higher level than workspace 322, window 308 will be displayed according to its relative z-position (e.g., filled 308) within workspace 302 (the higher level workspace) and window 308 will not be displayed according to its z-position (e.g., unfilled 308) within workspace 322. In this manner, every window associated with workspaces 302 and 322 can be displayed and the windows of workspace 302 can be given a higher priority than (e.g., displayed above) the windows of workspace 322 based on the higher workspace level assigned to workspace 302. It should be noted here that the windows within workspace 302 and workspace 322 are displayed according to the global z-order for windows. However, the workspace level assigned to each workspace can cause windows of a higher level workspace to be displayed above windows of a lower level workspace causing it to appear that the windows are displayed contrary to or differently than what is specified by the global z-order for windows, as illustrated by
In some implementations, workspaces can be dynamically overlaid upon other workspaces. For example, referring to
In some implementations, a user can provide input to cause workspace 302 to be displayed. For example, workspace 302 can be displayed as a temporary overlay above workspace 322. Workspace 302 can be overlaid upon workspace 322 by assigning workspace 302 a higher workspace level than the workspace level of workspace 322. When workspace 302 is overlaid upon workspace 322, the windows of the workspaces (e.g., windows 308-310) will be displayed according to the workspace levels assigned to the workspaces and the global z-order for windows, as described above with reference to
In some implementations, the user can provide input to remove the workspace overlay. For example, responsive to user input, workspace 302 can be hidden leaving only workspace 322 displayed. When workspace 302 is hidden, only windows 308 and 310 will remain displayed, for example.
In some implementations, a union set of windows can be determined for the displayed workspaces. For example, to avoid displaying window 710 twice, the union set of windows associated with workspace 706 (e.g., windows 710 and 712) and workspace 708 (e.g., window 710) can be determined. Thus, only one window 710 and one window 712 will be displayed in multiple display system 700. However, as described below, windows will only be displayed in workspaces with which the windows are associated. For example, window 710 can be displayed on display device 702 and 704 while window 712 will only be displayed on display device 702. Thus, window 712 will be clipped to (e.g., restricted to, cropped to) the display area associated with workspace 706.
In some implementations, a window that belongs to workspaces associated with two or more displays can be positioned based on which display corresponds to the main display. For example, window 710 is associated with workspace 706 and workspace 708. However, only one instance of window 710 can be displayed. System 700 may need to determine whether to display window 710 in workspace 706 or workspace 708. To make this determination, the system can determine which workspace is associated with the main display (e.g., display device 702) and display window 710 in that workspace. For example, the main display can be identified by the user in the system preferences of system 700. In some implementations, if workspaces 706 and 708 have different workspace levels, window 710 can be displayed in the workspace having the higher level.
In some implementations, windows can be displayed in multiple display system 700 based on the associations between windows and workspaces. A window can be displayed on a display device that is associated with a workspace with which the window is associated. For example, window 710 can be displayed on display device 702 and/or display device 704 because window 710 is associated with workspace 706 and workspace 708. If window 710 is positioned such that window portion 710B is moved off the edge of display device 702 (e.g., window portion 710A remains on display device 702), window portion 710B can be displayed on display device 704 because window 710 is associated with workspace 708. Thus, if a window is associated with workspaces on each display device, the window can be displayed on any display device.
In some implementations, windows can be displayed across multiple display devices only if the window belongs to the workspaces associated with each display device. For example, window 712 is only associated with workspace 706 (e.g., display device 702). Window 712 is not associated with workspace 708 (e.g., display device 704). Thus, when window 712 is positioned such that window portion 712B is moved off the edge of display device 702 (e.g., window portion 712A remains on display device 702), window portion 712B will be clipped to the display area associated with workspace 706. For example, window portion 712B will not be displayed on display device 704 because window 712 is not associated with workspace 708.
In some implementations, workspace-window associations are maintained for both visible and hidden workspaces. For example, by maintaining workspace-window associations various operations can be performed on workspaces and the windows of the workspaces as a group. For example, instead of performing operations on each individual window in a workspace, the workspace as a whole (including each window in the workspace) can be operated upon. Moreover, if an operation has been performed on a workspace, the operation can be applied to windows added to the workspace in the future. For example, if the opacity or transparency of the workspace has been adjusted, the opacity or transparency adjustment can be applied to all windows associated with the workspace. If windows are added to the workspace after the opacity adjustment has been made, the workspace adjustments can be applied to the added windows. If windows are removed from the workspace, the workspace adjustments will no longer be applied to the windows.
In some implementations, workspace transforms can be performed. For example, the workspace (including the windows associated with the workspace) can be moved, scaled, rotated, etc., as a whole thereby simplifying the transformation process. In some implementations, workspace transparency or opacity can be adjusted. For example, the transparency or opacity of a workspace (including the windows associated with the workspace) can be adjusted as a whole thereby simplifying the adjustment process.
In some implementations, each workspace can be associated with a workspace data structure that can store information that identifies the windows that belong to the workspace. This workspace data structure can maintain the workspace to windows association even when a workspace (and its associated windows) is not currently displayed. As each window is opened and associated with a workspace, the workspace data structure can store and maintain the workspace to windows associations.
At step 804, workspace levels can be determined. In some implementations, workspaces levels can be assigned by a user. For example, a user may have a favorite workspace and assign that workspace a high workspace level. In some implementations, workspace levels can be assigned dynamically. For example, if a user invokes a workspace overlay, the invoked workspace can be dynamically assigned a workspace level that is high enough to ensure that the invoked workspace will be displayed over any currently displayed workspaces. The workspace level can be maintained in the workspace data structure described above.
At step 806, a global z-order for windows can be determined. In some implementations, a data structure (e.g., array, list, etc.) can be maintained that represents the global z-order for windows across workspaces. This global z-order data structure can be referenced to determine how to display windows for each workspace. As windows are moved and z-positions adjusted, the global z-order data structure can be updated to represent the changed z-order for windows.
At step 808, windows can be displayed based on the global z-order for windows and the workspace levels. For example, when one or more workspaces are displayed, the windows associated with the workspaces can be displayed according to the global z-order for windows and the workspace levels, as described above with reference to
Each workspace object can be associated with one or more windows 916. For example, workspace object 902 can be associated with windows 908, 906 and 904. Workspace object 922 can be associated with windows 910 and 908. Workspace object 942 can be associated with windows 906 and 904. In some implementations, windows can be represented by window objects 904, 906, 908 and 910. Each window object can have attributes, such as an order attribute 918 and other attributes 920 (e.g., opacity, size, orientation, etc.). The order attributes can store a value that indicates the z-position of a window relative to other windows.
In some implementations, global z-order object 950 can maintain the relative order for all windows across all workspaces. For example, global z-order object 950 can be associated with a linked list, array, or other ordered collection that indicates the global z-order for all windows. In some implementations, visibility array 960 can be associated with a linked list, array, or other ordered collection that indicates the global z-order for all visible windows.
In some implementations, global z-order object 950 can maintain the global z order for windows. For example, if global z-order object 950 maintains the global z-order of windows using a linked list, the windows can be ordered first to last, top to bottom in the linked list. If global z-order object 950 maintains the global z-order for windows using an array, the position of the window within the array can indicate the relative z-position of the window.
In some implementations, when a user causes one or more workspaces to be displayed, the windows can be ordered based on the global z-order maintained by the global z-order object 950. For example, if a user selects workspace 902 for display, the order attribute 918 for all windows can be initially set to negative one (−1). Negative one can indicate that a window should not be displayed. Then, each window associated with workspace 902 (e.g., the workspace to be displayed) can be assigned an order based on the global z-order maintained by global z-order object 950. For example, workspace 902 includes windows 908, 906 and 904. Thus, windows 908, 906 and 904 can be assigned an order value corresponding to their relative positions within the global z-order object 950. For example, windows 908, 906 and 904 can be ordered 904, 906, 908. Window object 904 can have an order attribute value of one. Window object 906 can have an order attribute value of two. Window object 906 can have an order attribute value of three. Each order attribute value can correspond to the position of the window in the global z-order object 950.
Once order attribute values are assigned to each window object, the window objects can be assigned to the visibility array 960 based on the order attribute values. For example, each window having an order attribute value greater than negative one can be assigned to the visibility array. Since order attribute values greater than negative one will only be assigned to visible windows, only the visible windows will be included in visibility array object 960. Once the visible windows are added to visibility array object 960, the windows can be sorted according to their respective order attributes. The visibility array 960, including the ordered windows, can then be provided as input to the system's compositor (e.g., windows manager) for rendering onto the system's display.
In some implementations, multiple workspaces can be displayed simultaneously. For example, workspace 902 and 922 can be displayed simultaneously causing windows 904-910 to be displayed. If workspace 902 and workspace 922 are associated with the same workspace level (e.g., have the same level attribute value), then the ordering and displaying of windows can be performed as described above.
In some implementations, workspaces can be associated with different levels. For example, workspace 902 can be associated with a level (e.g., level zero) that is higher than workspace 922 (e.g., level one). To account for the different workspace levels, the order attribute of the windows associated with each workspace can be adjusted based on the workspace level. For example, if windows are ordered zero to N (highest to lowest), and workspaces are ordered zero to N (highest to lowest), then order attribute value for windows associated with workspace 902 can be the order values specified by the global z-order object 950 and the order attribute value for windows associated with workspace 922 can be adjusted such that the windows of workspace 922 are all below the windows associated with workspace 902. Once the order attribute values for each window is adjusted to account for workspace level, the visible windows can be assigned to visibility array object 960 and provided as input to the system's compositor for rendering on a display device.
Display device 1006 can be any known display technology, including but not limited to display devices using Liquid Crystal Display (LCD) or Light Emitting Diode (LED) technology. Processor(s) 1002 can use any known processor technology, including but are not limited to graphics processors and multi-core processors. Input device 1004 can be any known input device technology, including but not limited to a keyboard (including a virtual keyboard), mouse, track ball, and touch-sensitive pad or display. Bus 1012 can be any known internal or external bus technology, including but not limited to ISA, EISA, PCI, PCI Express, NuBus, USB, Serial ATA or FireWire. Computer-readable medium 1010 can be any medium that participates in providing instructions to processor(s) 1002 for execution, including without limitation, non-volatile storage media (e.g., optical disks, magnetic disks, flash drives, etc.) or volatile media (e.g., SDRAM, ROM, etc.).
Computer-readable medium 1010 can include various instructions 1014 for implementing an operating system (e.g., Mac OS®, Windows®, Linux) and/or application (e.g., software program). The operating system can be multi-user, multiprocessing, multitasking, multithreading, real-time and the like. The operating system performs basic tasks, including but not limited to: recognizing input from input device 1004; sending output to display device 1006; keeping track of files and directories on computer-readable medium 1010; controlling peripheral devices (e.g., disk drives, printers, etc.) which can be controlled directly or through an I/O controller; and managing traffic on bus 1012. Network communications instructions 1016 can establish and maintain network connections (e.g., software for implementing communication protocols, such as TCP/IP, HTTP, Ethernet, etc.).
A graphics processing system 1018 can include instructions that provide graphical user interface processing capabilities. For example, the graphics processing system 1018 can implement the processes described with reference to
The described features can be implemented advantageously in one or more computer programs that are executable on a programmable system including at least one programmable processor coupled to receive data and instructions from, and to transmit data and instructions to, a data storage system, at least one input device, and at least one output device. A computer program is a set of instructions that can be used, directly or indirectly, in a computer to perform a certain activity or bring about a certain result. A computer program can be written in any form of programming language (e.g., Objective-C, Java), including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment.
Suitable processors for the execution of a program of instructions include, by way of example, both general and special purpose microprocessors, and the sole processor or one of multiple processors or cores, of any kind of computer. Generally, a processor will receive instructions and data from a read-only memory or a random access memory or both. The essential elements of a computer are a processor for executing instructions and one or more memories for storing instructions and data. Generally, a computer will also include, or be operatively coupled to communicate with, one or more mass storage devices for storing data files; such devices include magnetic disks, such as internal hard disks and removable disks; magneto-optical disks; and optical disks. Storage devices suitable for tangibly embodying computer program instructions and data include all forms of non-volatile memory, including by way of example semiconductor memory devices, such as EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in, ASICs (application-specific integrated circuits).
To provide for interaction with a user, the features can be implemented on a computer having a display device such as a CRT (cathode ray tube) or LCD (liquid crystal display) monitor for displaying information to the user and a keyboard and a pointing device such as a mouse or a trackball by which the user can provide input to the computer.
The features can be implemented in a computer system that includes a back end component, such as a data server, or that includes a middleware component, such as an application server or an Internet server, or that includes a front-end component, such as a client computer having a graphical user interface or an Internet browser, or any combination of them. The components of the system can be connected by any form or medium of digital data communication such as a communication network. Examples of communication networks include, e.g., a LAN, a WAN, and the computers and networks forming the Internet.
The computer system can include clients and servers. A client and server are generally remote from each other and typically interact through a network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
One or more features or steps of the disclosed embodiments can be implemented using an API. An API can define on or more parameters that are passed between a calling application and other software code (e.g., an operating system, library routine, function) that provides a service, that provides data, or that performs an operation or a computation.
The API can be implemented as one or more calls in program code that send or receive one or more parameters through a parameter list or other structure based on a call convention defined in an API specification document. A parameter can be a constant, a key, a data structure, an object, an object class, a variable, a data type, a pointer, an array, a list, or another call. API calls and parameters can be implemented in any programming language. The programming language can define the vocabulary and calling convention that a programmer will employ to access functions supporting the API.
In some implementations, an API call can report to an application the capabilities of a device running the application, such as input capability, output capability, processing capability, power capability, communications capability, etc.
A number of implementations have been described. Nevertheless, it will be understood that various modifications may be made. For example, other steps may be provided, or steps may be eliminated, from the described flows, and other components may be added to, or removed from, the described systems. Accordingly, other implementations are within the scope of the following claims.
This application is a continuation of U.S. application Ser. No. 13/365,159, filed Feb. 2, 2012, and published on Aug. 8, 2013 as U.S. Publication No. 2013-0205239, the content of which is incorporated by reference herein in its entirety for all intended purposes.
Number | Name | Date | Kind |
---|---|---|---|
5121478 | Rao | Jun 1992 | A |
5483261 | Yasutake | Jan 1996 | A |
5488204 | Mead et al. | Jan 1996 | A |
5491784 | Douglas et al. | Feb 1996 | A |
5499334 | Staab | Mar 1996 | A |
5564002 | Brown | Oct 1996 | A |
5682550 | Brown et al. | Oct 1997 | A |
5825352 | Bisset et al. | Oct 1998 | A |
5835079 | Shieh | Nov 1998 | A |
5841435 | Dauerer et al. | Nov 1998 | A |
5880411 | Gillespie et al. | Mar 1999 | A |
5880773 | Suzuki | Mar 1999 | A |
6016145 | Horvitz et al. | Jan 2000 | A |
6188391 | Seely et al. | Feb 2001 | B1 |
6310610 | Beaton et al. | Oct 2001 | B1 |
6323846 | Westerman et al. | Nov 2001 | B1 |
6437803 | Panasyuk et al. | Aug 2002 | B1 |
6690387 | Zimmerman et al. | Feb 2004 | B2 |
7015894 | Morohoshi | Mar 2006 | B2 |
7159189 | Weingart et al. | Jan 2007 | B2 |
7184064 | Zimmerman et al. | Feb 2007 | B2 |
7663607 | Hotelling et al. | Feb 2010 | B2 |
7676761 | Oliver et al. | Mar 2010 | B2 |
8054319 | Lee et al. | Nov 2011 | B2 |
8479122 | Hotelling et al. | Jul 2013 | B2 |
20040056900 | Blume | Mar 2004 | A1 |
20050188329 | Cutler et al. | Aug 2005 | A1 |
20050223334 | Guido et al. | Oct 2005 | A1 |
20050273466 | Yoon | Dec 2005 | A1 |
20060197753 | Hotelling | Sep 2006 | A1 |
20060230156 | Shappir et al. | Oct 2006 | A1 |
20080028321 | Weksler et al. | Jan 2008 | A1 |
20110078624 | Missig | Mar 2011 | A1 |
20110087982 | McCann | Apr 2011 | A1 |
20110271226 | Janssen | Nov 2011 | A1 |
20120005269 | Janssen et al. | Jan 2012 | A1 |
20120242692 | Laubach | Sep 2012 | A1 |
Number | Date | Country |
---|---|---|
2000-163031 | Jun 2000 | JP |
2002-342033 | Nov 2002 | JP |
Entry |
---|
Final Office Action dated Jun. 14, 2013, for U.S. Appl. No. 13/365,159, filed Feb. 2, 2012, 11 pages. |
Final Office Action dated Aug. 28, 2015, for U.S. Appl. No. 13/365,159, filed Feb. 2, 2012, 11 pages. |
Final Office Action dated Sep. 22, 2015, for U.S. Appl. No. 13/365,159, filed Feb. 2, 2012, 14 pages. |
Lee, S.K. et al. (Apr. 1985). “A Multi-Touch Three Dimensional Touch-Sensitive Tablet,” Proceedings of CHI: ACM Conference on Human Factors in Computing Systems, pp. 21-25. |
Non-Final Office Action dated Oct. 22, 2012, for U.S. Appl. No. 13/365,159, filed Feb. 2, 2012, eight pages. |
Non-Final Office Action dated Jan. 15, 2015, for U.S. Appl. No. 13/365,159, filed Feb. 2, 2012, eight pages. |
Notice of Allowance dated Mar. 16, 2016, for U.S. Appl. No. 13/365,159, filed Feb. 2, 2012, five pages. |
Rubine, D.H. (Dec. 1991). “The Automatic Recognition of Gestures,” CMU-CS-91-202, Submitted in Partial Fulfillment of the Requirements of the Degree of Doctor of Philosophy in Computer Science at Carnegie Mellon University, 285 pages. |
Rubine, D.H. (May 1992). “Combining Gestures and Direct Manipulation,” CHI '92, pp. 659-660. |
Westerman, W. (Spring 1999). “Hand Tracking, Finger Identification, and Chordic Manipulation on a Multi-Touch Surface,” A Dissertation Submitted to the Faculty of the University of Delaware in Partial Fulfillment of the Requirements for the Degree of Doctor of Philosophy in Electrical Engineering, 364 pages. |
Number | Date | Country | |
---|---|---|---|
20170068426 A1 | Mar 2017 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13365159 | Feb 2012 | US |
Child | 15213282 | US |