The present invention relates generally to computing devices, and more particularly to user interaction with computing devices.
Contemporary computing devices allow users to input information in a number of ways, including via a keyboard, by or more types of pointing devices, and dedicated hardware buttons (typically on portable devices). With respect to buttons, some personal computers, such as tablet-based personal computers, have one or more buttons that allow the user to perform some tasks without taking out the pen or use a finger to interact with the digitizer built into the display screen. Buttons are particularly valuable when reading, because there is little interaction needed, and often no reason for the user to take out the pen. A typical use of these buttons is to scroll through a document, where two buttons would be employed to perform page up and page down operations, respectively, or read email, where buttons would allow navigation operations for an email program.
One desirable operation for a hardware button is to change the current application, otherwise known as task switching. However, typical tablet-based personal computers only provide for a single hardware button to jump between applications. This leads to an end-user experience that is less than desirable, and somewhat confusing, because most users typically want other behavior for task switching.
Briefly, the present invention provides a system and method that detects and differentiates different actuation methods entered via a single hardware button, and then takes different task switching actions based on the type of actuation method detected. For example, in one implementation, the button is actuated in different ways that map to different actions, such as double actuation (which is relatively fast, like double clicking a mouse), press-and-hold, single actuation, and latent double actuation (which is slower than double actuation, but fast enough to be differentiated from a single actuation).
The different task switching actions that can be performed may include toggling focus between the last two most-recently-accessed application programs, cycling to focus (in turn) each active program (and possible a Start menu), presenting a Start menu from which to launch programs, and/or presenting a list of active programs from which to select, e.g., by using navigation and Enter buttons. Other actions are feasible. In one implementation, the user may map actions to actuation methods.
The single hardware button may be dedicated to task switching, or may be a multi-purpose button that performs task switching when entered into a task switching mode via one actuation method, and performs one or more other functions when not in the task switching mode. The button actuation methods may thus be used to enter and exit a task switching mode, as needed, and the mode may be automatically exited as part of an action. Visible indications of the task-switching mode may be shown when active, as well as visible indications related to the timing used in button method differentiation.
Other advantages will become apparent from the following detailed description when taken in conjunction with the drawings, in which:
Exemplary Operating Environment
The invention is operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to, personal computers, server computers, hand-held or laptop devices, tablet devices, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
The invention may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, objects, components, data structures, and so forth, which perform particular tasks or implement particular abstract data types. The invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer storage media including memory storage devices.
With reference to
The computer 110 typically includes a variety of computer-readable media. Computer-readable media can be any available media that can be accessed by the computer 110 and includes both volatile and nonvolatile media, and removable and non-removable media. By way of example, and not limitation, computer-readable media may comprise computer storage media and communication media. Computer storage media includes volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer-readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can accessed by the computer 110. Communication media typically embodies computer-readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of the any of the above should also be included within the scope of computer-readable media.
The system memory 130 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 131 and random access memory (RAM) 132. A basic input/output system 133 (BIOS), containing the basic routines that help to transfer information between elements within computer 110, such as during start-up, is typically stored in ROM 131. RAM 132 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 120. By way of example, and not limitation,
The computer 110 may also include other removable/non-removable, volatile/nonvolatile computer storage media. By way of example only,
The drives and their associated computer storage media, discussed above and illustrated in
The computer 110 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 180. The remote computer 180 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 110, although only a memory storage device 181 has been illustrated in
When used in a LAN networking environment, the computer 110 is connected to the LAN 171 through a network interface or adapter 170. When used in a WAN networking environment, the computer 110 typically includes a modem 172 or other means for establishing communications over the WAN 173, such as the Internet. The modem 172, which may be internal or external, may be connected to the system bus 121 via the user input interface 160 or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 110, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation,
Program Task Switching Via a Single Hardware Button
The present invention is primarily directed to user input data entered via a hardware button, which results in various types of task switching actions. As will be understood, numerous ways to implement the present invention are feasible, and only some of the alternatives are described herein. For example, in one implementation, the button is actuated in different ways that map to different actions, such as double actuation (like double clicking a mouse), press-and-hold, single actuation, and latent double actuation (slower than double actuation, but fast enough to be differentiated from a single actuation). However, other ways to actuate buttons are feasible, including triple actuations, and patterns such as a single actuation followed by a press-and-hold action. Moreover, the different task switching actions that can be performed, such as toggling between the last two most-recently-accessed application programs in response to one type of button actuation, are only examples; an implementation in which the user configures the number of applications to switch among is straightforward to implement. As such, the present invention is not limited to any particular examples used herein, but rather may be used various ways that provide benefits and advantages in computing in general.
Turning to
Essentially, the button driver 230 knows the state of each button, that is, when any button is up or down. As described below with reference to
The task switching button may be dedicated to task switching, or may be a multi-purpose button used to perform one or more other actions as well. For example, when actuated in one way, a hardware button may toggle the display orientation of a tablet-based personal computer between landscape and portrait orientations. When actuated in another way, the same button may enter a mode in which the button is used for task switching, until deactivated.
By way of example,
Step 302 of
At step 306, the process waits for a button up event. When received, step 308 is executed, which evaluates the time that the button was held down against a press-and-hold time. Note that the press-and-hold time may be user configurable, or set by default to some reasonable time (e.g., on the order of one or two seconds) that clearly differentiates a user's press and hold intention versus another type of actuation. Further note that some visible indication may be given, possibly after some delay, to inform the user of the time remaining before the threshold press-and-hold time will be achieved.
If the press-and-hold time was not reached, step 308 branches to step 310 to perform the button's other function; note that such a function can actually further distinguish between other button actuation methods (other than press-and-hold) to make a decision on some further action, e.g., take one action on a double-actuation, and another action on a single actuation.
If the press-and-hold time was reached, step 308 enters the task switching mode, generally represented in
It should be noted that the task switching mode of
Step 402 represents waiting for a button down while in the task switching mode of operation; this is again represented as a loop, but may be an event-awakened process. Step 404 starts a timer on the button down event, and step 406 waits for a button up when the user releases the button.
Step 408 represents evaluating whether the time held was a press-and-hold action for a sufficient amount of time. The threshold press-and-hold time evaluated at step 408 need not be the same amount of time as the press-and-hold time of FIG. 3. If so, step 408 branches to step 411 to perform some action, shown as action 1.
In the situation where a non-dedicated button was used to enter the task switching mode, one such action would be to exit the task switching mode, as represented by the dashed lines below step 411. This would allow a user to press and hold to enter the task switching mode, use it as desired, and then press and hold to exit the task switching mode. The exit actuation method need not be the same as the enter actuation method, however, e.g., press and hold to enter, double actuate to exit.
Alternatively, such as with a dedicated task switching hardware button, some other action (described below) may be performed for a press and hold in the task switching mode. After the action, as indicated by the optional other dashed line, the process returns to step 402 to await further user actuation of the button. Note that the action may leverage other buttons that are available, e.g., up and down arrows, and the enter key. For example, one task-switching related action may provide a start menu, or present a group of programs from which to select one. Movement arrows and an Enter key button may be used to navigate and make the selection.
Returning to step 408, in the event that the press and hold time was not reached, step 408 branches to step 412 to start another timer, (which may be the same one as used in step 404). This time, the timer will be used to differentiate between other actuation methods, and continues until the user again presses and releases the button (step 414), or the timer reaches some maximum amount of time (step 416).
If there is a button up and down, step 414 branches to step 418, which evaluates the time to determine whether the user double-actuated the button relatively quickly (like a mouse double-click). If so, step 418 branches to step 422 to perform whatever task-switching action is mapped to a double-actuation, as described below. Otherwise, this is a slow double actuation, referred to as a latent double actuation, which branches to step 423 to perform a (typically) different task-switching action.
Returning to steps 414 and 416, if the user has not pressed the button a second time at step 414, the maximum time will be reached. This is essentially a single actuation, whereby step 424 is executed to perform a (typically) different task-switching action. Note that some visible indication may be given to the user to indicate when this time is to be reached, so that, for example, a user is not frustrated waiting for the single press (detected at steps 402 and 406) to result in an action. Indeed, if latent double actuation is not active, the maximum time at step 416 can be the double-actuation time, which is very short, and step 416 can go directly to step 422.
As can be seen from
A number of task switching actions are possible, including back-and-forth “toggling” between two applications, including changing back and forth between which program's window has focus, and predictable “cycling” through all running application programs, including bringing each program window to a foreground state for each program when it is that program's turn in the cycle, that is, interactively switching to the application. The user may also be presented with a list of active programs to explicitly choose the application program to switch to from a list. The user may also be presented with Start menu, including possibly inactive programs, from which an application program instance may be launched, (or switched to if already active and not more than one instance may be run at a time). The present invention provides such actions by mapping the button actuation method to a task switching action.
Another desirable action provides the user with access to the operating system's Start menu user interface, to allow new applications to be started. This may be done by mapping an action to the Start menu, and/or by treating the Start menu as one of the running application programs while in the task switching mode. Note that the Start menu may thus appear as one selectable option with which to interface when cycling through application programs.
As can be seen from
The user may map these methods to actions, or a default mapping may be provided. By way of example, one configuration may map a single button tap to toggling between two current applications, a double actuation to invoke the start menu, and a latent double actuation to cycles between all current application programs. Another configuration may map a single button tap to toggle between two application programs, and a press and hold to cycle between all current application programs. Note that although the example of
A user need not map an action to an actuation method. Thus, as described above, a user can elect to not use the latent double actuation method, and instead have a quick tap, a double actuation, and a press and hold action. Further, the methods described herein are only some examples; a user can use other methods such as a triple actuation. Similarly, the actions described herein are only some examples of task switching, and indeed, a user could do some other action, such as launch a particular program, from within the task switching mode.
In sum, when task switching is invoking via a single button, a mode is entered in which actions may occur. However, it should be understood that
As can be seen from the foregoing detailed description, there is provided a method and system that uses a single button to control task switching in a variety of ways. The button may be dedicated to task switching, or may be shared with different functionality. Distinctions are detected with the same button via different actuation methods.
While the invention is susceptible to various modifications and alternative constructions, certain illustrated embodiments thereof are shown in the drawings and have been described above in detail. It should be understood, however, that there is no intention to limit the invention to the specific form or forms disclosed, but on the contrary, the intention is to cover all modifications, alternative constructions, and equivalents falling within the spirit and scope of the invention.