1. Field
The present disclosure relates to computer user interfaces. More specifically, the present disclosure relates to space-constrained marking menus that can facilitate single-hand operation of a hand-held device.
2. Related Art
The recent developments in mobile computing technologies have stimulated integration of different communication and network applications into a single hand-held device. For example, smart phones and personal data assistants (PDAs) can provide voice-communication services, Internet connectivity, and multi-media applications in one palm-sized device. Meanwhile, advances in display and input technologies, such as liquid-crystal displays (LCDs) and touch screens, allow more precise and ergonomic touch-screen displays with higher resolution. However, the design of a small-size, intuitive, easy-to-use, easy-to-learn, and functionality-rich graphic user interface remains a challenge.
One embodiment of the present invention provides a user interface. The user interface includes a touch-screen display and a set of marking menus comprising at least one radial menu which can be displayed on the touch-screen display. A radial menu allows a user to select a menu item by performing a stroke on the touch-screen display in a direction corresponding to a slice of the radial menu associated with the menu item. In this embodiment, all the slices of a radial sub-menu are substantially at an angle of approximately 90° or less with respect to a previous stroke leading from a pervious radial menu, thereby allowing a series of consecutive strokes to end near the origin of the first stroke.
In a variation on this embodiment, the marking menus comprise at least one initial radial menu and at least one radial sub-menu. Furthermore, a radial sub-menu can be an edge radial menu placed along an edge of the touch-screen display, or a corner radial menu placed in a corner of the touch-screen display.
In a further variation, the edge radial menu comprises three slices. Two of the three slices are in opposite directions along the edge. The middle slice of the three slices corresponds to a stroke which is substantially perpendicular to the edge and points away from the edge.
In a further variation, the three slices do not have equal sizes.
In a further variation, a wedge angle of the middle slice is greater than those of the other two slices.
In a further variation, the corner radial menu comprises three slices. Two of the three slices on the outside are along the directions of the edges which form the corner, respectively. Furthermore, the middle slice of the three slices corresponds to a stroke which substantially points to a corner that is opposite to the corner associated with the corner radial menu.
In a further variation, the three slices do not have equal sizes.
In a further variation, a wedge angle the middle slice is larger than those of the other two slices.
In one variation on this embodiment, the marking menus comprise at least one of a radial menu that is deformed based on the shape of the touch-screen display and a radial menu wherein the slices therein are grouped in locations where the perimeter of the radial menu is visible.
In one variation on this embodiment, the marking menus are configured to allow a user to select a menu item by maintaining contact with a corresponding slice for a predetermined period.
In one variation on this embodiment, the marking menus are configured to allow a user to select a menu item by drawing a stroke either beyond the perimeter of a corresponding slice or by hitting an edge of the touch-screen display.
The following description is presented to enable any person skilled in the art to make and use the invention, and is provided in the context of a particular application and its requirements. Various modifications to the disclosed embodiments will be readily apparent to those skilled in the art, and the general principles defined herein may be applied to other embodiments and applications without departing from the spirit and scope of the present invention. Thus, the present invention is not limited to the embodiments shown, but is to be accorded the widest scope consistent with the claims.
The data structures and code described in this detailed description are typically stored on a computer-readable storage medium, which may be any device or medium that can store code and/or data for use by a computer system. This includes, but is not limited to, volatile memory, non-volatile memory, magnetic and optical storage devices such as disk drives, magnetic tape, CDs (compact discs), DVDs (digital versatile discs or digital video discs), or other media capable of storing computer readable media now known or later developed.
One challenge in designing an easy-to-use user interface for hand-held devices is the presentation of menu items. Many smart phones and PDAs still use the conventional “drop-down” or “pop-up” style menus. Although these menu styles benefit from user familiarity because of their resemblance to desktop menus, they are difficult to manage on a hand-held device. These conventional menu items can be fairly small due to the high resolution and limited size of the display. Consequently, a user often has to use a fine-pointed stylus to active a menu item on a touch-screen display. Such stylus operation requires both hands, one for holding the device and one for holding the stylus, which is often burdensome. Furthermore, in conventional menus with multiple hierarchies, a user may be required to traverse a number of menu hierarchies before reaching a desired menu item, which can be time-consuming and error-prone.
Embodiments of the present invention adopt a special type of menus, called “marking menus,” to facilitate operation of hand-held devices. Marking menus are typically implemented on touch screens and work as follows. During operation, a user presses down on the screen with an object, such as a stylus or finger, and waits for a certain period, typically less than a second (this operation is referred to as “press-and-wait”). A radial menu then appears. In one embodiment, the radial menu appears directly under the press-and-wait contact point on the screen. Note that a conventional radial menu typically has a circular shape, and the menu items are assigned to different “slices” or “wedges” of the circle.
After the radial menu appears, the user then highlights an item by making a stroke with the stylus or finger towards the desired item. If the selected item corresponds to a sub-menu, another radial menu can appear at the end of the stroke. The user can then select a menu item by making another stroke on the sub-menu. Note that the user can also make a series of selections in an “expert mode” by drawing consecutive, connected strokes. In expert mode, the user does not perform “press-and-wait” and the user interface typically does not display the radial menus. Hence, the user can quickly bypass several menu hierarchies if he/she can remember the positions of the appropriate menu items. Note that, in this disclosure, the process of selecting menu items based on displayed radial menus is referred to as the “novice mode.”
The user can draw a second stroke toward the lower-right slice of sub-menu 104 without lifting stylus 106. This way, the user can traverse two menu levels by drawing consecutive strokes, which form a “mark.” Note that the user can optionally draw the two strokes without the press-and-wait process. In this case, the user interface does not present radial menus 102 and 104, and can immediately receive the instruction to perform the copy operation using clipboard 3 after the user completes the two consecutive strokes.
Embodiments of the present invention provide a marking-menu based user interface that can be operated with a thumb. That is, a user can hold the hand-held device and navigate through the menus using the thumb of the holding hand. Marking menus are desirable for thumb-based interaction on touch-sensitive devices because they allow a relatively large number of options to be made available in a small space for selection using a thumb, which is an imprecise instrument. Marking menus do not require any dedicated display space because they are hidden until used. They can also be arranged hierarchically, which means that an arbitrary number of options can be made available.
Furthermore, marking menus can be accessed by both novices (with explicitly displayed radial menus) and experts (without explicitly displayed radial menus). Particularly, the expert-mode performance can be quite high, because accessing a known menu item becomes a gesture, which means that users can effect operations using very fast muscle memory rather than cognitive processing.
Although these features make marking menus more preferable than traditional drop-down or pop-up menus, conventional marking menus are still not ideal for small hand-held devices. The original marking menus were developed in the early 1990's for large-screen displays. One problem with conventional marking menus is that they do not adapt well to space-constrained devices. In particular, since strokes drawn on a series of radial menus can continue to radiate outwards, conventional marking menus do not have any theoretical bound to the amount of space they can require. In other words, several strokes in substantially the same direction can become a “runaway” mark on a small screen. For instance, in the example in
Embodiments of the present invention provide an improved marking-menu system that prevents such runaway strokes. The improved marking-menu configuration can ensure that two consecutive strokes made by a user are not in the same direction. Hence, the end point of a series of strokes can remain in the vicinity of the starting point. Furthermore, the present improved marking-menu system uses both full and partial radial menus, such as quarter-circle menus and half-circle menus. These partial radial menus allow a user to use edges and corners of a touch-screen display, which are often available on hand-held devices, to draw more precise strokes with a thumb.
Embodiments of the present invention provide space-constrained marking menus (SCMMs) which allow an arbitrary number of menu items to be presented in a constrained space, such as the touch-screen display of a hand-held device. As with previous marking menus, SCMMs can be operated in both novice and expert mode. In novice mode, the user presses and holds down on a menu's anchor point, which is typically the center of a radial menu. After a delay (typically on the order of 200-500 ms), a radial menu is displayed to allow the user to select an item from the menu. If one of the items is the anchor point for a submenu, the same pattern of selecting and holding can be repeated to display the sub-menu, and so forth. In expert mode, the user simply draws a series of strokes corresponding to a particular series of menu selections in order to invoke the desired operation.
In embodiments of the present invention, different levels of marking menus are configured in such a way that any given sub-stroke is ensured to “double back” towards the origin of the previous stroke. Note that a sub-stroke is a stroke that follows a previous stroke and is typically drawn on a sub-menu invoked by the previous stroke. In particular, the slices of a sub-menu are placed in unique locations so that all sub-strokes are at an angle of approximately 90° or less with respect to the corresponding previous strokes. This is important for mobile devices because they have limited screen sizes. To support multi-level menus, which are required for the complexity of modern applications, consecutive strokes are often arranged to maximize the number of subsequent stroke directions that can be taken.
The dashed arrows in
In one embodiment, the initial menu can be a full-circle radial menu. All the sub-menus are either half-circle or quarter-circle menus, which force the sub-strokes to substantially point back at the previous menu or sub-menu. Note that it is not required that a sub-menu slice points directly back at the previous menu. Runaway strokes can still be avoided so long as a sub-stroke does not point in the same direction as the previous stroke.
For example, the top slice of menu 210 leads to the half-circle sub-menu 204 which is placed along the top edge of the screen. Sub-menu 204 has three slices, and each slice corresponds to a stroke at an angle of 90° or less with respect to the stroke from menu 210 to sub-menu 204. Furthermore, the three slices of sub-menu 204 lead to sub-menus 202, 216, and 206, respectively. Therefore, any combination of strokes leading from menu 210 to sub-menu 204 and to further sub-menus is contained within the screen.
Note that in this example a quarter-circle or half-circle sub-menu has three slices, and the full-circle menu 210 has four slices. In general, other number of slices for any type of menu or sub-menu is also possible. For example, full-circle menu 210 can have six slices, three on the top and three on the bottom (or three on the left and three on the right). Each slice can point to a quarter-circle sub-menu (placed at a corner) or a half-circle sub-menu (placed against an edge). In the example in
In general, a quarter-circle menu is not required to be 90° wide, and a half-circle menu is not required to be 180° wide. A quarter-circle menu can be more generally referred to as a corner radial menu, as long as its two straight edges substantially match the shape of a corner of the screen. Similarly, a half-circle menu can be more generally referred to as an edge radial menu, as long as its straight edges substantially match an edge of the screen.
In addition, a quarter-circle or half-circle sub-menu can contain more than three slices. Although the example in
Furthermore, the transition relationship illustrated in
The aforementioned configuration can be especially useful for thumb based operations. The contact area of a thumb on the touch screen is generally much larger than that of a stylus tip. Hence, a marking menu designed for one-thumb operation ideally has slices that are sufficiently large for relatively error free operation. Hence, on a small screen of a hand-held device, a marking menu could easily take up almost the entire screen space. The present inventive configuration allows large-size sub-menus to be displayed in a limited space while containing the strokes within the screen area. The placement of sub-menus against corners and edges also allows the user to use the actual screen edges, which typically is a material above the screen and forms a “frame” around the screen, as guides when drawing strokes.
Different Number of Slices
Embodiments of the present invention can be implemented with different variations of marking menus.
In embodiments of the present invention, a radial menu, either full-circle or partial-circle, can have any number of slices.
Corner Menus with Unequal Slices
In the example above, a corner radial menu has three slices with equal wedge angles, i.e., 30° each. This angle configuration is equivalent to a full-circle with 12 slices, and hence may limit the menu's accuracy with thumb operations. It may be beneficial to use unequal wedge angles for the slices. In one embodiment, as illustrated by an exemplary corner radial menu 402 in
Different Ways to Select Menu Items
There are several ways that a user can select a menu after highlighting it. In one embodiment, the user interface allows the user to select an item by drawing the stroke beyond the edge of the corresponding slice of the radial menu. However, on small displays, the radial menu can be relatively large and can occupy almost all the screen space, which leaves little space beyond the radial menu's perimeter. The user interface can cope with this situation with several different approaches. In one embodiment, the user interface can only allow the marking menus to appear if there is enough room beyond the menu's perimeter. Optionally, the user interface can also warp or deform the radial menu, so that some space beyond the menu's perimeter remains visible, as illustrated by the exemplary menu 502 in
In a further embodiment, the user interface can use an extension of the aforementioned perimeter-crossing technique. If the perimeter of a portion of the menu falls outside the touch-screen display, then a menu item is considered selected if the user's contact point which falls within the corresponding slice hits an edge of the touch-screen display, even if the contact point is still within the slice.
In a further embodiment, the user interface can use a timeout-based selection technique. That is, a menu item becomes selected after the user maintains contact with the corresponding slice for longer than a timeout period. This way, the user can select a menu item without drawing a stroke beyond the perimeter of the slice.
As a result of this stroke, the user interface displays a corner sub-menu against the upper right corner of the screen. The user subsequently makes a downward sub-stroke to select the slice along the right edge of the screen (operation 606). The user interface then displays a third-level corner sub-menu against the lower right corner. The user makes the final sub-stroke along the lower screen edge to invoke the bottom slice of this corner sub-menu (operation 608).
Note that embodiments of the present invention can also be implemented with corner sub-menus placed substantially in the center of a screen.
As a result, the user interface displays a corner sub-menu which contains slices that are pointing toward the lower edge or the left edge. Note that this corner sub-menu is placed at the end of the first stroke. The user then makes a downward stroke, which invokes the right slice of the sub-menu (operation 706). The user interface then displays a third level corner sub-menu at the end of the second stroke. In response, the user makes the final sub-stroke toward left to invoke the bottom slice of this corner sub-menu (operation 708). Note that in the configuration in
Storage device 908 stores code for an operating system 916, as well as applications 920 and 922. Operating system 916 further includes a user-interface module 918 based on space-constrained marking menus as taught in the present disclosure. During operation, the operating system 916, which includes the space-constrained marking-menu-based user interface module 918, is loaded in memory 906. When processor 904 executes the corresponding code stored in memory 906, the spaced-constrained marking menus are displayed on touch-screen display 901.
The foregoing descriptions of embodiments of the present invention have been presented only for purposes of illustration and description. They are not intended to be exhaustive or to limit the present invention to the forms disclosed. Accordingly, many modifications and variations will be apparent to practitioners skilled in the art. Additionally, the above disclosure is not intended to limit the present invention. The scope of the present invention is defined by the appended claims.