This application relates to handheld communication devices, and in particular to a method for automatically determining the availability status of a user of a handheld communication device.
There are handheld communication device applications in which updated user availability status information is important. Instant messaging is a good example of such an application. A user expects answers mostly in real time (unlike SMS, for example), so it is critical to know other party's availability status at the time when the user sends his or her instant message. Most instant messaging allow the user to explicitly set his or her availability status. Most such applications also provide an implicit way for the client application to say whether the user is available or not. Usually the user availability status is changed by a desktop application based on whether the keyboard has remained idle for a certain period of time. However, this approach is not relevant for some handheld communication devices, such as when the device is in its holster, for example. The user may be actually available for responses, and just in a waiting mode, with the device idle. The implicit or automatic approach that is used by a desktop client is therefore not applicable to such devices.
In view of the above, it is an object of embodiments herein to provide an improved method for determining the availability status of a user of a handheld communication device.
Thus according to an aspect herein, a method is provided for automatically determining user availability status. Various selected conditions of the device may be checked, which imply whether or not the user is likely Available, or else Unavailable.
According to a further aspect, preferably the selected conditions are checked only if the user has not explicitly or semi-explicitly set his or her status to Unavailable. In such a case, checking would be clearly redundant, since the user has clearly indicated a desire to override any automatic determination.
The conditions to be checked can vary widely, but generally include anything from which it might be inferred or implied that the user is likely either Available or Unavailable. Such conditions can include, for example, whether or not a specified timeout for use of a keypad, trackwheel or other mechanical feature of the device has elapsed yet; whether or not a real-time application is in use (a phone or games application, for example); and preferably any one or more of a variety of other conditions, one further example being whether or not there are any unattended-to notifications such as an unanswered phone call, or a missed e-mail, SMS or other message.
Further aspects will be described or will become apparent in the course of the following detailed description.
Throughout this specification, the terms Available and Unavailable are used for convenience. Of course it should be clearly understood that the terms used may vary among devices and from company to company within the industry, and the embodiments herein apply regardless of what actual terms are used to describe the states herein designated as Available and Unavailable. Without limiting the generality of the foregoing, alternative expressions such as “busy” or “unreachable” or “inaccessible” could be used, for example.
Aspects and embodiments will now be described with reference to the accompanying drawings, in which:
In the
In
Preferably the method first checks at box 21 to see if the elapsed time from last use of a keyboard or trackwheel or possibly some other mechanical feature of the device is greater than some defined timeout, 15 to 30 minutes for example. If not, then the user availability status is set to or left at Available, i.e. he or she is considered to be Available in view of current or recent use of the device.
If the timeout has elapsed, then preferably the method next checks at box 22 to see if a real-time application such as a phone or game is in use. If so, the user availability status is set to or left at Available, i.e. he or she is considered to be likely Available, just temporarily occupied.
If there is no real-time application in use, then preferably the method next checks at box 23 for any one of a number of possible additional conditions which might indicate or imply that the user is Unavailable. For example, the method could check for any of the following:
It should be clearly understood that the above is a list of examples only, and the manner in which the method is applied may vary considerably. For some devices, some of the above options may not be applicable, or there may be some options available which are not listed. And for some devices, even if the options are available, a decision may be made that only one or a few options will be checked. For example, it may be decided just to check whether the timeout has elapsed, if so check whether a real-time application is in use, and if not check for any unattended-to notifications.
If one of the conditions checked for does indeed apply, then the user availability status is set to Unavailable at box 3. Otherwise, it is set to Available at box 5. In either event, the method then routes to the Check Later box 4.
Especially if it is decided that the system will be set up to check a number of conditions, it makes sense to first check if a real-time application is in use, as in the preceding. However, that is not strictly a requirement herein. It is merely preferable, before using resources to check for other conditions. In general, it makes sense, where there are multiple conditions to be checked, to check them in the order of highest probability, though not mandatory.
The consequences of the device being deemed Available or Unavailable depend on specific applications and specific implementations, and can vary. That is outside the scope of the application itself. The consequences can be established by either the user's device, or a peer device, or both of them. For example, the user might not be able to send a message to someone who is Unavailable, or, as another example, the user may still be able to send the message, but the peer device will not notify the user if the peer device is Unavailable. The behavior may be fixed, or preferably can be defined through user options.
Those who are knowledgeable in the field will appreciate that there may be obvious variations to the preceding. Accordingly, the invention is defined not by the above specific examples, but by the claims which follow.
This is a divisional of U.S. patent application Ser. No. 11/048,716, filed Feb. 3, 2005, which claims the benefit of Provisional Application No. 60/607,758, filed Sep. 8, 2004, the contents of all of which are expressly incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
60607758 | Sep 2004 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11048716 | Feb 2005 | US |
Child | 12354184 | US |