A method and apparatus for detecting a shake by a user to invoke an invoked application, identifying whether there is a conflicting application. When a conflicting application is detected, storing state information for the conflicting application and halting the conflicting application. The method further comprising starting the invoked application, and upon detecting an end of use of the invoked application, restoring the conflicting application to the stored state.
|
1. A method comprising:
detecting a shake by a user to invoke an invoked application;
identifying whether there is a conflicting application, and when a conflicting application is detected storing state information for the conflicting application and halting the conflicting application;
starting the invoked application; and
upon detecting an end of use of the invoked application, restoring the conflicting application to the stored state.
16. A handheld mobile device comprising:
an accelerometer to detect a shake;
an invoked command identification logic to identify an application invoked by the shake;
an application halt logic to halt a conflicting application which conflicts with the invoked application, the application halt logic to store a state of the conflicting application in a memory;
an application start logic to start the invoked application; and
a restoration logic to restore the conflicting application to a prior state when the invoked application is ended.
8. A processor including an invocation logic to invoke an application on a handheld device, the invocation logic comprising:
an invoked command identification logic to identify an application invoked by a shake by a user;
an application halt logic to halt a conflicting application which conflicts with the invoked application, the application halt logic to store a state of the conflicting application in a memory;
an application start logic to start the invoked application; and
a restoration logic to restore the conflicting application to a prior state when the invoked application is ended.
2. The method of
3. The method of
4. The method of
determining if the invoked application utilizes bandwidth; and
throttling available bandwidth to other applications while the invoked application is active.
5. The method of
6. The method of
enabling a user to register one or more motions as the shake.
7. The method of
9. The invocation logic of
a bandwidth logic to throttle bandwidth to an application when the invoked application uses high bandwidth.
10. The invocation logic of
an invoked application monitor to determine when the invoked application use is terminated, and to trigger the restoration logic.
11. The invocation logic of
12. The invocation logic of
13. The invocation logic of
14. The invocation logic of
a gesture registration logic enabling a user to register one or more motions as the shake.
15. The invocation logic of
17. The handheld mobile device of
a communication logic to send and receive information using bandwidth;
a bandwidth logic to throttle bandwidth to an application when the invoked application uses high bandwidth.
18. The handheld mobile device of
an invoked application monitor to determine when the invoked application use is terminated, and to trigger the restoration logic.
19. The handheld mobile device of
20. The handheld mobile device of
a gesture registration logic enabling a user to register one or more motions to invoke one or more applications.
|
The present invention relates to a user interface, and more particularly to an improved method of invoking an application.
There are an increasing number of multi-purpose handheld devices. These devices include mobile telephones which also provide features such as music players, calendar managers, game applications etc. They also include personal digital assistants (PDAs) which provide calendar and contact applications, among other features.
Generally speaking, users navigate from an application to another using multiple menus in combination with hardware or software buttons.
A method comprising detecting a shake by a user to invoke an invoked application, and identifying whether there is a conflicting application. When a conflicting application is detected, the method further includes storing state information for the conflicting application and terminating the conflicting application. The method then includes starting the invoked application. In one embodiment, the method further includes upon detecting an end of use of the invoked application, restoring the conflicting application to the stored state.
The present invention is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which:
The method and apparatus described is a method of using an accelerometer or other motion detection mechanism to simplify navigation between applications. For example, in a multi-function mobile telephone, it often takes multiple navigational steps to get from a current application to the phone application. Furthermore, the user sometimes needs to close applications in order to provide enough RAM (random access memory) to run the new application.
The present application utilizes an accelerometer built into the device to provide speedier access to an application. For example, instead of navigating away from a current application, closing conflicting applications, and opening the dial pad, the user may shake the handheld device in a pre-arranged pattern to invoke the application and simultaneously close down any competing applications. Furthermore, this feature ensures, in one embodiment, that after the application is closed, the previously competing application can be re-started automatically. This means that if the user interrupts, for example, a music program in order to make a telephone call, at the termination of the call, the music program is automatically restarted. In one embodiment, the user may be returned to the screen that was active prior to the invocation of the interrupting application.
In one embodiment, if the applications do not conflict, but the new application has a high bandwidth requirement, in one embodiment the system may throttle the bandwidth available to other applications. In one embodiment, the throttling may simply disconnect the other applications from the network. In one embodiment, when possible, the system saves state so the application can be fully restored when the invoked application is terminated.
Invocation logic 110 detects the pre-determined shakes, taps, or other motions of the device. These motions are used to trigger various actions. In one embodiment, the system includes an initial set of invoking motions, which may in one embodiment include:
two shakes to go to a dial pad
two shakes to pick up the telephone when it is ringing
three shakes to go to an address book
tap to navigate down a menu
In one embodiment, the various motions to command relationships are registered in the database of commands 215. In one embodiment, the system comes with a list of command pre-registered. In one embodiment, the user may add additional commands to the database 215. The commands may include invoking/starting an application, navigation within an application, terminating an application.
Shake detection logic 220 receives the accelerometer data and attempts to identify a command associated with the data. In one embodiment, the command may be to open an application, turn on a device, turn off a device, navigate a menu, or any other command applicable to a mobile device. In one embodiment, if the system includes
Invoked command ID logic 222 determines which command, if any, is being invoked. In one embodiment, if various sets of shakes may invoke separate commands (i.e. two shakes invoking a first command, while three shakes invokes a second command) the logic 222 determines the termination of the sequence of motions prior to identifying the command being invoked. Thus, for example, upon detecting a first shake, the command ID logic 222 determines if there is further motion indicating that a 2nd shake is about to occur. Therefore, matching is performed when that 2nd (or 3rd, or 4th) shake or motion is successfully identified, and the motion terminates.
Once the invoked command is identified, the invoked application is identified by the called application identification logic (CAIL) 225. The application may be a user interface application, such as a dial pad for dialing a telephone, contact list, answering a telephone, or any other application.
Application Halt logic 230 utilizing the identified application to determine which, if any, other running applications may conflict with the newly invoked application. For example, a phone application may conflict with a music player because the user cannot simultaneously listen to music and a telephone conversation. Similarly, a game may conflict with any other application since the user cannot pay attention to both the game and the newly invoked application. In one embodiment, the Halt logic 230 determines if the application needs to be terminated or suspended/paused. Applications that actually interfere with the ability to execute the invoked program are terminated. Applications that do not interfere with the ability to execute the program, but cannot be simultaneously used by the user, are paused in one embodiment. In one embodiment, for applications that cannot maintain their state while paused, and for applications which are terminated, the application halt logic 230 stores the state in state storage 235. In one embodiment, sufficient state data is stored to enable the re-starting of the application and if possible returning to the same state as prior to the termination/halt.
In one embodiment, if the application is not a problem, but it uses bandwidth, and the newly invoked application also requires bandwidth availability, bandwidth logic 240 throttles the bandwidth available to the other applications. For example, if the user is downloading something off the Web, while invoking a telephone application, the download speed may be throttled to ensure that adequate bandwidth is available for the phone application. In one embodiment, throttling means reducing the available bandwidth to zero.
The application is then started by application start logic 270.
Invoked application monitor 260 monitors the use of the application. When the application is no longer used, for example when the user hangs up the telephone, invoked application monitor notifies the restoration logic 250. Restoration logic 250 restores the previously halted/terminated applications, and the bandwidth availability. Thus, in one embodiment, restoration logic 250 returns the device to its state prior to the invocation of the application.
At block 310 the motion data is added to the buffer. In one embodiment, the data added to the buffer is the currently identified motions, rather than raw accelerometer data.
At block 315, the process determines whether an invocation command has been identified. In one embodiment, an invocation command is not identified until the motion is complete. Thus, for example, if the user is mid-movement and two shakes (a command) could be identified, the system waits until the motion stops, so ensure that the user is not attempting to finish a three-shake command. If the command is not recognizable, or the movement has not stopped, the process continues to block 310 to continue buffering accelerometer data.
At block 320, the command is identified.
At block 325, the currently running applications are identified. In one embodiment, the system may separately identify necessary applications (operating system, applications necessary to enable the use of the invoked application, bandwidth using applications, high CPU-using applications, etc. In one embodiment, only those applications known as conflicting are identified. In one embodiment, the user may designate applications as conflicting. In one embodiment, the system automatically identifies applications that utilize resources necessary for the invoked application as conflicting. In one embodiment, the system comes pre-programmed with a list of applications which may be conflicting with an invoked application.
At block 330, the process determines whether any applications should be halted. Halting applications, in one embodiment, includes terminating, pausing, and suspending applications. If so, at block 335, the identified applications are halted. The process then continues to block 340.
At block 340, the process determines whether the invoked application requires high bandwidth. If so, at block 345, the bandwidth available to other applications is reduced. In one embodiment, this is done on a per-application basis. In one embodiment, any active application which uses a lot of bandwidth is disconnected from the network.
At block 335, the application itself is invoked. As noted above, this may include opening a dial pad on a phone, answering a call on a phone, opening a contact list on a phone, opening a calendar item, opening a mapping program with or without GPS (global positioning system) support, etc. In one embodiment, the user may at this point use motion-based navigation to navigate within the application. In one embodiment, the user may, at any time, invoke another application. Thus, for example, the user may first open an address book via invocation, then realize that he doesn't have a number in there, and open the dial pad via invocation.
At block 360, the process determines whether the invoked application is done. In one embodiment, the user may close the application. In one embodiment, the invoked process (making a phone call, answering a phone call) is terminated in other known ways. When the application is ended, in one embodiment at block 365 the halted applications are restored to their prior state. In one embodiment, this may include opening prior applications. At block 370, if appropriate, the bandwidth settings are reset to their prior state. The process then ends. In one embodiment, the restoration may be a nested process, that is, if multiple applications were invoked in a series, the restoration returns to the previously invoked application. In another embodiment, the restoration returns to the original pre-invocation state for the device.
In this way, the system permits a user to simply and quickly invoke an application, regardless of where in the menu structure and available applications the user is currently. Furthermore, the system ensures that other open applications do not conflict with the invoked application, or do not take away sufficient bandwidth to interfere with the invoked application.
In the foregoing specification, the invention has been described with reference to specific exemplary embodiments thereof. It will, however, be evident that various modifications and changes may be made thereto without departing from the broader spirit and scope of the invention as set forth in the appended claims. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.
Kahn, Philippe, Kinsolving, Arthur
Patent | Priority | Assignee | Title |
10031772, | Aug 26 2014 | ADVANCED NEW TECHNOLOGIES CO , LTD | Method and apparatus for managing background application |
10191556, | Jan 06 2011 | BlackBerry Limited | Electronic device and method of displaying information in response to a gesture |
10481788, | Jan 06 2011 | BlackBerry Limited | Electronic device and method of providing visual notification of a received communication |
10649538, | Jan 06 2011 | BlackBerry Limited | Electronic device and method of displaying information in response to a gesture |
10884618, | Jan 06 2011 | BlackBerry Limited | Electronic device and method of providing visual notification of a received communication |
11379115, | Jan 06 2011 | BlackBerry Limited | Electronic device and method of providing visual notification of a received communication |
11698723, | Jan 06 2011 | BlackBerry Limited | Electronic device and method of providing visual notification of a received communication |
8689146, | Feb 28 2011 | BlackBerry Limited | Electronic device and method of displaying information in response to input |
8726198, | Jan 23 2012 | Malikie Innovations Limited | Electronic device and method of controlling a display |
8872646, | Oct 08 2008 | UNILOC LUXEMBOURG S A | Method and system for waking up a device due to motion |
9015641, | Feb 28 2011 | BlackBerry Limited | Electronic device and method of providing visual notification of a received communication |
9058168, | Jan 23 2012 | Malikie Innovations Limited | Electronic device and method of controlling a display |
9423878, | Feb 28 2011 | BlackBerry Limited | Electronic device and method of displaying information in response to a gesture |
9465440, | Feb 28 2011 | BlackBerry Limited | Electronic device and method of displaying information in response to a gesture |
9471145, | Dec 01 2011 | BlackBerry Limited | Electronic device and method of displaying information in response to a gesture |
9477311, | Jan 06 2011 | BlackBerry Limited | Electronic device and method of displaying information in response to a gesture |
9507495, | Apr 03 2013 | Malikie Innovations Limited | Electronic device and method of displaying information in response to a gesture |
9619038, | Jan 23 2012 | Malikie Innovations Limited | Electronic device and method of displaying a cover image and an application image from a low power condition |
9684378, | Jan 06 2011 | BlackBerry Limited | Electronic device and method of displaying information in response to a gesture |
9690476, | Mar 14 2013 | Malikie Innovations Limited | Electronic device and method of displaying information in response to a gesture |
9766718, | Feb 28 2011 | BlackBerry Limited | Electronic device and method of displaying information in response to input |
9766802, | Feb 28 2011 | BlackBerry Limited | Electronic device and method of providing visual notification of a received communication |
9798580, | Aug 26 2014 | ADVANCED NEW TECHNOLOGIES CO , LTD | Method and apparatus for managing background application |
9801004, | Jun 29 2012 | Intel Corporation | Device, method, and system for securely pairing mobile communication devices using movement |
Patent | Priority | Assignee | Title |
5161226, | May 10 1991 | JMI SOFTWARE SYSTEMS, INC | Microprocessor inverse processor state usage |
5375161, | Sep 14 1984 | Wilmington Trust, National Association, as Administrative Agent | Telephone control system with branch routing |
5428772, | Oct 01 1991 | PTC INC | Data processing system providing user interaction in multiple natural languages |
5610970, | Sep 14 1984 | Wilmington Trust, National Association, as Administrative Agent | Telephone system with scheduled handling of calls |
5673299, | Sep 14 1984 | Wilmington Trust, National Association, as Administrative Agent | Adjunct controller for a telephone system |
6013007, | Mar 26 1998 | Philips North America LLC | Athlete's GPS-based performance monitor |
6122360, | Feb 10 1997 | Genesys Telecommunications Laboratories, Inc. | Negotiated routing in telephony systems |
6822635, | Jan 19 2000 | Immersion Corporation | Haptic interface for laptop computers and other portable devices |
7010332, | Feb 21 2000 | Unwired Planet, LLC | Wireless headset with automatic power control |
7031728, | Sep 21 2004 | AGIS HOLDINGS, INC ; AGIS SOFTWARE DEVELOPMENT LLC | Cellular phone/PDA communication system |
7190263, | Sep 20 2004 | Google Technology Holdings LLC | Utilizing a portable electronic device to detect motion |
7489297, | May 11 2004 | GOOGLE LLC | Method for displaying information and information display system |
7499725, | Jul 29 2003 | LENOVO INNOVATIONS LIMITED HONG KONG | Mobile terminal having recording function |
7689232, | Sep 21 2004 | AGIS HOLDINGS, INC ; AGIS SOFTWARE DEVELOPMENT LLC | Method of providing call forward of voice and messages and remote phone activation |
20050232404, | |||
20070125852, | |||
20070190979, | |||
20080165022, | |||
20090048001, | |||
20090088204, | |||
20090124196, | |||
20090191850, | |||
20090262074, | |||
20100067434, | |||
20100214216, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Jul 18 2008 | DP TECHNOLOGIES, INC. | (assignment on the face of the patent) | / | |||
Sep 29 2008 | KAHN, PHILIPPE | FULLPOWER TECHNOLOGIES, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 021615 | /0169 | |
Sep 29 2008 | KINSOLVING, ARTHUR | FULLPOWER TECHNOLOGIES, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 021615 | /0169 | |
Nov 24 2008 | FULLPOWER TECHNOLOGIES, INC | DP TECHNOLOGIES, INC | NUNC PRO TUNC ASSIGNMENT SEE DOCUMENT FOR DETAILS | 021973 | /0517 |
Date | Maintenance Fee Events |
Sep 02 2015 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Sep 02 2019 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Sep 20 2023 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Mar 20 2015 | 4 years fee payment window open |
Sep 20 2015 | 6 months grace period start (w surcharge) |
Mar 20 2016 | patent expiry (for year 4) |
Mar 20 2018 | 2 years to revive unintentionally abandoned end. (for year 4) |
Mar 20 2019 | 8 years fee payment window open |
Sep 20 2019 | 6 months grace period start (w surcharge) |
Mar 20 2020 | patent expiry (for year 8) |
Mar 20 2022 | 2 years to revive unintentionally abandoned end. (for year 8) |
Mar 20 2023 | 12 years fee payment window open |
Sep 20 2023 | 6 months grace period start (w surcharge) |
Mar 20 2024 | patent expiry (for year 12) |
Mar 20 2026 | 2 years to revive unintentionally abandoned end. (for year 12) |