EP1376325A2 - Method and system for presenting menu commands for selection - Google Patents

Method and system for presenting menu commands for selection Download PDF

Info

Publication number
EP1376325A2
EP1376325A2 EP03010201A EP03010201A EP1376325A2 EP 1376325 A2 EP1376325 A2 EP 1376325A2 EP 03010201 A EP03010201 A EP 03010201A EP 03010201 A EP03010201 A EP 03010201A EP 1376325 A2 EP1376325 A2 EP 1376325A2
Authority
EP
European Patent Office
Prior art keywords
command
commands
menu
grid
actuation
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Ceased
Application number
EP03010201A
Other languages
German (de)
French (fr)
Other versions
EP1376325A3 (en
Inventor
Chee H. Chew
Justin M. Maguire
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Microsoft Technology Licensing LLC
Original Assignee
Microsoft Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Microsoft Corp filed Critical Microsoft Corp
Publication of EP1376325A2 publication Critical patent/EP1376325A2/en
Publication of EP1376325A3 publication Critical patent/EP1376325A3/en
Ceased legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0481Interaction techniques based on graphical user interfaces [GUI] based on specific properties of the displayed interaction object or a metaphor-based environment, e.g. interaction with desktop elements like windows or icons, or assisted by a cursor's changing behaviour or appearance
    • G06F3/0482Interaction with lists of selectable items, e.g. menus
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M1/00Substation equipment, e.g. for use by subscribers
    • H04M1/72Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
    • H04M1/724User interfaces specially adapted for cordless or mobile telephones
    • H04M1/72469User interfaces specially adapted for cordless or mobile telephones for operating the device by selecting functions from two or more displayed items, e.g. menus or icons

Definitions

  • the present invention relates generally to computer devices, and more particularly computer devices having displayed command menus.
  • the stylus mode is generally superior to keyboard modes for direct manipulation of displayed items, including traditional menu selection of commands and the like, the stylus mode is relatively slower than the keyboard mode for text input. This is true even with limited keyboards, such as those referred to as thumb keyboards.
  • some devices provide both stylus and keyboard input mechanisms, whereby that a user can use the stylus for command selection and the key buttons for text input.
  • switching between using the keyboard and using the stylus is cumbersome, awkward and slow.
  • the stylus mode is not even possible on devices which are not touch-sensitive (e.g., most mobile telephones).
  • the present invention provides a system and method on a computing device that significantly reduces the average time required to locate and select a desired command of the device. This is accomplished by providing a two-dimensional menu (grid) of commands, in combination with improved selection techniques including simultaneous hardware button usage, referred to as hardware button chording. Pressing and holding a menu invoke button (or simply, menu button) causes display of the command menu, with the center, default item initially selected.
  • a menu invoke button or simply, menu button
  • a directional control e.g., a directional pad, or dpad, arrow keys, or rocker
  • the menu invoke button is released, the selected item is invoked.
  • a two-dimensional menu such as a 3 x 3 grid of commands is displayed (or if already displayed, made active) by the user pressing and holding the menu key. Because the default command (e.g., the most commonly needed or most frequently used) is initially the highlighted command, the user can select the default command with a single menu button push and release. In a device with only horizontal and vertical directional buttons, that is, a four-way control, other commands (referred to as secondary commands) that are vertically or horizontally next to the default command can be selected by pressing only one directional control button. When selected, the menu button (and optionally the direction button) is then released to invoke the currently selected command.
  • One command may be a cancel command so that the user can exit the menu without invoking a device function.
  • tertiary commands may be positioned diagonally with respect to the centered default command. To be invoked, such tertiary commands require only two directional control button pushes, along with release of the menu button. Note that if the direction control were an eight-way (including diagonal) control, such diagonally placed commands would also be secondary commands, not tertiary commands.
  • the grid need not be symmetrical, and may be enlarged to accommodate larger menu sets, such as a 3 x 4, 4 x 4, 4 x 5 or a 5 x 5 grid. This may be accomplished by displaying the entire grid at once, or by scrolling only a subset menu of a larger grid into the display area.
  • a "menu lock” feature may be provided. For example, when the menu invoke command is depressed and held for a sufficient time without pressing any directional key, the menu becomes locked such that the release of the menu invoke command does not invoke the highlighted command, but rather acts to confirm entry into the menu lock mode (or has no further effect). Once the command menu is locked, which may be visually confirmed, the user may use the directional control to select a different item, and then press the menu invoke command again to actually perform the invocation.
  • the menu lock mechanism facilitates single-handed command selection by allowing the menu button to be released without causing an action.
  • FIGURE 1 illustrates an example of a suitable operating environment 120 in which the invention may be implemented, particularly for decoding image and/or video data.
  • the operating environment 120 is only one example of a suitable operating environment and is not intended to suggest any limitation as to the scope of use or functionality of the invention.
  • Other 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, multiprocessor systems, microprocessor-based systems, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
  • program modules include routines, programs, objects, components, data structures and so forth that perform particular tasks or implement particular abstract data types.
  • functionality of the program modules may be combined or distributed as desired in various embodiments.
  • Computer-readable media can be any available media that can be accessed by the computing device 120.
  • 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 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 computing device 120.
  • 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.
  • 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.
  • 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.
  • FIG. 1 shows functional components of one such handheld computing device 120, including a processor 122, a memory 124, a display 126, and a keyboard 128 (which may be a physical or virtual keyboard).
  • the memory 124 generally includes both volatile memory (e.g., RAM) and non-volatile memory (e.g., ROM, PCMCIA cards, and so forth).
  • An operating system 130 is resident in the memory 124 and executes on the processor 122, such as the Windows® CE operating system from Microsoft® Corporation, or another operating system.
  • One or more application programs 132 are loaded into memory 124 and run on the operating system 130. Examples of applications include email programs, scheduling programs, PIM (personal information management) programs, word processing programs, spreadsheet programs, Internet browser programs, and so forth.
  • the handheld personal computer 120 may also include a notification manager 134 loaded in the memory 124, which executes on the processor 122. The notification manager 134 handles notification requests, e.g., from the application programs 132.
  • the handheld personal computer 120 has a power supply 136, which is implemented as one or more batteries.
  • the power supply 136 may further include an external power source that overrides or recharges the built-in batteries, such as an AC adapter or a powered docking cradle.
  • the exemplary handheld personal computer 120 represented in FIG. 1 is shown with three types of external notification mechanisms: one or more light emitting diodes (LEDs) 140 and an audio generator 144. These devices may be directly coupled to the power supply 136 so that when activated, they remain on for a duration dictated by a notification mechanism even though the handheld personal computer processor 122 and other components might shut down to conserve battery power.
  • the LED 140 preferably remains on indefinitely until the user takes action.
  • contemporary versions of the audio generator 144 use too much power for today's handheld personal computer batteries, and so it is configured to turn off when the rest of the system does or at some finite duration after activation.
  • FIG. 2 is a representation of a conventional, prior art mobile telephone 200 having a display screen 202.
  • a user uses up and down buttons 203 and 205 to scroll vertically and highlight a selection (e.g., 209) of a plurality of displayed selections 207-209. Once highlighted, the user presses an OK button 213 or the like to invoke the selection, which typically takes the user to a similarly arranged sub-menu.
  • OK button 213 or the like to invoke the selection, which typically takes the user to a similarly arranged sub-menu.
  • commands such as Messages, or Setup.
  • sub-menus of commands such as to select a name from a user's telephone directory, there may be hundreds of such entries.
  • FIG. 3 is a representation of a mobile telephone 300, with a display 302 arranged to have commands invoked in accordance with the present invention.
  • FIG. 4 is a representation of a handheld computing device 400 (such as the device 120 described with reference to FIG. 1) with a display 402 similarly arranged. Both devices 300 and 400 include a menu button (or equivalent, labeled 304 and 404, respectively. Note that any hardware keyboard key in a keyboard mode would equivalently suffice as the menu button.
  • the mobile telephone 300 is constructed with a four-way control 306 (which may be a single four-way rocker switch or four separate buttons, corresponding to up, down, left and right), whereas the computing device 400 is constructed with an eight-way control 406, adding diagonal movement commands.
  • the different controls and devices represented herein are for purposes of varying the examples, and the present invention may be implemented with virtually any control that allows movement in two-dimensions, and with any computing device. Further, in addition to being controlled by button actuation, the devices may or may not also be touch sensitive.
  • the commands on the display 302 are presented to the user in the form of a two-dimensional grid 310, which the user activates and views by pressing and holding the menu button 304.
  • the commands are similarly presented to the user in the form of a two-dimensional grid 410, activated and viewed by pressing and holding the menu button 404.
  • a mechanism arranged to display the menu grid 310 (or 410) such as by default, but not have the menu grid 310 (or 410) be active until the menu button 304 (or 404) is pressed and held.
  • the inactive grid may be shown in a different color, grayed-out, and/or with no highlighted selection.
  • a default command (labeled Default Command) is centered in the corresponding menu grid 310 or 410.
  • the default command may be placed elsewhere, such as near the center.
  • the default command may be a command that the menu designer deemed to be the one most likely to be needed, although it is feasible to have the default command be dynamic, with a most frequently used algorithm or the like controlling what is displayed as the default, or have the default command be user-configurable.
  • the commands that are more likely to be used should be arranged so as to be selected with the fewest number of button pushes possible.
  • command can be essentially any menu item that can be displayed, and are not limited to commands that when invoked perform some unique and/or definite function.
  • menu items may be duplicate commands or blanks, such as when there are not enough distinct commands in a given menu to complete a grid.
  • Menu commands can also correspond to one or more letters or numbers, macros, and so forth.
  • releasing of the menu button invokes the selected command.
  • This facilitates rapid selection of a command, with as little as one push-and-release of the menu button required to invoke the default command. Indeed, the menu need not even be displayed if the menu button is pressed and released fast enough.
  • it is essentially equivalent (although somewhat less convenient) to have more than one hardware menu button, e.g., with one button pressed as the first actuation that activates / displays the menu and another button pressed as the second actuation that invokes the current selection.
  • a "menu button,” “menu button mechanism”or the like may be any hardware mechanism that enables distinct first and second actuations.
  • a user uses the four-way control 306 to move the pending selection.
  • This chording technique changes the highlighting (or other indication) of the selection. If more commands are available than can be displayed, such commands may be scrolled into the display area when needed, e.g., when the user is requesting further directional movement to select a command that exists logically beyond the edge of the display.
  • the menu button (and possibly the directional button) is released to make the selection, whereby the device invokes the command as appropriate, e.g., renders a new sub-menu for the selection, dials a telephone number, and so on.
  • the commands displayed in the grid 310 of FIG. 3 include some commands that require only one directional button (Command A, Cancel, Command B and Command C, corresponding to up, down, left or right, respectively) to be selected. Such commands are referred to as secondary commands, with the default command being considered the primary command. Because of the four-way switch, other commands, referred to as tertiary commands, require that two directional buttons be serially pressed to select them. For example, Command D, Command E, Command F and Command G are respectively selected by pressing up/left, down/left, up/right and down/right, in either order.
  • the numeric keys 331 (1-9, *, 0 and #) are also in a two-dimensional layout, and thus spatially and intuitively relate to the displayed grid 310, at least in part. Accordingly, commands may be selected via the directional pad 306 and menu button 304, and also via the numeric keys 331.
  • the various commands of the grid 310 can each display a number (not shown) identifying a corresponding keypad key, e.g., Command D can indicate that it may be also be invoked by pressing the 1 key on the keypad 331, Command A by the 2 key, and so on up to Command F corresponding to the 9 key.
  • one of the selections is a Cancel command.
  • the Cancel command enables the menu button 304 to be released without invoking a command.
  • each menu grid (and sub-menu) will include at least one such Cancel command. More than one may be provided, such as when scrolling, so that a Cancel command always appears regardless of how scrolled.
  • another hardware button such as the "End” button 318 (or at least one of the "Other” buttons such as the button 418 in FIG. 4) may operate to cancel command selection via the grid, whether or not a Cancel command is also provided in the grid.
  • FIGS. 5A-5E describe one way in which scrolling may be accomplished.
  • a 5 x 5 grid of commands 510 is available, however the display only shows a 3 x 3 subset of these commands.
  • the displayed 3 x 3 subset, labeled 540 A -540 E respectively is represented by a solid box surrounding commands drawn with solid lines, while the available, but not displayed commands are shown surrounded by dashed lines.
  • a dashed box surrounds the entire 5 x 5 grid, and the currently selected command is highlighted, indicated with slanted lines, and shadowed. Note that the in FIGS.
  • the solid box representing what is currently being displayed generally appears to move around, but does not, as in actuality what is presently displayed is logically moved into the corresponding display area. Further, note that although not necessary to the invention, the entire 5 x 5 grid of FIGS. 5A-5E is arranged such that at least one Cancel command selection is displayed to the user regardless of how scrolled.
  • FIG. 5A shows the initially displayed menu 540 A which is a subset of the grid 510, with the default command initially and automatically selected and centered in the entire grid 510, in keeping with one preferred implementation described above. If the menu button is released at this time, the default command would be selected.
  • FIG. 5B shows the user having changed the pending selection to Command C, accomplished via a right directional control button. Note that as represented in FIG. 5B, scrolling preferably does not occur, since Command C was visible, and thus the commands displayed in the subset 540 A and 540 B are the same, but with the pending command changed.
  • FIG. 5C shows the displayed subset menu 540 C of the complete grid 510 being logically scrolled into the display area, and the selection of Command S, which occurs when the user again actuates the right directional button. Scrolling right again at this time may be prevented, or it may result in the user circularly moving the selection to Command K, or moving / scrolling up or down. For purposes of simplicity, scrolling while at the logical scroll limit will be described as being prevented by the system.
  • FIGS. 5D and 5E show the results of two down directional buttons having been pressed following the state shown in FIG. 5C, pressed once to result in the state represented in FIG. 5D, and pressed once more to result in the state represented in FIG. 5E.
  • FIG. 5D does not scroll since Command R was already displayed, while FIG. 5E scrolls to display a new subset 540 E in order to enable the requested selection of Command Q.
  • slider mechanisms FIG. 6A
  • FIG. 6B may be employed to provide a visual indication to the user of where the user has scrolled to a subset 640 within the overall grid, and/or to assist with navigation therein.
  • the mechanisms 601, 602 and 604 represented in FIGS. 6A and 6B may be used to indicate that the user has scrolled to the lower right corner of the overall grid, as in the state represented in FIG. 5E.
  • FIG. 4 represents an example computing device 400 that is physically different from the mobile telephone device 300 of FIG. 3, yet operates similarly with respect to menu selection.
  • the eight-way directional control button 406 it is possible to move diagonally to select any one of the commands, labeled Command D, Command E, Command F or Command G.
  • such diagonally-positioned commands are secondary commands, not tertiary commands, although it is also possible to select such a command using a combination two-step horizontal and vertical button press instead of a one-step diagonal press.
  • secondary means a minimum of one step away from the current position, while tertiary means two steps away, regardless of whether the user actually moves the selection in this direct manner.
  • FIG. 7 shows a grid 710, which generally corresponds to the grid 410 of FIG. 4 after a single diagonal (up and right) button press has changed the pending command selection from the Default Command to Command G.
  • any grid can have duplicate commands, such as the multiple Cancel commands represented in FIGS. 5A-5E.
  • a grid may also have one or more commands omitted therefrom, such as by showing a blank or grayed-out space instead of a command and preventing selection of that space, or showing a command as "No operation" or the like can be selected, but when invoked, has no effect.
  • Command D is shown with a dashed box around it to indicate that the command may or may not be present, or if present, may have a different appearance, wherein the user may be prevented from selecting Command D or Command D may have no associated function or a special function.
  • one such special function may correspond to a lock mode command that enters the device into a lock mode state, described below.
  • FIG. 8 shows one way in which the hardware buttons in combination with a two-dimensional grid of menu commands may be operated to facilitate user command selection. Note that this is only an example of a suitable process and components for purposes of describing the operation and structure, and there are many equivalent ways and components to accomplish the general logic. Further note that the components in FIG. 11 may be the same as like components represented in FIG. 3 or FIG. 4, or may be components on a different device.
  • Step 800 of FIG. 8 begins when the menu button 1104 of FIG. 11 is pressed, and represents initializing the display 1102 and initializing the currently pending command to the Default Command.
  • Step 802 represents updating (or if already properly displayed, activating) the display 1102, although as described above, this may be temporarily deferred to avoid rendering the display 1102 if the user very quickly presses and releases the hardware menu button 1104.
  • Step 804 tests whether the menu button 1104 of FIG. 11 has been released. If so, the process would end, and the currently selected command, which at this time would be the Default Command, would be invoked. Note that this might result in the default command being executed, and/or invoking a sub-menu (which may similarly comprise a command grid) that is displayed for further sub-selection in a similar manner, or the performance of other types of functions.
  • a sub-menu which may similarly comprise a command grid
  • step 806 represents testing whether one of the directional buttons 1106 has been pressed. If not, step 806 loops back until either the menu button 1104 is released or a directional button is pressed. Note that steps 804 and 806 need not actually be in such a loop, as such a process 1100 often will be event driven and thus block waiting for the appropriate button event, whereby the device and/or process can perform other activities while waiting. Further note that other hardware buttons may be pressed that may impact the process 1120, e.g., a hardware cancel button may exist so that the user can exit via hardware instead of (or in addition to) requiring a menu selection to cancel.
  • step 808 evaluates whether the requested command to-be-selected is currently shown on the display.
  • data structures 1130 such as a data array that matches the grid and/or other suitable data structure or structures can track which subset (if any) of the available commands are being displayed and which are not. The same array or one or more other variables can track which command is currently selected.
  • step 808 branches to step 814 to change the current (pending) command to the newly selected one, e.g., updating the array and/or other variables in the data structure 1130, and returning to step 802 to update the display 1102 to reflect the new selection. Otherwise, scrolling may be possible, as evaluated by step 810. If not, e.g., a scroll limit has already been reached (the user has scrolled to the end of the total grid and circular or other scrolling is not allowed), step 810 returns to step 804, essentially ignoring the request. Note that a beep, visual indication or other alarm may be first provided to inform the user of the scroll limit having been reached.
  • step 810 branches to step 812 to scroll the requested command into the displayed (subset) command menu. Again, this may be accomplished by adjusting the values in the array or the like, and using the array values to map to what is displayed. Step 812 continues to step 814 to change the current pending command, as described above, and returns to step 802 to update the display 1104 to reflect the scrolling and the new selection.
  • FIGS. 9 and 10 provide an alternative enhancement that may be used, for example, to facilitate one-handed operation of the device.
  • the device instead of the release of the menu button 1104 acting as its secondary actuation, the device can be placed in a lock (or lock down) mode 1122 of operation, in which the menu button 1104 may be released and not secondarily actuated until pressed again to invoke the currently pending selection.
  • the menu button 1104 is initially and then secondarily actuated, but the second actuation may be accomplished in different ways (e.g., released in a regular mode, or pressed a second time if in the lock mode).
  • FIG. 9 describes one way in which the lock mode 1122 can be incorporated into the regular mode, e.g., as described above with reference to FIG. 8.
  • the process 1120 when initially actuated, the process 1120 operates generally the same to initialize the array and/or variables at step 900, and further starts a lock mode timer 1132.
  • the menu button 1104 is held for some substantial, predetermined or user configurable time period (e.g., two seconds), and then released without a directional button having been pressed during that period, the lock mode 1122 is entered.
  • some substantial, predetermined or user configurable time period e.g., two seconds
  • the lock mode 1122 is entered.
  • two things are required to achieve entering of the lock mode 1122, namely holding the menu button 1104 for the required duration, and then releasing it before any directional button 1106 is pressed.
  • the lock mode 1122 can be entered, regardless of whether it is released before or after the pressing of a directional control button.
  • Step 902 updates the display 1102 of FIG. 11 as generally described above, and step 904 tests for the release of the menu button 1104. If released before lock mode 1122 was entered, the current command is invoked, e.g., as in the regular mode. Otherwise a directional button is tested for at step 906. However, instead of returning when no directional button is pressed, another test regarding whether the lock mode time has been achieved by the lock mode timer 1132 occurs at step 908. Note that the lock mode duration should be far longer than the device takes to executed steps 900-906, whereby there is no way to reach the lock mode time before the user has had at least a reasonable chance to release the menu button 1104 and make a selection in the previously described manner and/or press a directional button. In this manner, the process operates as before, unless and until the lock mode 1122 is entered.
  • steps 910-916 operate in the same general way as the similar steps described above with reference to FIG. 8, and thus these steps will not be described again for purposes of brevity.
  • step 1000 of FIG. 10 a test is performed to determine if the menu button 1104 has been released.
  • the menu button 1104 needs to be released before any of the directional buttons 1106 are pressed, regardless of how long the menu button 1104 was held down before the directional button was pressed.
  • lock mode command that is easy to select, even by one-handed operation, e.g., a menu button press and release followed rapidly by a left directional arrow may be considered a switch to the lock mode (instead of immediately treating the release as selection of the default command).
  • a menu button press and release followed rapidly by a left directional arrow may be considered a switch to the lock mode (instead of immediately treating the release as selection of the default command).
  • the user would release the menu button but then not press the directional button right after the release.
  • step 1000 branches to step 1002 to determine whether the user has pressed one of the directional buttons 1106. If so, the lock mode 1110 is not successfully entered, and the process returns to FIG. 9, step 910. If at step 1002 a directional button has not been pressed, the process 1120 loops or otherwise waits for one of these two button actions to occur.
  • step 908 the lock mode time has been achieved at step 908, but the lock mode was not entered because a directional button 1106 was pressed before release of the menu button 1104, in one implementation the process will not again attempt to enter the lock mode, as indicated by the dashed line from step 906 back to step 904.
  • a flag or the like can track this time-achieved, but lock-mode-not-entered state.
  • the lock mode could be re-entered by continuing to hold the menu button 1104 for a sufficient time without selecting a directional button.
  • step 1000 either the menu button 1104 is released at step 1000, or a directional button 1106 is pressed at step 1002. If first released, the lock mode 1122 is entered, and step 1000 branches to step 1004 to update the display 1102 if desired, such as to indicate to the user the state change into the lock mode 1122. Note that an audible sound may also be output to indicate initial entry into the lock mode, and that step 1000 may bypass step 1004 if no such visible indication is made.
  • steps 1006-1018 operate in the same general way as the similar steps described above with reference to FIG. 8, but with one difference, namely that the secondary actuation that is required to invoke the currently selected command is now a button press at step 1006, not a button release.
  • selection and scrolling may be the same as in the regular mode of operation, the display 1102 will be updated as appropriate, and so on, however in this mode, pressing (not releasing) of the (already-released) menu button 1104 is detected as the second actuation that invokes the selected command.
  • a full press-and-release of the menu button 1104 may instead be required to actuate, and indeed, a second press and hold for a sufficient time may even be used for another purpose, such as to exit the lock mode and return to regular non-locked operation.
  • a method and system that facilitates rapid hardware button selection of a large number of menu commands. For example, with an eight way directional control, any one of nine commands can be selected with at most one directional control button press, and any one of twenty-five commands can be selected with at most two directional control button presses.
  • the grid provides similar exponential benefits with a four-way control.
  • the method and system are flexible, may be varied and/or otherwise customized to meet a variety of scenarios, are intuitive to use and provide numerous advantages over prior art mechanisms.

Abstract

A system and method on a computing device that significantly reduces the average time required to locate and select a desired command of the device. A two-dimensional menu (grid) of commands is provided, in combination with improved selection techniques including simultaneous hardware button usage. Pressing and holding a menu button causes display of the command menu, with the center, default item initially selected. A directional control button may be used to change the selection, and scroll the display if more commands are available than presently displayed. When the menu invoke button is released, the currently selected item is invoked, thereby rapidly enabling selection and invocation of a command. The method and system may be enhanced with a menu locking feature to facilitate single-handed command selection.

Description

    FIELD OF THE INVENTION
  • The present invention relates generally to computer devices, and more particularly computer devices having displayed command menus.
  • BACKGROUND OF THE INVENTION
  • Designers of contemporary mobile computing devices, including pocket-sized personal computers, mobile telephones, pagers and the like, are challenged with trying to build devices of ever-decreasing size with ever-increasing features, all while providing a user interface that is sufficiently user-friendly to facilitate input. Alternative modes exist for obtaining user input, including a keyboard mode, wherein input is performed via keys, and a stylus mode, where the device is controlled by a stylus and a touch-sensitive display screen / input mechanism.
  • Each of these modes has advantages and disadvantages. For example, while the stylus mode is generally superior to keyboard modes for direct manipulation of displayed items, including traditional menu selection of commands and the like, the stylus mode is relatively slower than the keyboard mode for text input. This is true even with limited keyboards, such as those referred to as thumb keyboards.
  • As a result, some devices provide both stylus and keyboard input mechanisms, whereby that a user can use the stylus for command selection and the key buttons for text input. However, switching between using the keyboard and using the stylus is cumbersome, awkward and slow. Moreover, the stylus mode is not even possible on devices which are not touch-sensitive (e.g., most mobile telephones).
  • To contend with these problems, designers of devices that do not have touch-sensitive displays, such as many mobile telephones, and/or otherwise want to allow users to select commands via a keyboard mode, essentially simulate the stylus mode with keys. Selection is typically accomplished via up and down cursor buttons (and in some devices a scrolling wheel) for scrolling through a menu of vertically-arranged commands, starting at the top, along with a select button that the user actuates when the desired command is highlighted. While functional, on average this is relatively slow for a user to find and enter a command, and often results in the user scrolling past (overshooting) or stopping short of (undershooting) the desired menu item. What is needed is an improved way of facilitating the entry of commands via buttons / hardware keys.
  • SUMMARY OF THE INVENTION
  • Briefly, the present invention provides a system and method on a computing device that significantly reduces the average time required to locate and select a desired command of the device. This is accomplished by providing a two-dimensional menu (grid) of commands, in combination with improved selection techniques including simultaneous hardware button usage, referred to as hardware button chording. Pressing and holding a menu invoke button (or simply, menu button) causes display of the command menu, with the center, default item initially selected.
  • While the menu invoke button is depressed, a directional control (e.g., a directional pad, or dpad, arrow keys, or rocker) may be used to change the highlighted, pending selection. When the menu invoke button is released, the selected item is invoked. The combination of hardware button chording and the two-dimensional arrangement and selection of commands facilitates the rapid and simple menu selection of a large menu command set.
  • In one alternative embodiment, a two-dimensional menu such as a 3 x 3 grid of commands is displayed (or if already displayed, made active) by the user pressing and holding the menu key. Because the default command (e.g., the most commonly needed or most frequently used) is initially the highlighted command, the user can select the default command with a single menu button push and release. In a device with only horizontal and vertical directional buttons, that is, a four-way control, other commands (referred to as secondary commands) that are vertically or horizontally next to the default command can be selected by pressing only one directional control button. When selected, the menu button (and optionally the direction button) is then released to invoke the currently selected command. One command may be a cancel command so that the user can exit the menu without invoking a device function.
  • In a device having only horizontal and vertical directional buttons, tertiary commands may be positioned diagonally with respect to the centered default command. To be invoked, such tertiary commands require only two directional control button pushes, along with release of the menu button. Note that if the direction control were an eight-way (including diagonal) control, such diagonally placed commands would also be secondary commands, not tertiary commands.
  • The grid need not be symmetrical, and may be enlarged to accommodate larger menu sets, such as a 3 x 4, 4 x 4, 4 x 5 or a 5 x 5 grid. This may be accomplished by displaying the entire grid at once, or by scrolling only a subset menu of a larger grid into the display area.
  • In another alternative embodiment, a "menu lock" feature may be provided. For example, when the menu invoke command is depressed and held for a sufficient time without pressing any directional key, the menu becomes locked such that the release of the menu invoke command does not invoke the highlighted command, but rather acts to confirm entry into the menu lock mode (or has no further effect). Once the command menu is locked, which may be visually confirmed, the user may use the directional control to select a different item, and then press the menu invoke command again to actually perform the invocation. As can be appreciated, the menu lock mechanism facilitates single-handed command selection by allowing the menu button to be released without causing an action.
  • Other advantages will become apparent from the following detailed description when taken in conjunction with the drawings, in which:
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIGURE 1 is a block diagram representing one exemplary computing device into which the present invention may be incorporated;
  • FIG. 2 is a simplified representation of a mobile telephone constructed in accordance with the prior art;
  • FIG. 3 is a simplified representation of a mobile telephone constructed in accordance with an aspect of the present invention;
  • FIG. 4 is a simplified representation of a pocket-sized or handheld computing device constructed in accordance with an aspect of the present invention;
  • FIGS. 5A-5E are representations of an overall 5 x 5 grid of available commands representing scrolling to display a 3 x 3 subset menu of the commands arranged in accordance with an aspect of the present invention;
  • FIGS. 6A and 6B are representations of various mechanisms that can provide a visual indication to a user of where within an overall grid the user has scrolled to display a subset of commands, and/or to assist with navigation in the grid, in accordance with an aspect of the present invention;
  • FIG. 8 is a flow diagram generally describing one suitable process for controlling navigation and command selection in a grid, in accordance with an aspect of the present invention;
  • FIGS. 9 and 10 comprise a flow diagram generally describing an alternative, lock-mode-capable process for controlling navigation and command selection in a grid, in accordance with an aspect of the present invention; and
  • FIG. 11 is a block diagram representing exemplary components for implementing the flow diagrams of FIGS. 8-10 (or similarly suitable logic) in accordance with an aspect of the present invention.
  • DETAILED DESCRIPTION EXEMPLARY OPERATING ENVIRONMENT
  • FIGURE 1 illustrates an example of a suitable operating environment 120 in which the invention may be implemented, particularly for decoding image and/or video data. The operating environment 120 is only one example of a suitable operating environment and is not intended to suggest any limitation as to the scope of use or functionality of the invention. Other 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, multiprocessor systems, microprocessor-based systems, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like. For example, it is likely that encoding image and/or video image data often will be performed on a computer with more processing power than contemporary hand-held personal computers, but there is no reason encoding cannot be performed on the exemplary device, or decoding on a more powerful machine.
  • The invention may be described in the general context of computer-executable instructions, such as program modules, executed by one or more computers or other devices. Generally, program modules include routines, programs, objects, components, data structures and so forth that perform particular tasks or implement particular abstract data types. Typically the functionality of the program modules may be combined or distributed as desired in various embodiments.
  • Computing device 120 typically includes at least some form of computer readable media. Computer-readable media can be any available media that can be accessed by the computing device 120. 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 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 computing device 120. 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.
  • FIG. 1 shows functional components of one such handheld computing device 120, including a processor 122, a memory 124, a display 126, and a keyboard 128 (which may be a physical or virtual keyboard). The memory 124 generally includes both volatile memory (e.g., RAM) and non-volatile memory (e.g., ROM, PCMCIA cards, and so forth). An operating system 130 is resident in the memory 124 and executes on the processor 122, such as the Windows® CE operating system from Microsoft® Corporation, or another operating system.
  • One or more application programs 132 are loaded into memory 124 and run on the operating system 130. Examples of applications include email programs, scheduling programs, PIM (personal information management) programs, word processing programs, spreadsheet programs, Internet browser programs, and so forth. The handheld personal computer 120 may also include a notification manager 134 loaded in the memory 124, which executes on the processor 122. The notification manager 134 handles notification requests, e.g., from the application programs 132.
  • The handheld personal computer 120 has a power supply 136, which is implemented as one or more batteries. The power supply 136 may further include an external power source that overrides or recharges the built-in batteries, such as an AC adapter or a powered docking cradle.
  • The exemplary handheld personal computer 120 represented in FIG. 1 is shown with three types of external notification mechanisms: one or more light emitting diodes (LEDs) 140 and an audio generator 144. These devices may be directly coupled to the power supply 136 so that when activated, they remain on for a duration dictated by a notification mechanism even though the handheld personal computer processor 122 and other components might shut down to conserve battery power. The LED 140 preferably remains on indefinitely until the user takes action. Note that contemporary versions of the audio generator 144 use too much power for today's handheld personal computer batteries, and so it is configured to turn off when the rest of the system does or at some finite duration after activation.
  • HARDWARE BUTTON MENU
  • FIG. 2 is a representation of a conventional, prior art mobile telephone 200 having a display screen 202. As represented in FIG. 2, a user uses up and down buttons 203 and 205 to scroll vertically and highlight a selection (e.g., 209) of a plurality of displayed selections 207-209. Once highlighted, the user presses an OK button 213 or the like to invoke the selection, which typically takes the user to a similarly arranged sub-menu. Although only three selections are shown, there are frequently many more (e.g., on the order of ten to twenty) commands available in the main menu alone, including commands such as Messages, or Setup. For sub-menus of commands, such as to select a name from a user's telephone directory, there may be hundreds of such entries. As is understood, a significant amount of scrolling is often required to navigate such menus. Various shortcuts are sometimes provided, e.g., with lists of alphabetized names, pressing an appropriate one of the alphanumeric keys 231 in some devices may skip to ahead start scrolling the names from that letter. Although sometimes helpful, such shortcuts still require a user to perform a number of extra steps and are thus inconvenient, and a lot of scrolling may still be required, as many names begin with the same letter. The usage of such shortcuts is also not very intuitive.
  • FIG. 3 is a representation of a mobile telephone 300, with a display 302 arranged to have commands invoked in accordance with the present invention. FIG. 4 is a representation of a handheld computing device 400 (such as the device 120 described with reference to FIG. 1) with a display 402 similarly arranged. Both devices 300 and 400 include a menu button (or equivalent, labeled 304 and 404, respectively. Note that any hardware keyboard key in a keyboard mode would equivalently suffice as the menu button.
  • As represented herein, the mobile telephone 300 is constructed with a four-way control 306 (which may be a single four-way rocker switch or four separate buttons, corresponding to up, down, left and right), whereas the computing device 400 is constructed with an eight-way control 406, adding diagonal movement commands. As will be understood, the different controls and devices represented herein are for purposes of varying the examples, and the present invention may be implemented with virtually any control that allows movement in two-dimensions, and with any computing device. Further, in addition to being controlled by button actuation, the devices may or may not also be touch sensitive.
  • In accordance with one aspect of the present invention and as generally represented in FIG. 3, instead of a linear list of commands, the commands on the display 302 are presented to the user in the form of a two-dimensional grid 310, which the user activates and views by pressing and holding the menu button 304. On the display 402 of the computing device 400 (FIG. 4), the commands are similarly presented to the user in the form of a two-dimensional grid 410, activated and viewed by pressing and holding the menu button 404. It is also feasible to have a mechanism arranged to display the menu grid 310 (or 410), such as by default, but not have the menu grid 310 (or 410) be active until the menu button 304 (or 404) is pressed and held. To indicate a grid in an inactive state, for example, the inactive grid may be shown in a different color, grayed-out, and/or with no highlighted selection.
  • In FIGS. 3 and 4, a default command (labeled Default Command) is centered in the corresponding menu grid 310 or 410. For grids that have an even number of items in a row and/or column, e.g., a 4 x 3 grid, the default command may be placed elsewhere, such as near the center. The default command may be a command that the menu designer deemed to be the one most likely to be needed, although it is feasible to have the default command be dynamic, with a most frequently used algorithm or the like controlling what is displayed as the default, or have the default command be user-configurable. Similarly, the commands that are more likely to be used should be arranged so as to be selected with the fewest number of button pushes possible. Thus, it may be more advantageous to have the commands remain constant or mostly constant so that users can quickly memorize button patterns, e.g., menu button held plus "up" would be an easy to remember pattern, and thus it would make sense to design the menu so that the command selected by this pattern will be one that is likely to be used fairly often. Note that as used herein, the terms "command" and "commands" can be essentially any menu item that can be displayed, and are not limited to commands that when invoked perform some unique and/or definite function. For example, menu items may be duplicate commands or blanks, such as when there are not enough distinct commands in a given menu to complete a grid. Menu commands can also correspond to one or more letters or numbers, macros, and so forth.
  • In accordance with one aspect of the present invention, in one embodiment, releasing of the menu button (304 in FIG. 3, 404 in FIG. 4) invokes the selected command. This facilitates rapid selection of a command, with as little as one push-and-release of the menu button required to invoke the default command. Indeed, the menu need not even be displayed if the menu button is pressed and released fast enough. Note that it is essentially equivalent (although somewhat less convenient) to have more than one hardware menu button, e.g., with one button pressed as the first actuation that activates / displays the menu and another button pressed as the second actuation that invokes the current selection. Thus, as used herein, a "menu button," "menu button mechanism"or the like may be any hardware mechanism that enables distinct first and second actuations.
  • In FIG. 3, to select something other than the default command, while still holding the menu button 304, (or otherwise locking the device into a menu mode, described below), a user uses the four-way control 306 to move the pending selection. This chording technique changes the highlighting (or other indication) of the selection. If more commands are available than can be displayed, such commands may be scrolled into the display area when needed, e.g., when the user is requesting further directional movement to select a command that exists logically beyond the edge of the display. Once the desired command is highlighted, the menu button (and possibly the directional button) is released to make the selection, whereby the device invokes the command as appropriate, e.g., renders a new sub-menu for the selection, dials a telephone number, and so on.
  • The commands displayed in the grid 310 of FIG. 3 include some commands that require only one directional button (Command A, Cancel, Command B and Command C, corresponding to up, down, left or right, respectively) to be selected. Such commands are referred to as secondary commands, with the default command being considered the primary command. Because of the four-way switch, other commands, referred to as tertiary commands, require that two directional buttons be serially pressed to select them. For example, Command D, Command E, Command F and Command G are respectively selected by pressing up/left, down/left, up/right and down/right, in either order.
  • It should also be noted that in FIG. 3, the numeric keys 331 (1-9, *, 0 and #) are also in a two-dimensional layout, and thus spatially and intuitively relate to the displayed grid 310, at least in part. Accordingly, commands may be selected via the directional pad 306 and menu button 304, and also via the numeric keys 331. To facilitate use of the keys 331 for invoking commands, the various commands of the grid 310 can each display a number (not shown) identifying a corresponding keypad key, e.g., Command D can indicate that it may be also be invoked by pressing the 1 key on the keypad 331, Command A by the 2 key, and so on up to Command F corresponding to the 9 key.
  • Note that one of the selections is a Cancel command. The Cancel command enables the menu button 304 to be released without invoking a command. Preferably each menu grid (and sub-menu) will include at least one such Cancel command. More than one may be provided, such as when scrolling, so that a Cancel command always appears regardless of how scrolled. Note that another hardware button such as the "End" button 318 (or at least one of the "Other" buttons such as the button 418 in FIG. 4) may operate to cancel command selection via the grid, whether or not a Cancel command is also provided in the grid.
  • FIGS. 5A-5E describe one way in which scrolling may be accomplished. In FIGS. 5A-5E, a 5 x 5 grid of commands 510 is available, however the display only shows a 3 x 3 subset of these commands. In FIGS. 5A-5E, the displayed 3 x 3 subset, labeled 540A-540E respectively, is represented by a solid box surrounding commands drawn with solid lines, while the available, but not displayed commands are shown surrounded by dashed lines. A dashed box surrounds the entire 5 x 5 grid, and the currently selected command is highlighted, indicated with slanted lines, and shadowed. Note that the in FIGS. 5A-5E, the solid box representing what is currently being displayed generally appears to move around, but does not, as in actuality what is presently displayed is logically moved into the corresponding display area. Further, note that although not necessary to the invention, the entire 5 x 5 grid of FIGS. 5A-5E is arranged such that at least one Cancel command selection is displayed to the user regardless of how scrolled.
  • FIG. 5A shows the initially displayed menu 540A which is a subset of the grid 510, with the default command initially and automatically selected and centered in the entire grid 510, in keeping with one preferred implementation described above. If the menu button is released at this time, the default command would be selected. FIG. 5B shows the user having changed the pending selection to Command C, accomplished via a right directional control button. Note that as represented in FIG. 5B, scrolling preferably does not occur, since Command C was visible, and thus the commands displayed in the subset 540A and 540B are the same, but with the pending command changed.
  • FIG. 5C shows the displayed subset menu 540C of the complete grid 510 being logically scrolled into the display area, and the selection of Command S, which occurs when the user again actuates the right directional button. Scrolling right again at this time may be prevented, or it may result in the user circularly moving the selection to Command K, or moving / scrolling up or down. For purposes of simplicity, scrolling while at the logical scroll limit will be described as being prevented by the system.
  • FIGS. 5D and 5E show the results of two down directional buttons having been pressed following the state shown in FIG. 5C, pressed once to result in the state represented in FIG. 5D, and pressed once more to result in the state represented in FIG. 5E. FIG. 5D does not scroll since Command R was already displayed, while FIG. 5E scrolls to display a new subset 540E in order to enable the requested selection of Command Q. Note that slider mechanisms (FIG. 6A) 601-602, and/or a map 604 (FIG. 6B) may be employed to provide a visual indication to the user of where the user has scrolled to a subset 640 within the overall grid, and/or to assist with navigation therein. For example, the mechanisms 601, 602 and 604 represented in FIGS. 6A and 6B may be used to indicate that the user has scrolled to the lower right corner of the overall grid, as in the state represented in FIG. 5E.
  • Returning to FIG. 4, FIG. 4 represents an example computing device 400 that is physically different from the mobile telephone device 300 of FIG. 3, yet operates similarly with respect to menu selection. However, because of the eight-way directional control button 406, it is possible to move diagonally to select any one of the commands, labeled Command D, Command E, Command F or Command G. Thus, in this alternative, such diagonally-positioned commands are secondary commands, not tertiary commands, although it is also possible to select such a command using a combination two-step horizontal and vertical button press instead of a one-step diagonal press. As used herein, secondary means a minimum of one step away from the current position, while tertiary means two steps away, regardless of whether the user actually moves the selection in this direct manner. FIG. 7 shows a grid 710, which generally corresponds to the grid 410 of FIG. 4 after a single diagonal (up and right) button press has changed the pending command selection from the Default Command to Command G.
  • It should be noted that any grid can have duplicate commands, such as the multiple Cancel commands represented in FIGS. 5A-5E. A grid may also have one or more commands omitted therefrom, such as by showing a blank or grayed-out space instead of a command and preventing selection of that space, or showing a command as "No operation" or the like can be selected, but when invoked, has no effect. In FIG. 7, Command D is shown with a dashed box around it to indicate that the command may or may not be present, or if present, may have a different appearance, wherein the user may be prevented from selecting Command D or Command D may have no associated function or a special function. For example, one such special function may correspond to a lock mode command that enters the device into a lock mode state, described below.
  • Turning to an explanation of the present invention with particular reference to the flow diagrams of FIGS. 8-10 and the block diagram of FIG. 11, FIG. 8 shows one way in which the hardware buttons in combination with a two-dimensional grid of menu commands may be operated to facilitate user command selection. Note that this is only an example of a suitable process and components for purposes of describing the operation and structure, and there are many equivalent ways and components to accomplish the general logic. Further note that the components in FIG. 11 may be the same as like components represented in FIG. 3 or FIG. 4, or may be components on a different device.
  • Step 800 of FIG. 8 begins when the menu button 1104 of FIG. 11 is pressed, and represents initializing the display 1102 and initializing the currently pending command to the Default Command. Step 802 represents updating (or if already properly displayed, activating) the display 1102, although as described above, this may be temporarily deferred to avoid rendering the display 1102 if the user very quickly presses and releases the hardware menu button 1104.
  • Step 804 tests whether the menu button 1104 of FIG. 11 has been released. If so, the process would end, and the currently selected command, which at this time would be the Default Command, would be invoked. Note that this might result in the default command being executed, and/or invoking a sub-menu (which may similarly comprise a command grid) that is displayed for further sub-selection in a similar manner, or the performance of other types of functions.
  • If at step 804 of FIG. 8 the menu button 1104 is still being pressed, step 806 represents testing whether one of the directional buttons 1106 has been pressed. If not, step 806 loops back until either the menu button 1104 is released or a directional button is pressed. Note that steps 804 and 806 need not actually be in such a loop, as such a process 1100 often will be event driven and thus block waiting for the appropriate button event, whereby the device and/or process can perform other activities while waiting. Further note that other hardware buttons may be pressed that may impact the process 1120, e.g., a hardware cancel button may exist so that the user can exit via hardware instead of (or in addition to) requiring a menu selection to cancel.
  • At some point, the menu button 1104 will be released as detected by step 804, or one of the directional buttons 1106 pressed as detected by step 806. When a directional button is pressed, step 808 evaluates whether the requested command to-be-selected is currently shown on the display. To this end, data structures 1130 such as a data array that matches the grid and/or other suitable data structure or structures can track which subset (if any) of the available commands are being displayed and which are not. The same array or one or more other variables can track which command is currently selected.
  • For example, the following matrix may be used to store data regarding the selection and grid display of the 5 x 5 grid of FIG. 5E, wherein the first digit in each pair represents visible (=1) or not (=0), and the second digit in each pair indicates whether the corresponding command is currently selected (=1) or not (=0):
    Figure 00240001
  • If the requested command is currently being shown on the display 1102, scrolling is not needed, whereby step 808 branches to step 814 to change the current (pending) command to the newly selected one, e.g., updating the array and/or other variables in the data structure 1130, and returning to step 802 to update the display 1102 to reflect the new selection. Otherwise, scrolling may be possible, as evaluated by step 810. If not, e.g., a scroll limit has already been reached (the user has scrolled to the end of the total grid and circular or other scrolling is not allowed), step 810 returns to step 804, essentially ignoring the request. Note that a beep, visual indication or other alarm may be first provided to inform the user of the scroll limit having been reached.
  • If step 810 determines that scrolling is possible, step 810 branches to step 812 to scroll the requested command into the displayed (subset) command menu. Again, this may be accomplished by adjusting the values in the array or the like, and using the array values to map to what is displayed. Step 812 continues to step 814 to change the current pending command, as described above, and returns to step 802 to update the display 1104 to reflect the scrolling and the new selection.
  • FIGS. 9 and 10 provide an alternative enhancement that may be used, for example, to facilitate one-handed operation of the device. To this end, instead of the release of the menu button 1104 acting as its secondary actuation, the device can be placed in a lock (or lock down) mode 1122 of operation, in which the menu button 1104 may be released and not secondarily actuated until pressed again to invoke the currently pending selection. Thus, as used herein, in either implementation the menu button 1104 is initially and then secondarily actuated, but the second actuation may be accomplished in different ways (e.g., released in a regular mode, or pressed a second time if in the lock mode).
  • FIG. 9 describes one way in which the lock mode 1122 can be incorporated into the regular mode, e.g., as described above with reference to FIG. 8. For example, when initially actuated, the process 1120 operates generally the same to initialize the array and/or variables at step 900, and further starts a lock mode timer 1132. In general, if the menu button 1104 is held for some substantial, predetermined or user configurable time period (e.g., two seconds), and then released without a directional button having been pressed during that period, the lock mode 1122 is entered. Thus, in FIGS. 9 and 10, two things are required to achieve entering of the lock mode 1122, namely holding the menu button 1104 for the required duration, and then releasing it before any directional button 1106 is pressed. Alternatively, (not shown), once held for the appropriate duration without a directional button having been pressed, the lock mode 1122 can be entered, regardless of whether it is released before or after the pressing of a directional control button.
  • Step 902 updates the display 1102 of FIG. 11 as generally described above, and step 904 tests for the release of the menu button 1104. If released before lock mode 1122 was entered, the current command is invoked, e.g., as in the regular mode. Otherwise a directional button is tested for at step 906. However, instead of returning when no directional button is pressed, another test regarding whether the lock mode time has been achieved by the lock mode timer 1132 occurs at step 908. Note that the lock mode duration should be far longer than the device takes to executed steps 900-906, whereby there is no way to reach the lock mode time before the user has had at least a reasonable chance to release the menu button 1104 and make a selection in the previously described manner and/or press a directional button. In this manner, the process operates as before, unless and until the lock mode 1122 is entered.
  • If a directional button is pressed before the lock mode time has been reached, steps 910-916 operate in the same general way as the similar steps described above with reference to FIG. 8, and thus these steps will not be described again for purposes of brevity.
  • If the lock mode time is achieved at step 908, the process continues to step 1000 of FIG. 10, where a test is performed to determine if the menu button 1104 has been released. As described above, to ensure that the user really wants to enter the lock mode 1122, in this alternative, the menu button 1104 needs to be released before any of the directional buttons 1106 are pressed, regardless of how long the menu button 1104 was held down before the directional button was pressed. Although it is alternatively feasible to base the lock mode determination solely on holding time (without another selection being made), requiring both a holding time and an actual release before another selection is made seems more consistent with one-handed operation, which is one reason for having a lock mode. Note that the choice between these alternatives and others may be user configurable. Further, note that other mechanisms for entering the lock mode are feasible, such as by displaying in the grid a lock mode command that is easy to select, even by one-handed operation, e.g., a menu button press and release followed rapidly by a left directional arrow may be considered a switch to the lock mode (instead of immediately treating the release as selection of the default command). With such an alternative mechanism, to select the default command, the user would release the menu button but then not press the directional button right after the release.
  • In the described implementation (in which the menu button 1104 needs to be held for the appropriate time and released before any directional button is hit to enter the lock mode), if the menu button 1104 has not been released at step 1000, step 1000 branches to step 1002 to determine whether the user has pressed one of the directional buttons 1106. If so, the lock mode 1110 is not successfully entered, and the process returns to FIG. 9, step 910. If at step 1002 a directional button has not been pressed, the process 1120 loops or otherwise waits for one of these two button actions to occur. Note that once the lock mode time has been achieved at step 908, but the lock mode was not entered because a directional button 1106 was pressed before release of the menu button 1104, in one implementation the process will not again attempt to enter the lock mode, as indicated by the dashed line from step 906 back to step 904. A flag or the like can track this time-achieved, but lock-mode-not-entered state. In other implementations the lock mode could be re-entered by continuing to hold the menu button 1104 for a sufficient time without selecting a directional button.
  • Eventually in FIG. 10, either the menu button 1104 is released at step 1000, or a directional button 1106 is pressed at step 1002. If first released, the lock mode 1122 is entered, and step 1000 branches to step 1004 to update the display 1102 if desired, such as to indicate to the user the state change into the lock mode 1122. Note that an audible sound may also be output to indicate initial entry into the lock mode, and that step 1000 may bypass step 1004 if no such visible indication is made.
  • At this time, steps 1006-1018 operate in the same general way as the similar steps described above with reference to FIG. 8, but with one difference, namely that the secondary actuation that is required to invoke the currently selected command is now a button press at step 1006, not a button release. Thus, selection and scrolling may be the same as in the regular mode of operation, the display 1102 will be updated as appropriate, and so on, however in this mode, pressing (not releasing) of the (already-released) menu button 1104 is detected as the second actuation that invokes the selected command. Note that instead of detecting only the subsequent press, a full press-and-release of the menu button 1104 may instead be required to actuate, and indeed, a second press and hold for a sufficient time may even be used for another purpose, such as to exit the lock mode and return to regular non-locked operation.
  • As can be seen from the foregoing detailed description, there is provided a method and system that facilitates rapid hardware button selection of a large number of menu commands. For example, with an eight way directional control, any one of nine commands can be selected with at most one directional control button press, and any one of twenty-five commands can be selected with at most two directional control button presses. The grid provides similar exponential benefits with a four-way control. The method and system are flexible, may be varied and/or otherwise customized to meet a variety of scenarios, are intuitive to use and provide numerous advantages over prior art mechanisms.
  • 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.

Claims (33)

  1. In a computing device, a method comprising:
    receiving a first actuation of a menu button mechanism;
    activating a two-dimensional grid of commands;
    enabling, via a set of at least one directional control button, a selection of a command as a selected command;
    receiving a second actuation of the menu button mechanism; and
    in response to the second actuation, invoking the selected command.
  2. The method of claim 1 wherein the menu button mechanism comprises a single hardware key, wherein receiving a first actuation comprises receiving an indication that the key was pressed, and wherein receiving a second actuation comprises receiving an indication that the key was released.
  3. The method of claim 1 wherein activating the two-dimensional grid of commands comprises displaying the grid.
  4. The method of claim 1 wherein activating the two-dimensional grid of commands is performed in response to the first actuation of the menu button mechanism.
  5. The method of claim 1 further comprising, selecting a default command as the selected command upon activating the two-dimensional grid of commands.
  6. The method of claim 5 wherein the default command is centered within the two-dimensional grid of commands.
  7. The method of claim 1 further comprising, receiving an actuation of a directional control button, and in response, changing the selected command to another command.
  8. The method of claim 7 further comprising, updating a display to indicate that the other command is the selected command.
  9. The method of claim 7 further comprising, updating a display to scroll to a subset of commands in the grid.
  10. The method of claim 9 further comprising, outputting visual information indicative of where the user has scrolled within the grid.
  11. The method of claim 1 wherein the selected command corresponds to a cancel command, and wherein invoking the selected command comprises deactivating the two-dimensional grid of commands.
  12. The method of claim 1 wherein the first actuation comprises pressing and holding down the hardware button mechanism, and further comprising, detecting whether the first actuation has been held down for a defined time period without a directional control button being actuated, and if so, entering a lock mode in which the second actuation of the menu button mechanism does not correspond to a release of the menu button mechanism.
  13. The method of claim 12 wherein the second actuation comprises a second pressing of the menu button mechanism.
  14. A computer-readable medium having computer-executable instructions for performing the method of claim 1.
  15. In a computing device, a system comprising:
    a menu button mechanism configured to indicate actuations thereof;
    a set of at least one directional control button configured to indicate requests to move in a direction, each request corresponding a direction associated with at least one of two dimensions;
    a display having a two-dimensional grid of menu commands represented thereon; and
    a process that operates on a first actuation of the menu button mechanism, the process connected to receive indications of at least one other actuation from the menu button mechanism and to receive from the set of directional control buttons indications of requests to move, the process configured to:
    1) control the display output to represent a selected one of the menu commands in the grid;
    2) change the selected menu command in response to a request to move received from the set of directional control buttons; and
    3) cause invocation of the selected command upon receiving an indication of a second actuation of the menu button mechanism.
  16. The system of claim 15 wherein the first actuation corresponds to the menu button mechanism being pressed, and the second actuation corresponds to the menu button mechanism being released.
  17. The system of claim 16 wherein the default command is centered within the two-dimensional grid of commands.
  18. The system of claim 15 wherein the grid has more commands available than are displayed, and wherein the process scrolls a subset of commands into the display.
  19. The system of claim 18 wherein the process further controls the display to output visual information indicative of the position of the subset that is displayed with respect to the grid.
  20. The system of claim 15 wherein the selected command corresponds to a cancel command.
  21. The system of claim 15 wherein the first actuation comprises pressing and holding down the hardware button mechanism, and further comprising a timer mechanism, wherein the process communicates with the timer mechanism to determine whether the first actuation has been held down for a defined time period without a directional control button being actuated, and if so, the process entering a lock mode in which the second actuation of the menu button mechanism does not correspond to a release of the menu button mechanism.
  22. The system of claim 21 wherein the second actuation comprises a second pressing of the menu button mechanism.
  23. The system of claim 15 wherein the grid comprises a three-by-three menu of commands.
  24. The system of claim 15 wherein the process initially selects a default command as the selected command.
  25. The system of claim 15 wherein the grid comprises a menu of commands in which only a subset thereof is displayable at one time, the process configured to scroll the subset into the display based on the move request received from the directional control button set.
  26. The system of claim 15 wherein the set of directional control buttons comprises a four-way control that indicates each request to move as a request to move in an up, down, left or right direction.
  27. The system of claim 15 wherein the set of directional control buttons comprises an eight-way control that indicates each request to move as a request to move in an up, down, left, right, up/left, down/left, up/right or down/right direction.
  28. The system of claim 15 further comprising a plurality of physical keys in a two-dimensional arrangement, wherein the process relates at least some of the physical keys to at least some of the menu commands in the grid.
  29. In a computing device, a method comprising:
    receiving first information indicating that a menu button has been pressed;
    in response to receiving the first information, and while the menu button is being held, displaying and activating a two-dimensional grid of commands, including one default command chosen as a selected command;
    receiving, via a directional control mechanism, at least one request to change the selection of the selected command, and in response, changing the selection of the selected command and updating the displayed grid to indicate the changed selection; and
    receiving second information indicating that the menu button has been released, and in response, invoking the selected command.
  30. The method of claim 29 wherein updating the displayed grid includes scrolling a subset of commands into a displayed subset of the grid.
  31. The method of claim 29 wherein the default command is initially centered in the displayed grid.
  32. The method of claim 29 further comprising, deactivating and removing from the display the two-dimensional grid of commands in response to receiving the second information indicating that the menu button has been released.
  33. A computer-readable medium having computer-executable instructions for performing the method of claim 29.
EP03010201A 2002-06-28 2003-05-06 Method and system for presenting menu commands for selection Ceased EP1376325A3 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US10/187,195 US7546548B2 (en) 2002-06-28 2002-06-28 Method and system for presenting menu commands for selection
US187195 2002-06-28

Publications (2)

Publication Number Publication Date
EP1376325A2 true EP1376325A2 (en) 2004-01-02
EP1376325A3 EP1376325A3 (en) 2006-09-13

Family

ID=29718036

Family Applications (1)

Application Number Title Priority Date Filing Date
EP03010201A Ceased EP1376325A3 (en) 2002-06-28 2003-05-06 Method and system for presenting menu commands for selection

Country Status (2)

Country Link
US (1) US7546548B2 (en)
EP (1) EP1376325A3 (en)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1892627A1 (en) * 2006-08-23 2008-02-27 Samsung Electronics Co., Ltd. Multitask managing apparatus and method in mobile communication system
WO2008022757A1 (en) 2006-08-24 2008-02-28 Nokia Corporation User interface for an electronic device
EP2381353A1 (en) * 2010-04-23 2011-10-26 Research In Motion Limited Graphical context short menu
EP2360570A3 (en) * 2010-02-15 2012-05-16 Research In Motion Limited Graphical context short menu
EP2750012A4 (en) * 2011-11-17 2015-07-08 Zhuhai Kingsoft Office Software Co Ltd Scrolling toolbar display and control method

Families Citing this family (120)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2003056784A2 (en) 2001-12-21 2003-07-10 Research In Motion Limited Handheld electronic device with keyboard
US20040135823A1 (en) * 2002-07-30 2004-07-15 Nokia Corporation User input device
DE10252688A1 (en) * 2002-11-13 2004-06-03 Caa Ag Vehicle on board computer system with selection and activation of main and sub menus by repeated operation of a switch element
AU2003297172A1 (en) * 2002-12-16 2004-07-22 Microsoft Corporation Systems and methods for interfacing with computer devices
JP2006510135A (en) * 2002-12-16 2006-03-23 マイクロソフト コーポレーション System and method for interfacing with a computer device
JP2006510335A (en) * 2002-12-16 2006-03-23 マイクロソフト コーポレーション System and method for interfacing with a computer device
US7571393B2 (en) * 2003-04-15 2009-08-04 Microsoft Corporation Method for navigation between elements on a page of content in a handheld device
JP4179085B2 (en) * 2003-07-16 2008-11-12 松下電器産業株式会社 Electronics
US20050066291A1 (en) * 2003-09-19 2005-03-24 Stanislaw Lewak Manual user data entry method and system
KR100617827B1 (en) * 2003-11-14 2006-08-28 삼성전자주식회사 Apparatus and method for displaying menu of hierarchy structures in mobile terminal equipment
KR100608679B1 (en) * 2004-01-08 2006-08-02 삼성전자주식회사 Displaying apparatus and method for indicating movement direction of an object
KR100590593B1 (en) * 2004-05-27 2006-06-19 (주)비즈키즈 Contents index structure, and method and apparatus for demanding contents using the same
US20070254700A1 (en) * 2004-06-21 2007-11-01 Griffin Jason T Handheld wireless communication device
US7982712B2 (en) * 2004-06-21 2011-07-19 Research In Motion Limited Handheld wireless communication device
US20070254688A1 (en) * 2004-06-21 2007-11-01 Griffin Jason T Handheld wireless communication device
US8463315B2 (en) 2004-06-21 2013-06-11 Research In Motion Limited Handheld wireless communication device
US20070254689A1 (en) * 2004-06-21 2007-11-01 Griffin Jason T Handheld wireless communication device
US20070254708A1 (en) * 2004-06-21 2007-11-01 Griffin Jason T Handheld wireless communication device
US7986301B2 (en) 2004-06-21 2011-07-26 Research In Motion Limited Handheld wireless communication device
US20070254703A1 (en) * 2004-06-21 2007-11-01 Griffin Jason T Handheld wireless communication device
US8271036B2 (en) * 2004-06-21 2012-09-18 Research In Motion Limited Handheld wireless communication device
US20070254698A1 (en) * 2004-06-21 2007-11-01 Griffin Jason T Handheld wireless communication device
US20070254721A1 (en) * 2004-06-21 2007-11-01 Griffin Jason T Handheld wireless communication device
US20070192711A1 (en) * 2006-02-13 2007-08-16 Research In Motion Limited Method and arrangement for providing a primary actions menu on a handheld communication device
US8219158B2 (en) * 2004-06-21 2012-07-10 Research In Motion Limited Handheld wireless communication device
US20070254704A1 (en) * 2004-06-21 2007-11-01 Griffin Jason T Handheld wireless communication device
US7973765B2 (en) * 2004-06-21 2011-07-05 Research In Motion Limited Handheld wireless communication device
US8064946B2 (en) * 2004-06-21 2011-11-22 Research In Motion Limited Handheld wireless communication device
US20070254705A1 (en) * 2004-06-21 2007-11-01 Griffin Jason T Handheld wireless communication device
US20050289480A1 (en) * 2004-06-25 2005-12-29 Motorola, Inc. Method and apparatus to reduce navigational keystrokes in electronic devices
US20060064650A1 (en) * 2004-09-20 2006-03-23 International Business Machines Corporation Method, system, and computer program product for type-based table navigation
US8539374B2 (en) * 2005-09-23 2013-09-17 Disney Enterprises, Inc. Graphical user interface for electronic devices
US7739620B1 (en) * 2005-09-29 2010-06-15 Adobe Systems Inc. Method of setting alternate style assignments to menu elements of an application
US7509588B2 (en) 2005-12-30 2009-03-24 Apple Inc. Portable electronic device with interface reconfiguration mode
US8537117B2 (en) 2006-02-13 2013-09-17 Blackberry Limited Handheld wireless communication device that selectively generates a menu in response to received commands
US7770118B2 (en) * 2006-02-13 2010-08-03 Research In Motion Limited Navigation tool with audible feedback on a handheld communication device having a full alphabetic keyboard
US8244757B2 (en) * 2006-03-30 2012-08-14 Microsoft Corporation Facet-based interface for mobile search
US20070240077A1 (en) * 2006-04-07 2007-10-11 Mccarthy Kevin Mobile communication terminal and method therefor
US20070250792A1 (en) * 2006-04-24 2007-10-25 Lavery Andrew J Presentation of service data in support of a user interactive application program during running of the program on a computer controlled display
US7940250B2 (en) * 2006-09-06 2011-05-10 Apple Inc. Web-clip widgets on a portable multifunction device
US8564544B2 (en) 2006-09-06 2013-10-22 Apple Inc. Touch screen device, method, and graphical user interface for customizing display of content category icons
US10313505B2 (en) 2006-09-06 2019-06-04 Apple Inc. Portable multifunction device, method, and graphical user interface for configuring and displaying widgets
US9344548B2 (en) * 2006-12-28 2016-05-17 Blackberry Limited Method for saving an image from a camera application of a portable electronic device
US7802201B2 (en) 2006-12-29 2010-09-21 Research In Motion Limited System and method for panning and zooming an image on a display of a handheld electronic device
US20080163121A1 (en) * 2006-12-29 2008-07-03 Research In Motion Limited Method and arrangement for designating a menu item on a handheld electronic device
US20080163112A1 (en) * 2006-12-29 2008-07-03 Research In Motion Limited Designation of menu actions for applications on a handheld electronic device
US8635559B2 (en) * 2006-12-29 2014-01-21 Blackberry Limited On-screen cursor navigation delimiting on a handheld communication device
US8788954B2 (en) * 2007-01-07 2014-07-22 Apple Inc. Web-clip widgets on a portable multifunction device
US8519964B2 (en) 2007-01-07 2013-08-27 Apple Inc. Portable multifunction device, method, and graphical user interface supporting user navigations of graphical objects on a touch screen display
US8719723B2 (en) * 2007-03-05 2014-05-06 Microsoft Corporation Displaying data sensitive targets
US9122396B2 (en) * 2007-03-30 2015-09-01 Qualcomm Incorporated Application quick launch extension
US20080256454A1 (en) * 2007-04-13 2008-10-16 Sap Ag Selection of list item using invariant focus location
US7979805B2 (en) 2007-05-21 2011-07-12 Microsoft Corporation Button discoverability
US9933937B2 (en) 2007-06-20 2018-04-03 Apple Inc. Portable multifunction device, method, and graphical user interface for playing online videos
US9772751B2 (en) * 2007-06-29 2017-09-26 Apple Inc. Using gestures to slide between user interfaces
US9619143B2 (en) 2008-01-06 2017-04-11 Apple Inc. Device, method, and graphical user interface for viewing application launch icons
US11126321B2 (en) 2007-09-04 2021-09-21 Apple Inc. Application menu user interface
US8619038B2 (en) 2007-09-04 2013-12-31 Apple Inc. Editing interface
US8314789B2 (en) * 2007-09-26 2012-11-20 Autodesk, Inc. Navigation system for a 3D virtual scene
US20090096812A1 (en) * 2007-10-12 2009-04-16 Business Objects, S.A. Apparatus and method for morphing data visualizations
TW200930023A (en) * 2007-12-31 2009-07-01 Htc Corp Method for providing a menu using an end key and mobile communication device using the same
KR20090077142A (en) * 2008-01-10 2009-07-15 삼성전자주식회사 Method and apparatus for displaying information used to choose input element
JP5140538B2 (en) 2008-09-30 2013-02-06 任天堂株式会社 Start control program, start control device, start control system, and start control method
CN101847074A (en) * 2009-03-26 2010-09-29 深圳富泰宏精密工业有限公司 Array functional arrangements, application system and method
KR101588242B1 (en) * 2009-07-13 2016-01-25 삼성전자주식회사 Apparatus and method for scroll of a portable terminal
JP5359634B2 (en) * 2009-07-16 2013-12-04 富士通モバイルコミュニケーションズ株式会社 Information processing device
AU2010312327B2 (en) * 2009-10-30 2016-05-19 Richard John Cale Environmental control method and system
US8736561B2 (en) 2010-01-06 2014-05-27 Apple Inc. Device, method, and graphical user interface with content display modes and display rotation heuristics
US20110179376A1 (en) * 2010-01-21 2011-07-21 Sony Corporation Three or higher dimensional graphical user interface for tv menu and document navigation
US8423911B2 (en) 2010-04-07 2013-04-16 Apple Inc. Device, method, and graphical user interface for managing folders
US10788976B2 (en) 2010-04-07 2020-09-29 Apple Inc. Device, method, and graphical user interface for managing folders with multiple pages
CN102314293A (en) * 2010-07-07 2012-01-11 富泰华工业(深圳)有限公司 Electronic device and multimedia data browsing method
KR20120019244A (en) * 2010-08-25 2012-03-06 삼성전자주식회사 Control method of a plurality of attribute and portable device thereof
US9244606B2 (en) 2010-12-20 2016-01-26 Apple Inc. Device, method, and graphical user interface for navigation of concurrently open software applications
KR101785323B1 (en) * 2011-01-05 2017-10-17 삼성전자주식회사 Method and apparatus for providing a user interface in a portable terminal
US9104288B2 (en) 2011-03-08 2015-08-11 Nokia Technologies Oy Method and apparatus for providing quick access to media functions from a locked screen
JP5725504B2 (en) * 2011-07-12 2015-05-27 アルパイン株式会社 In-vehicle device
US20130132883A1 (en) * 2011-11-22 2013-05-23 Nokia Corporation Apparatus and Associated Methods
KR20130078486A (en) * 2011-12-30 2013-07-10 삼성전자주식회사 Electronic apparatus and method for controlling electronic apparatus thereof
US10304347B2 (en) 2012-05-09 2019-05-28 Apple Inc. Exercised-based watch face and complications
US10990270B2 (en) 2012-05-09 2021-04-27 Apple Inc. Context-specific user interfaces
US10613743B2 (en) 2012-05-09 2020-04-07 Apple Inc. User interface for receiving user input
US9459781B2 (en) 2012-05-09 2016-10-04 Apple Inc. Context-specific user interfaces for displaying animated sequences
US9582165B2 (en) 2012-05-09 2017-02-28 Apple Inc. Context-specific user interfaces
US9727238B2 (en) * 2012-06-04 2017-08-08 Home Control Singapore Pte. Ltd. User-interface for entering alphanumerical characters
US20140289641A1 (en) * 2013-03-20 2014-09-25 Jerome Eymard Whitcroft Adaptive User Interface
JP6123514B2 (en) 2013-06-25 2017-05-10 ソニー株式会社 Electronic device, control method and program for electronic device
KR102405189B1 (en) 2013-10-30 2022-06-07 애플 인크. Displaying relevant user interface objects
WO2015118661A1 (en) * 2014-02-07 2015-08-13 三菱電機株式会社 Information processing device and information processing method
CN116243841A (en) 2014-06-27 2023-06-09 苹果公司 Reduced size user interface
EP3195098A2 (en) 2014-07-21 2017-07-26 Apple Inc. Remote user interface
US10452253B2 (en) 2014-08-15 2019-10-22 Apple Inc. Weather user interface
US10254948B2 (en) 2014-09-02 2019-04-09 Apple Inc. Reduced-size user interfaces for dynamically updated application overviews
CN115623117A (en) 2014-09-02 2023-01-17 苹果公司 Telephone user interface
US10475008B1 (en) * 2014-12-09 2019-11-12 Jpmorgan Chase Bank, N.A. Enhanced graphical user interfaces
CN105808038B (en) * 2014-12-30 2019-10-29 联想(北京)有限公司 A kind of information processing method and electronic equipment
US10055121B2 (en) 2015-03-07 2018-08-21 Apple Inc. Activity based thresholds and feedbacks
WO2016144385A1 (en) 2015-03-08 2016-09-15 Apple Inc. Sharing user-configurable graphical constructs
US9916075B2 (en) 2015-06-05 2018-03-13 Apple Inc. Formatting content for a reduced-size user interface
EP4321088A2 (en) 2015-08-20 2024-02-14 Apple Inc. Exercise-based watch face
CN105487748B (en) * 2015-11-20 2020-12-18 腾讯科技(深圳)有限公司 Method and device for displaying icon, storage medium and computer terminal
DK201670595A1 (en) 2016-06-11 2018-01-22 Apple Inc Configuring context-specific user interfaces
DK201770423A1 (en) 2016-06-11 2018-01-15 Apple Inc Activity and workout updates
US11816325B2 (en) 2016-06-12 2023-11-14 Apple Inc. Application shortcuts for carplay
TWI595438B (en) * 2016-09-29 2017-08-11 麗寶大數據股份有限公司 User interface display mehotd
WO2018089694A1 (en) * 2016-11-11 2018-05-17 Aerovironment, Inc. Safety system for operation of an unmanned aerial vehicle
DK179412B1 (en) 2017-05-12 2018-06-06 Apple Inc Context-Specific User Interfaces
US11327650B2 (en) 2018-05-07 2022-05-10 Apple Inc. User interfaces having a collection of complications
TWI694404B (en) * 2019-02-18 2020-05-21 麗寶大數據股份有限公司 User interface display mehotd
US11016643B2 (en) 2019-04-15 2021-05-25 Apple Inc. Movement of user interface object with user-specified content
US11675476B2 (en) 2019-05-05 2023-06-13 Apple Inc. User interfaces for widgets
KR102393717B1 (en) 2019-05-06 2022-05-03 애플 인크. Restricted operation of an electronic device
US11131967B2 (en) 2019-05-06 2021-09-28 Apple Inc. Clock faces for an electronic device
DK180392B1 (en) 2019-09-09 2021-03-12 Apple Inc Techniques for managing display usage
EP4133371A1 (en) 2020-05-11 2023-02-15 Apple Inc. User interfaces for managing user interface sharing
US11372659B2 (en) 2020-05-11 2022-06-28 Apple Inc. User interfaces for managing user interface sharing
DK202070625A1 (en) 2020-05-11 2022-01-04 Apple Inc User interfaces related to time
US11694590B2 (en) 2020-12-21 2023-07-04 Apple Inc. Dynamic user interface with time indicator
US11720239B2 (en) 2021-01-07 2023-08-08 Apple Inc. Techniques for user interfaces related to an event
US11921992B2 (en) 2021-05-14 2024-03-05 Apple Inc. User interfaces related to time

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5805167A (en) * 1994-09-22 1998-09-08 Van Cruyningen; Izak Popup menus with directional gestures

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5953541A (en) * 1997-01-24 1999-09-14 Tegic Communications, Inc. Disambiguating system for disambiguating ambiguous input sequences by displaying objects associated with the generated input sequences in the order of decreasing frequency of use
US6201540B1 (en) * 1998-01-07 2001-03-13 Microsoft Corporation Graphical interface components for in-dash automotive accessories
US6262717B1 (en) * 1998-07-02 2001-07-17 Cirque Corporation Kiosk touch pad
JP2000231432A (en) * 1999-02-12 2000-08-22 Fujitsu Ltd Computer system

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5805167A (en) * 1994-09-22 1998-09-08 Van Cruyningen; Izak Popup menus with directional gestures

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
"Tried and True Hardware -- The Cassiopeia E-115 Pocket PC" INTERNET DOCUMENT, [Online] May 2000 (2000-05), XP002378962 Retrieved from the Internet: URL:http://www.pocketpcmag.com/_archives/may00/triedandtrue.htm> *
BASIS INTERNATIONAL LTD: "Visual PRO/5 documentation: Menu System - Overview" ONLINE DOCUMENTATION, [Online] 7 February 2000 (2000-02-07), XP002378959 Retrieved from the Internet: URL:http://www.basis.com/onlinedocs/documentation/eus/menu_system_overview.htm> -& BASIS INTERNATIONAL LTD: "Visual PRO/5 documentation: Menu Header Screen" ONLINE DOCUMENTATION, 7 February 2000 (2000-02-07), XP002378960 -& BASIS INTERNATIONAL LTD: "BASIS Platform Availability" INTERNET DOCUMENT, 10 April 2006 (2006-04-10), XP002378961 *

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1892627A1 (en) * 2006-08-23 2008-02-27 Samsung Electronics Co., Ltd. Multitask managing apparatus and method in mobile communication system
WO2008022757A1 (en) 2006-08-24 2008-02-28 Nokia Corporation User interface for an electronic device
US8209631B2 (en) 2006-08-24 2012-06-26 Nokia Corporation User interface for an electronic device
EP2360570A3 (en) * 2010-02-15 2012-05-16 Research In Motion Limited Graphical context short menu
EP2381353A1 (en) * 2010-04-23 2011-10-26 Research In Motion Limited Graphical context short menu
US8631350B2 (en) 2010-04-23 2014-01-14 Blackberry Limited Graphical context short menu
EP2750012A4 (en) * 2011-11-17 2015-07-08 Zhuhai Kingsoft Office Software Co Ltd Scrolling toolbar display and control method
US9471215B2 (en) 2011-11-17 2016-10-18 Zhuhai Kingsoft Office Software Co., Ltd Method for controlling display of a context toolbar

Also Published As

Publication number Publication date
EP1376325A3 (en) 2006-09-13
US7546548B2 (en) 2009-06-09
US20040001105A1 (en) 2004-01-01

Similar Documents

Publication Publication Date Title
US7546548B2 (en) Method and system for presenting menu commands for selection
US9122318B2 (en) Methods of and systems for reducing keyboard data entry errors
US10552037B2 (en) Software keyboard input method for realizing composite key on electronic device screen with precise and ambiguous input
EP1377902B1 (en) Multi-functional application launcher with integrated status
EP1509832B1 (en) Object entry into an electronic device
JP2603446B2 (en) Graphical user interface
RU2421777C2 (en) Improved pocket computer and associated method
US7694237B2 (en) Method and apparatus for using menu functions of an electronic device
KR100617827B1 (en) Apparatus and method for displaying menu of hierarchy structures in mobile terminal equipment
US20070220449A1 (en) Method and device for fast access to application in mobile communication terminal
US20120192094A1 (en) User interface
EP1302850A2 (en) Automatic software input panel selection based on application program state
JP2005235188A (en) Data entry device
JP2008542868A (en) Improved pocket computer and related methods
CA2823470A1 (en) Display of controllable attributes for a controllable item based on context
US20080222567A1 (en) Apparatus with Multiple Highlights
US8839123B2 (en) Generating a visual user interface
US20100020018A1 (en) System and method for selecting menu items of an electronic apparatus
US7308654B2 (en) Information processing apparatus, menu processing method and recording medium storing a menu processing program
CN108700990A (en) A kind of screen locking method, terminal and screen locking device
KR100358015B1 (en) Portable computer having a touch panel screen and method for setting input module in the portable computer
KR101452758B1 (en) Screen display device and method of mobile communication terminal
CN101273325B (en) Electronic equipments with touch sensitive input, hardware module and user interface
JPH04318619A (en) Window display control device in multiwindow system
CA2600247C (en) A method and handheld electronic device for improved calendar user interface navigation

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

AK Designated contracting states

Kind code of ref document: A2

Designated state(s): AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IT LI LU MC NL PT RO SE SI SK TR

AX Request for extension of the european patent

Extension state: AL LT LV MK

PUAL Search report despatched

Free format text: ORIGINAL CODE: 0009013

AK Designated contracting states

Kind code of ref document: A3

Designated state(s): AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IT LI LU MC NL PT RO SE SI SK TR

AX Request for extension of the european patent

Extension state: AL LT LV MK

17P Request for examination filed

Effective date: 20070219

AKX Designation fees paid

Designated state(s): AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IT LI LU MC NL PT RO SE SI SK TR

17Q First examination report despatched

Effective date: 20071122

RAP1 Party data changed (applicant data changed or rights of an application transferred)

Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: THE APPLICATION HAS BEEN REFUSED

18R Application refused

Effective date: 20161206