Data Synchronization Mechanism for Information Browsing Systems
Data objects are organized into attributes and can be acted upon using predefined actions and associated types to greatly simplify user accessibility to such data objects through the limited user interface and bandwidth capabilities of a mobile device. Each data object is associated with a numerical identifier such that the user can easily identify a data object of interest using the limited data entry capabilities of the typical mobile device.
This is a continuation of U.S. patent application Ser. No. 10/032,826, now U.S. Pat. No. 7,062,491.
FIELD OF THE INVENTIONThis invention relates to the field of data organization systems, and more specifically to a system for organizing information accessible to two or more information browsing devices.
BACKGROUNDThe growth of the Internet over the past few years has been tremendous—both in terms of the number of people accessing information through the Internet and in terms of the amount and nature of information available through the Internet. Information services now available on the Internet include driving directions between two addresses, nearly up-to-the-minute stock quotes, and directories of addresses and telephone numbers. In addition, the Internet has been a platform for offering a number of services including, for example, purchasing goods and services, making reservations at restaurants and hotels, purchasing airline tickets, and other services pertaining to vacations and travel generally.
The accessibility of such information and services to the typical user is greatly enhanced by organization of such information and user interface tools into multimedia documents known generally as Web pages. Such multimedia documents can include images, text, audio, motion video, and active computer instructions (e.g., JavaÔ scripts) to effectively and efficiently communicate information to the user and to provide intuitive and self-explanatory user interface mechanisms. In addition, such multimedia documents can refer to other multimedia documents to provide a hierarchical information structure to suit the specific informational needs of individual users. These tools, while conventional, provide a highly effective information browsing experience for the user.
The user's experience is frequently described as browsing or surfing since the user picks and chooses her way through the apparent sea of information to find her own path to her own information of interest. The descriptive terms of browsing and surfing seem particularly apt as broadband Internet access increases in popularity making the Internet user's experience a truly multimedia one.
If the general Internet is an apparent sea of information, accessing the Internet through a web-capable wireless telephone seems like a trickle of information by comparison. While many Internet-capable computer systems have screen resolutions of 1024 by 768 pixels or greater, 105-key keyboards, a pointing device such as a mouse or trackball, and sound capability; most Internet-capable wireless telephones are limited to just a few lines of just a few characters of alphanumeric text and input keypads of little more than a dozen keys. In addition, communications bandwidth of Internet-capable wireless telephones is also severely limited relative to the typical Internet-capable computer. If surfing in a sea aptly describes the typical user's experience through an Internet-capable computer, a typical user's experience in accessing information in an Internet-capable wireless telephone can sometimes feel like building a model ship in a bottle.
This limited browsing experience through mobile devices such as wireless telephones is exacerbated by the fact that the user is typically preoccupied with other activities while using the mobile device to browse information. Mobile devices derive their value primarily from their mobility and are therefore likely to be used when the user is preoccupied with other activities. Mobile devices are therefore frequently used with only one hand and in manners in which the user's physical control of the mobile device is otherwise compromised. As a result, mobile devices are not particularly well suited for handling large amounts of information and the user's interest is typically highly localized to a small amount of very specific information.
Of course, the great advantage of Internet access through a wireless telephone is the ability to access information of the apparent sea of information of the Internet while out and about—such as while commuting or while traveling away from home or while out shopping, for example. However, a better way to access information through an Internet-capable wireless telephone is highly desirable.
SUMMARY OF THE INVENTIONIn accordance with the present invention, a user of a base system such as a desktop computer system organizes information stored on a server system for subsequent access by the user through a mobile device such as a wireless telephone. The server system is coupled to both the base system and the mobile device through a wide area computer network such as the Internet, for example.
The user organizes information of interest using all the storage, bandwidth, multimedia, and user interface capabilities of a general purpose, modern computer system. Such information is gathered from local software applications on the base system such as personal information manager (PIM) programs or from any of a number of other computer systems through the wide area network. Thus, in accordance with the present invention, the user can use full bandwidth and full multimedia and user interface capabilities to navigate and collect information through the Internet for convenient, immediate, subsequent access through the mobile device.
When accessing the information through the mobile device, the server system provides a list of one or more data objects representing information previously gathered by the user, wherein each of the data objects can be accessed through the mobile device with a single user-interface gesture, e.g., by pressing a single key of a numeric keypad on the mobile device.
Each of the data objects stored by the server system representing information gathered and submitted by the user is associated with a data type according to which the content of each data object is organized into attributes and according to which actions are applicable to the data object. For example, information of a place type data object includes a name attribute, a street address attribute, a city attribute, a telephone number attribute, etc. Actions associated with a place type data object include initiating a telephone call to the telephone number of the place, getting driving directions to or from the address of the place, etc.
Some of the actions are performed by the mobile device. For example, initiating a telephone call in the mobile device uses data of the place object already displayed on the mobile device in conjunction with an initiate telephone call instruction performed by the mobile device. Others of the actions are performed primarily by the server system, using the mobile device primarily for user interface purposes. For example, in obtaining driving directions relative to a place object, the server system prompts the user, through the mobile device, to specify whether the place data object currently displayed is the origin or destination of the trip for which directions are sought and for another place which specifies the other end of the trip. The system server requests directions for the trip from a map server through a wide area network such as the Internet and formats the resulting driving directions for display on the user's mobile device and sends the formatted directions for such display.
Thus, while the Internet is generally very open-ended and users are free to meander about the virtual sea of information using apt multimedia-capable computer system and apt user input devices, a user is free to organize information gathered from the Internet or from her computer for storage in a number of predefined data types with associated actions such that the user's interaction with the Internet through a mobile device with limited display capabilities, limited bandwidth, and limited user input devices can be prearranged and customized by the user. Such improves dramatically the usability of Internet-capable mobile devices for the types of tasks they are likely to be used in an Internet context.
BRIEF DESCRIPTION OF THE DRAWINGS
FIGS. 10A-E show user authentication through a mobile device.
In accordance with the present invention, information accessible by an Internet-capable mobile device is gathered and organized using an Internet-capable computer. Thus, the full bandwidth, multimedia capabilities, and user interface efficiencies of a general purpose computer are used by the user to collect and organize specific information of interest and to make that specific information readily accessible through a mobile device with limited bandwidth, display, and user interface capabilities. In addition, actions are associated with and actionable upon the specific information to provide significant user interface leverage, i.e., allowing the user to process such specific information with very little interaction with the mobile device. To facilitate appreciation and understanding of the invention, a few aspects of information browsing in a wide area network 102 are briefly described.
Servers 104A-C are server computers which provide information and/or services through wide area network 102. In this illustrative embodiment, wide area network 102 is the Internet. Of course, while only three (3) servers 104A-C are shown, wide area network 102 can be coupled to many more servers. Servers 104A-C provide information and/or services through wide area network 102 to numerous users in a conventional and known manner. Servers 104A-C are conventional and are not described further herein.
A user accesses such information and/or services through a client computer system 106 which is similarly known and conventional. The user in this illustrative embodiment also uses a wireless telephone 110 which is capable of accessing information and/or services of servers 104A-C through wide area network using a wireless network gateway 108. Wireless telephone 110 and wireless network gateway 108 are known and conventional. In this illustrative embodiment, wireless telephone 110 implements the known and conventional Wireless Application Protocol (WAP) to access such information and/or services. Wireless telephone 110 can use other protocols for data communications as well, including the Short Message Service (SMS) protocol.
A pocket server 112 enables the user of client computer 106 and wireless telephone 110 to collect and organize information for later access through wireless telephone 110 in accordance with the present invention. Pocket server 112 is shown in greater detail in
Pocket server 112 includes a base system interface 202 for interacting with client computer 106 and other, similar Internet-capable computers of other users. Base system interface 202 serves requests from clients, such as client computer 106, which are presumed to have substantial data bandwidth capabilities, multimedia and presentation capabilities, and considerable user interface capabilities. In a manner described more completely below, the user of client computer 106 collects data through wide area network 102 (
One of the more significant advantages of Internet-capable wireless telephones, such as wireless telephone 110, is the ability to perform telephony actions upon data retrieved from the Internet. In addition, one of the more significant advantages of the Internet is the ability to tailor information retrieved from the Internet according to data entered by the user. To preserve these advantages, a number of actions, e.g., pocket item actions 208, are associated with various types of data received through base system interface 202. To determine which of actions 208 pertain to which data objects of pocket dataset 204, each data object stored in pocket dataset 204 is associated with one of pocket item types 206. Thus, pocket server 112 is able to distinguish an address from an airline flight reservation and different actions are associated with each.
Pocket dataset 204 for the subject user is shown in greater detail in
User configuration 302 is shown in greater detail in
User identifier 402 is an e-mail address of the subject user in this illustrative embodiment. Typically, this is the e-mail address through which the subject user is reachable through client computer 106 (
Password 404 is maintained in secrecy and is specified by the subject user, in combination with user identifier 402, for authentication purposes.
Mobile address 406 is a network address by which the subject user can receive data on wireless telephone 110. Typically, mobile address 406 is a telephone number by which wireless telephone 110 is reached. Mobile type 408 specifies the type of mobile system used by the subject user. Such types can include, for example, WAP wireless telephone, SMS (Short Message Service) wireless telephone, two-way alphanumeric pager, and personal digital assistant (PDA). Mobile service provider 410 specifies the organization which is responsible for delivering data to wireless telephone 110 (
Preferences 412 specify one or more preferences specified by the subject user. In this illustrative embodiment, a single user preference is supported. In particular, the user can specify whether adding a new data object 306 (
Landmarks 414 each specify a location which is frequently used by the subject user. Typically, one of landmarks 414 specify the user's home address and another specifies the user's work address. Landmarks 414 provide a particularly useful feature of the information management system according to the present invention. Since the raison d'etre of a mobile device is that it is mobile, location-oriented services through wide area network are particularly useful. However, such location-oriented services frequently require that an address is specified by the user. Since an address typically includes both numerical and alphanumerical data, specification of an address using only a numeric keypad of a mobile device is particularly tedious for a user. A numeric keypad is the sole input device for textual input in many mobile devices. Entering an address using a numeric keypad is particularly difficult if the user is distracted with other activities which is frequently the case for users of mobile devices. Allowing the user to enter and store frequently used locations as landmarks 414 greatly simplifies use of location-specific services as described more completely below.
Friends 416 each specify another user of the system implemented by pocket server 112. Like landmarks 414, friends 416 enable the user to use the full user interface capabilities of a general purpose computer such as client computer 106 to enter frequently contacted people with whom the subject user is likely to share information for easy subsequent retrieval or reference using wireless telephone 110 in a manner described more completely below.
Data object 306 (
Type 502 specifies one of pocket item types 206 (
Content 508 represents the substantive data of data object 306, i.e., the data intended to be accessible by the subject user through wireless telephone 110 (
Pocket item type 206 (
Identifier 602 uniquely identifies pocket item type 206 among all pocket item types supported by pocket server 112 (
Attribute definitions 604 define one or more attributes of data represented in content 508 (
Generally, data objects are added in a manner described below in which the associated data item type and the individual component attributes of the data object are individually specified unambiguously. However, a user can also create an object from copied text in a manner described below. As described more completely below, individual attributes are parsed from such bulk text when a user creates a new data object in this manner. Attribute pattern 608 maps bulk text to specific attributes defined by attribute definitions 604. Pocket server 112 (
Mobile system interface 210 (
Action engine 212 includes a number of action sets, e.g., action sets 652A-B, each of which (i) is associated with one or more conditions 654A-B and (ii) identifies one or more member actions of pocket item actions 208, e.g., pocket item actions 208A-C. Conditions 654A-B specifying whether action sets 652A-B, respectively, are applicable to a particular data object. For example, conditions 654A can specify that actions of action set 652A are applicable to users whose mobile service provider 410 (
Pocket item actions 208A-C are associated with respective conditions 656A-C, each of which specifies under what conditions the associated action applies. For example, if pocket item action 208A defines an initiate telephone call action, conditions 656A can specify that pocket item action 208A is only applicable for objects which include data in content 508 (
In gathering actions applicable to a particular data object, action engine 212 (at the request of mobile interface system 210—
Once an action set is determined by action engine 212 to be applicable, each member action of the applicable action set is evaluated to determine whether individual pocket item actions are applicable. For example, if action set 652B is determined by action engine 212 to be applicable, conditions 646A-C are individually evaluated to determine whether each of pocket item actions 208A-C, respectively, are applicable. More than one of pocket item actions 208A-C can be applicable. Action set 652B specifies a particular order of pocket item actions 208A-C to be presented to the user and that order is preserved in the listing of available actions to the user. Such presentation is described more completely below.
Object Collection and Organization Through the Base System Beginning with
The Web page of screen view 702 includes a link 704 by which the subject user is offered to place content 706 in her pocket. To facilitate an intuitive user experience, the analogy of a pocket is used. Essentially, the user is invited to make content 706 immediately accessible through wireless telephone 110 which can presumably be placed in the pocket of the subject user.
In this illustrative embodiment, content 706 is embedded in the URL to which link 704 points. URLs (Universal Resource Locators) are known and conventional and are only briefly described herein for completeness. A URL specifies a network address of a resource, such as a Web page for example, which can be accessed by the user solely by activating an associated link. In addition to specifying the location of a resource, a URL can include data to be provided to the resource. Specifically, the entirety of the URL is passed through the known and conventional Common Gateway Interface (CGI) and is available to a script invoked by the URL. The URL of link 704 includes data specifying a type of data object (an address in this illustrative embodiment) and content 706 parsed into attributes defined by that type. Specifically, the URL of link 704 includes, for each attributed defined by attribute definitions 604 (
Upon activation of link 704 by the subject user using conventional user interface techniques—typically involving physical manipulation of one or more user input devices and a single user interface gesture such as clicking on link 704, base system interface 202 (
In addition to a link embedded in a Web page, the subject user can cause data stored locally within client computer 106 to be made accessible through wireless telephone 110. For example, a Personal Information Management (PIM) process running within client computer 106 can store place information such as addresses and telephone numbers and can store notes of the subject user. In addition, such information is frequently organized in a structural manner, i.e., including attributes. Furthermore, since such PIM processes can be configured using a general purpose programming language with the full capabilities of client computer 106 available to such PIM processes, sending data organized into attributes defined by attribute definitions 604 (
In the same manner that link 704 (
Whether from a process or by activation of a link such as link 704 (
Upon clicking confirmation button 804, base system interface 202 (
Upon adding the newly created data object to object dataset 204, base system interface 202 sends a Web page to client computer 106 which results in screen view 822 (
As shown in
WML documents are briefly described to facilitate understanding and appreciation of the present invention. Since the display screens of most mobile devices are quite small and the bandwidth to and from most mobile devices is quite limited, more than one display is typically sent at one time. Each display is referred to as a card and the collection of cards defined by a single WML document is called a deck. Each card can include one or more links to other cards much like HTML documents can include hypertext links. Such WML links can be to cards within the same deck or within a different deck. Links to cards within the same deck are much like HTML links to anchors within the same HTML document containing the link. Users browsing the World Wide Web experience this routinely as a link within a particular Web page causes a different portion of the same Web page to be displayed. One difference however is that, while a user viewing a Web page in HTML can access all portions of the Web page, cards within a single deck are treated as distinct from one another and generally can only be viewed one at a time.
One advantage of WML decks is that related content can be organized into multiple views but transmitted to a mobile device in a single network transaction. WML decks are used in a manner described more completely below to send multiple views to the subject user in a single network transaction.
Upon initial contact with mobile system interface 210, the user of wireless telephone 110 is authenticated. Wireless telephone 110 contacts mobile system interface 210 by supplying a WAP URL which uniquely identifies mobile system interface 210 within wide area network 102 (
Wireless telephone 110 is shown in greater detail in
When the subject user presses key 1006 (
Mobile system interface 210 (
Authentication of the subject user is completed by requesting (by mobile system interface 210) that the user supply as associated password as shown in
As shown in
After authentication, if necessary according to the particular embodiment, the subject user is presented with a list of data objects in the user's pocket as shown in
When presented with the WML document resulting in the display of
According to WAP and the particular configuration of the WML document sent by mobile system interface 210, pressing of the “2” key (
The subject user can act upon the selected data object by pressing key 1006 which sends a message to mobile system interface 210 (
In response to the request for applicable actions, mobile system interface 210 retrieves applicable actions in conjunction with action engine 212 in the manner described above and presents the list of applicable actions to the user. To do this, mobile system interface 210 builds a WML document which identifies the applicable actions and provides the subject user with a—user interface mechanism to activate any of the applicable actions.
Each action in this illustrative embodiment includes both a short description and a collection of computer instructions and data defining behavior of the action. Each collection of computer instructions is designed to be performed either by mobile system interface 210 (
The call action, i.e., the action associated with the numeral “1” by which the subject user initiates a telephone call to the place, is performed by wireless telephone 110 and is therefore embodied in a WML script in the WML document resulting in the display shown in
In step 1402, wireless telephone 110 loads the voice telephone number of the current place data object. In constructing the WML script which defines the behavior of wireless telephone 110 in performing the call action, mobile system interface 210 retrieves the voice telephone number from the place object as defined by attribute definitions 604 (
In step 1404 of the WML script for the call action, wireless telephone 110 initiates a telephone call to the number loaded in step 1402. Thus, three user interface gestures are required to both select the current place from the subject user's pocket and to dial the associated telephone number. Specifically, pressing the numeral “2” key of keypad 1002 (
The subject user invokes the directions action of the current place object from the list of actions as shown in
In step 1602, mobile system interface 210 (
In step 1604, mobile system interface 210 queries the subject user for data specifying the other end of the trip. If the subject user has indicated that the current place is the destination of the trip, mobile system interface 210 sends a WML document to wireless telephone 110 querying the user for the origin of the trip as shown in
In step 1606 (
In step 1608 (
In an alternative embodiment, mobile system interface 210 (
Thus, by allowing the subject user to select from places previously collected through client computer 106 to specify both ends of the trip for which driving directions are sought, the subject user can get driving directions by applying just a few user interface gestures.
The subject user invokes the nearby places action of the current place object from the list of actions as shown in
In step 2002, mobile system interface 210 (
The resulting display of the WML document is shown in
In selecting the subcategory, the subject user invokes a link associated with the subcategory which communicates the category and subcategory to mobile system interface 210 (
Mobile system interface 210 receives the category and subcategory from the subject user in step 2004 (
In response to the directory search request, mobile system interface 210 receives a list of places in step 2008 (
The resulting display is shown in
It should also be noted that an extra action not associated with place objects of pocket dataset 204. In particular, the subject user can cause the selected place shown in
Thus, the nearby places action is quite powerful and requires only a few user interface gestures by the subject user to locate various types of establishments near a place of interest.
The preceding description pertains to data objects of the place type defined in this illustrative embodiment of the present invention. Other types of data objects defined in this illustrative embodiment include data objects representing flights, products, stocks, and notes.
Flight Objects Another type of data object specified in pocket item types 206 (
Box 2702 shows that the type of data object represented is a flight. This type can be specified in a URL activated by the subject user in the manner described above with respect to
In box 2704, a name of the flight data object is specified. The name of the flight data object identifies the data object to the subject user and should be distinct from names of other data objects in the pocket dataset associated with the user. The flight represented by the flight data object is sometimes referred to herein as the subject flight.
Boxes 2706-2714 represent the first or only leg of the subject flight. Additional boxes are provided for an optional second leg of the subject flight. Additional legs can also be specified.
The airline providing the first or only leg of the subject flight is specified in box 2706. Boxes 2708 specify the date of the first or only leg of the flight, and the flight number is specified in box 2710. Boxes 2712 and 2714 specify the origin and destination airports, respectively, of the first or only leg of the subject flight.
In response to submission of the information depicted in the HTML form of screen view 2700, base system interface 202 (i) creates a data object such as data object 306 (
Upon selection of the flight data object by the subject user, mobile system interface 210 (
Presentation of the WML deck causes the initial card representing the top-level menu to be displayed in display 1006 of wireless telephone 110 as shown in
Selection of the “Show Details” option activates a link to the details menu card of the WML deck, the results of which are shown in
Activation of the description option by the subject user activates a link referring to the flight details card resulting in the display shown in
Activation of the “[Actions]” option by the subject user activates a link referring to the actions menu card resulting in the display shown in
The call action is generally analogous to the call action described above with respect to place data objects with the exception that mobile system interface 210 retrieves the telephone number for the airline of the flight data object from previously stored contact information for those airlines supported by pocket server 112.
Both driving directions actions are generally analogous to the directions action for place data objects described above. However, instead of retrieving location information for the map server from a place data object, mobile system interface 210 (
In the action by which the subject user obtains driving directions relative to the airport of origin, mobile system interface 210 presumes that the airport of origin is the destination of the subject trip and allows the subject user to specify an origin of the subject trip, i.e., from where the subject user would like directions to the airport of origin. The user specifies the origin of the subject trip in the manner described above with respect to the directions action of place data objects, namely, by selecting a place from the user's pocket dataset 204 or by specifying an address or other location designation. In an alternative embodiment, mobile system interface 210 allows the user to specify that the airport of original for the subject flight is the origin of the subject trip such that the subject user can obtain directions from the airport of origin to another place. Such is useful if the subject user's flight has been delayed a significant amount of time and the subject user would like to leave the airport of original to get something to eat.
The action by which the subject user can obtain driving directions relative to the destination airport is analogous to the action by which the subject user can obtain driving directions relative to the airport of origin except that (i) the destination airport is one of the two locations defining the subject trip and (ii) the destination airport is presumed to be the origin of the subject trip in this illustrative embodiment. In an alternative embodiment, the subject user is free to specify that the destination airport is the destination of the subject trip and to specify a different origin of the subject trip.
In performing the action which updates flight information for the subject flight, mobile system interface 210 submits data representing the airline and flight number of the subject flight to an airline reservation server through wide area network 102. Airline reservation servers are well-known and conventional and are not described further herein. Any of servers 104A-C can be an airline reservation server. In response to the data representing the airline and flight number, mobile system interface 210 receives updated information regarding the scheduled time of departure and, in some embodiments, gate information for the subject flight.
Upon receiving the updated flight information, mobile system interface 210 constructs a new WML deck which includes the updated flight information and sends the new WML deck to wireless telephone 110 for display to the subject user. In this illustrative embodiment, the new WML deck is configured such that the subject user initially sees the flight details card as shown in
Thus, the most common things a person wants to know about a flight are made immediately accessible to the subject user through wireless telephone 110. Specifically, the subject user has immediate and easy access to such information as (i) a voice conversation with the airline of the subject flight, (ii) directions to the airport of origin, (iii) directions from the destination airport, and (iv) updated flight information. It should also be noted that this information comes from different servers through wide area network 102. For example, driving directions can be provided by a different server controlled by a different entity than that which provides updated flight information. In addition, the accessibility of this information is significantly enhanced by the ability to use previously entered places to define trips for which directions are sought.
Stock Objects Pocket item types 206 (
Box 3402 (
One feature of data object management by pocket server 112 is worth noting. Pocket server 112 organizes data objects for each user according to the date most recently accessed. Navigating lists which span several screens in a mobile device such as wireless telephone 110 is a considerable inconvenience. Accordingly, pocket server 112 assumes that those data objects most recently accessed by the subject user, whether through client computer 106 or through wireless telephone 110, are most likely to be the next accessed data objects. Therefore, pocket server 112 sorts data objects in pocket dataset 204 for the subject user from most recently accessed to least recently accessed.
This feature is illustrated by screen view 3500 (
The subject user selects a stock data object from a list of data objects in the user's pocket dataset in the manner described above for other data objects. In response, mobile system interface 210 (
Upon receipt of the updated stock information, mobile system interface 210 (
Upon confirmation by the subject user that this updated information has been read, a navigation card of the WML deck is presented to the user as shown in
For stock data objects, an update quote action is defined. The update quote action is performed by mobile system interface 210 on behalf of wireless telephone 110. In performing the update quote action, mobile system interface 210 again queries a stock server for updated information on the subject stock in the manner described above and re-constructs the WML deck in the manner described above. Mobile system interface 210 sends the re-constructed WML deck, which includes freshly updated stock information, to wireless telephone 110 for display to the subject user in the manner described above. From the perspective of the subject user, invocation of the update quote action returns the subject user to the display shown in
Thus, using all the user interface conveniences of client computer 106, the subject user can create stock data objects for each of a number of stocks of interest and subsequently access current information about those stock which significant ease. With a single key press, the user can retrieve a stock data object representing a particular stock. With two key presses—one to access the actions menu and another to invoke the update quote action—the subject user can get newly updated information about the stock.
Product Data Objects Pocket item types 206 (
The subject user can specify data corresponding to attributes defined by attribute definitions 604 (
Box 3802 (
Box 3814 includes a more detailed textual description of the subject product. Box 3816 includes any notes the subject user wishes to add to the product data object. Upon pressing confirmation button 3818 by the subject user, base system interface 202 receives the HTML form data shown in
Further illustrating sorting by pocket server 112, the newly added product data object is most recently accessed by either client computer 106 or wireless telephone 110 and is there listed first as shown in screen view 3900 (
When mobile system interface 210 (
Upon acknowledging reading of the detailed information in display 1004 (
In addition, a find nearest action is defined for product data objects. The find nearest action is similar to the nearby places action defined for place data objects as described above. Briefly, the subject user, by invoking the find nearest action, is requesting nearby places of a category and subcategory associated with the product subtype. Within the product type definition, pocket server 112 maintains data associating each product subtype with both a directory category and a subcategory. In performing the find nearest action associated with product data objects, mobile system interface 210 queries a directory server as described above in conjunction with the nearby places action, supplying the associated place category and subcategory associated with the current product data object.
As described above, such a request for nearby places is for places near a place of reference. In the find nearest action for product data objects, the point of reference is supplied by the subject user. In a manner analogous to that described above with respect to specification by the subject user of a location defining a trip for which driving directions are sought, the subject user specifies a current location relative to which nearby sources for the subject product are sought. Such includes, for example, identifying a place object with the pocket dataset of the subject user, identifying either airport in a flight data object, or specifying a location explicitly such as by an address or latitude/longitude coordinates.
When mobile system interface 210 receives the list of nearby places from the directory server, mobile system interface 210 constructs a WML deck which includes the nearest places received and sends the WML deck to wireless telephone 110 for presentation to the subject user in the manner described above with respect to
A folder data object is a data object whose content 508 (
By representing folders using data objects, the ability to associate actions in the manner described above is also applicable to folders. For example, the subject user can send the folder for a particular trip to a friend 416 (
In addition, a hierarchy of data objects can be specified in a single URL such as the one described above with respect to link 704 (
As described above in conjunction with
Occasionally, the subject user will want to include a data object pertaining to information found on wide area network 102 that is not pre-configured for direct input to pocket server 112 as a data object ready for storage in the subject user's dataset 204. Accordingly, pocket server 112 helps automate this process by recognizing attributes of data object types in text selected by the subject user.
Screen view 4200 (
Selection of option 4206 sends selected text 4202 to base system interface 202 (
In this illustrative example, the subject user intents selected text 4202 (
In response to indication by the subject user that the newly created data object should be a place data object, base system interface 202 retrieves an attribute pattern 606 (
Once text body 4302 (
Thus, the user can easily and quickly add new data objects based on data found in Web pages or other documents not otherwise prepared for automatic creation of pocket data objects.
Tracking of Browsing by the Subject User As described above, access of a particular data object by the subject user moves that data object to the beginning of the list of data objects in the pocket dataset 204 of the subject user. In this illustrative embodiment, base system interface 202 updates access time 506 (
In this illustrative embodiment, the subject user does not need to explicitly view a data object in her pocket dataset 204 to move that data object to the beginning of the list of data objects. Mere viewing of a Web page in which the substance of the data object is represented is sufficient.
To illustrate this feature, it is helpful to consider the example of the subject user's visiting the Web page shown in screen view 702 (
In this illustrative example, the Web page of screen view 702 is served by a server such as any of servers 104A-C. In this illustrative example, this Web page is served by server 104A. In serving the Web page, server 104A stores a document which defines the content of screen view 702 in HTML (Hyper-Text Markup Language) and presents the document in response to a request for the document in the form of a URL identifying the document. Such a URL includes identification of server 104A as the server for the Web page defining screen view 702. Such identification is typically a domain name or an Internet Protocol (IP) address.
HTML documents are well-known and conventional. However, to facilitate appreciation and understanding of the present invention, certain aspects of HTML documents are described briefly herein. It is common for HTML document to include other embedded documents. In fact, since HTML is a textual language and HTML document include only text, all images, sounds, and active scripts in Web pages are defined by separate documents which are included in the HTML document by reference—by the URL of the embedded separate document. Such embedded documents can be served by a different server than the server serving in the embedding HTML document. In this illustrative example, photograph 708 (
When the subject user requests the Web page of screen view 702 by use of the URL thereof, client computer 106 sends the URL through wide area network 102 to server 104A. Server 104A responds by sending the HTML document of the Web page. In displaying the Web page, client computer 106 encounters the embedded URL for photograph 708 and sends the photograph URL through wide area network 102 to server 104B which responds by sending a data file which represents photograph 708. Until the subject user activates link 704, pocket server 112 normally has no awareness of or interaction with client computer 106 or servers 104A-B related to the viewing of the Web page by the subject user.
However, the Web page shown in screen view 702 is configured to inform pocket server 112 of the fact that the subject user has visited the Web page of screen view 702. In particular, the HTML document defining the Web page of screen view 702 includes an embedded item served by pocket server 112 such that pocket server 112 is involved in the display of the Web page of screen view 702. Specifically, a single pixel 710 which is the same color as the background of the subject Web page is served by pocket server 112.
In addition to making pocket server 112 aware of the display of the Web page, pocket server 112 is notified as to the particular user displaying the Web page and the particular pocket data object associated with the Web page. To inform pocket server 112 as to which Web page is being displayed, both link 704 and 710 include the URL of the Web page of screen view 702 embedded therein. When pocket server 112 stores a data object as a result of activation of link 704, pocket server 112 receives the URL of the Web page of screen view 702 and associates the URL with the stored data object. Accordingly, the URL of the Web page of screen view 702 can be used by pocket server 112 to identify which of the data object within pocket datasets 204 (
To identify the subject user as the particular user browsing the Web page of screen view 702, pocket server 112 uses a cookie. Cookies and their use are known and conventional. Briefly, a cookie is a unique identifier by which a server recognizes a previously served client. The first time the subject user views the Web page of screen view 702, there is no cookie placed there by pocket server 112. Accordingly, pocket server 112 does not recognize the user. Pocket server 112 stores a cookie on client computer 106 such that subsequent views of the Web page of screen view 702 enable recognition of the subject user by pocket server 112. In this illustrative embodiment, the subject user places the place data object represented by link 704 in the pocket dataset associated with the subject user in the manner described above in this first visit.
When the subject user subsequently visits the Web page of screen view 702, the embedded pixel 710 informs pocket server 112 of the viewing of the Web page. In serving embedded pixel 710, pocket server 112 retrieves the cookie identifying the subject user. Accordingly, pocket server 112 knows the identity of both the subject user and the place data object described in the viewed Web page.
As a result of the subject user's visit to this Web page, pocket server 112 assumes that the described data object was viewed by the subject user, albeit served by a different server through wide area network 102. Pocket server 112 therefore updates the order in which data objects are presented to the subject user, through both client computer 106 and wireless telephone 110.
Thus, by merely viewing the Web page of screen view 702, the data object representing place data 706 is the first item listed when subsequently accessed through wireless telephone 110. In essence, the subject user's pocket dataset 204 is perpetually updated to reflect items determined to be of interest to the subject user—even when the subject user is not directly interacting with pocket server 112.
Thus, a mechanism is provided by which pocket server 112 is notified when data associated with a particular data object is accessed by a particular user. It should be appreciated that different levels of access can be notified. For example, pocket server 112 can be notified in the manner described above when substantive content 706 (
Mobile system interface 210 (
Having users moving about with complete access to a vast, wide area network such as the Internet provides advertisers with a tremendous opportunity to grant access to their products and services. However, much advertising is through mass media when the targeted customers are not using or near their computers.
The data objects described herein, being organized into attributes on which actions can act, provide a convenient, orderly access point for users of mobile devices to access the vast amount of information available through Internet-capable mobile devices. In addition, typical WAP URLs—being alphanumeric—are particularly difficult to enter using the typical numeric keypad 1002 available with most mobile devices.
Accordingly, pocket server 112 allows data objects such as data object 306 to be stored independently of any user and associated with a numerical identifier. Accordingly, a data object representing a restaurant—with all the attributes individually specified and all relevant actions properly defined—can be pre-created and stored within pocket server 112 and associated with a numerical identifier. The restaurant can be advertised on television, radio, billboards, in airports and train stations, in newspapers, etc.—all places which compete for customers' attention when the customer is away from her computer.
If a customer is interested in the restaurant, the customer can—through wireless telephone 110 which is immediately accessible to the customer while out and about—select a “Pocket by Number” action and provide the numerical identifier. Since the identifier is numerical, the customer can readily enter it using the numerical keypad 1002 of the typical mobile device. Even mobile devices such as PDAs which support textual input have difficulty with punctuation and other symbols typically included in URLs—WAP or otherwise. Accordingly, the simplicity of numerical identifiers significantly improves the ease with which the user can specify the identifier in these other forms of mobile devices.
Thus, the customer has access to the restaurant in the form of its name, address, an auto-dial action, driving directions, directories of nearby places, etc. all by entering several digits of a numerical identifier of the restaurant. Such represents tremendous economy in the amount of user effort compared to the amount of useful information obtained by such effort in a mobile information platform.
The above description is illustrative only and the present invention is defined solely by the claims which follow and their full range of equivalents.
Claims
1. A method for facilitating access to previously stored information on a computer network by a user of a mobile device, the method comprising:
- receiving data representing the information from a data provider through a base system interface;
- storing a data object representing the data in a database;
- associating the data object with the user within the database;
- associating the data object with a selected one of two or more data object types wherein the selected data object type specifies the type of the data object;
- receiving a request from the user for retrieval of the data through a mobile system interface; and
- sending the data to the user through the mobile system interface in accordance with one or more data attributes defined for the selected data object type;
- wherein the request is entered by the user through a mobile device coupled to the mobile system interface.
2. The method of claim 1 wherein each of the data object types is associated with a type identifier.
3. The method of claim 1 further comprising:
- parsing the data into one or more portions, each of which corresponds to the one or more data attributes defined for the selected data object type; and
- wherein storing the data object includes storing the one or more portions organized according to the data attributes defined for the selected data object type.
4. The method of claim 3 wherein the parsing is according to an attribute pattern specified for the selected data object type.
5. The method of claim 1 wherein sending comprises:
- sending the data along with one or more user interface triggers by which the user can invoke one or more respectively associated actions defined for the selected data object type to be taken with respect to the data.
6. The method of claim 5 wherein a selected one of the actions is to be performed by a mobile device used by the user to request the data.
7. The method of claim 6 wherein the selected action has a behavior defined by one or more instructions to be performed by the mobile device; and
- further wherein sending the data to the user includes sending the instructions with the data.
8. The method of claim 5 wherein a selected one of the actions is accessible to the user only if the selected data object type of the data object is one of one or more acceptable ones of the two or more data object types.
9. The method of claim 5 wherein performance of a selected one of the actions acts upon one or more of the data attributes of the data object.
10. The method of claim 5 wherein a selected one of the actions is accessible to the user depending upon user data representing characteristics of the user.
11. The method of claim 10 wherein the user data includes specification of a mobile data services provider.
12. A computer readable medium useful in association with a computer which includes a processor and a memory, the computer readable medium including computer instructions which are configured to cause the computer to facilitate access to previously stored information on a computer network by a user of a mobile device by:
- receiving data representing the information from a data provider through a base system interface;
- storing a data object representing the data in a database;
- associating the data object with the user within the database;
- associating the data object with a selected one of two or more data object types wherein the selected data object type specifies the type of the data object;
- receiving a request from the user for retrieval of the data through a mobile system interface; and
- sending the data to the user through the mobile system interface in accordance with one or more data attributes defined for the selected data object type;
- wherein the request is entered by the user through a mobile device coupled to the mobile system interface.
13. The computer readable medium of claim 12 wherein each of the data object types is associated with a type identifier.
14. The computer readable medium of claim 12 wherein the computer instructions are configured to cause the computer to facilitate access to previously stored information on a computer network by a user of a mobile device by also:
- parsing the data into one or more portions, each of which corresponds to the one or more data attributes defined for the selected data object type; and
- wherein storing the data object includes storing the one or more portions organized according to the data attributes defined for the selected data object type.
15. The computer readable medium of claim 14 wherein the parsing is according to an attribute pattern specified for the selected data object type.
16. The computer readable medium of claim 12 wherein sending comprises:
- sending the data along with one or more user interface triggers by which the user can invoke one or more respectively associated actions defined for the selected data object type to be taken with respect to the data.
17. The computer readable medium of claim 16 wherein a selected one of the actions is to be performed by a mobile device used by the user to request the data.
18. The computer readable medium of claim 17 wherein the selected action has a behavior defined by one or more instructions to be performed by the mobile device; and
- further wherein sending the data to the user includes sending the instructions with the data.
19. The computer readable medium of claim 16 wherein a selected one of the actions is accessible to the user only if the selected data object type of the data object is one of one or more acceptable ones of the two or more data object types.
20. The computer readable medium of claim 16 wherein performance of a selected one of the actions acts upon one or more of the data attributes of the data object.
21. The computer readable medium of claim 16 wherein a selected one of the actions is accessible to the user depending upon user data representing characteristics of the user.
22. The computer readable medium of claim 21 wherein the user data includes specification of a mobile data services provider.
23. A computer system comprising:
- a processor;
- a memory operatively coupled to the processor; and
- a mobile data access module (i) which executes in the processor from the memory and (ii) which, when executed by the processor, causes the computer to facilitate access to previously stored information on a computer network by a user of a mobile device by: receiving data representing the information from a data provider through a base system interface; storing a data object representing the data in a database; associating the data object with the user within the database; associating the data object with a selected one of two or more data object types wherein the selected data object type specifies the type of the data object; receiving a request from the user for retrieval of the data through a mobile system interface; and sending the data to the user through the mobile system interface in accordance with one or more data attributes defined for the selected data object type; wherein the request is entered by the user through a mobile device coupled to the mobile system interface.
24. The computer system of claim 23 wherein each of the data object types is associated with a type identifier.
25. The computer system of claim 23 wherein the mobile data access module is configured to cause the computer to facilitate access to previously stored information on a computer network by a user of a mobile device by also:
- parsing the data into one or more portions, each of which corresponds to the one or more data attributes defined for the selected data object type; and
- wherein storing the data object includes storing the one or more portions organized according to the data attributes defined for the selected data object type.
26. The computer system of claim 25 wherein the parsing is according to an attribute pattern specified for the selected data object type.
27. The computer system of claim 23 wherein sending comprises:
- sending the data along with one or more user interface triggers by which the user can invoke one or more respectively associated actions defined for the selected data object type to be taken with respect to the data.
28. The computer system of claim 27 wherein a selected one of the actions is to be performed by a mobile device used by the user to request the data.
29. The computer system of claim 28 wherein the selected action has a behavior defined by one or more instructions to be performed by the mobile device; and
- further wherein sending the data to the user includes sending the instructions with the data.
30. The computer system of claim 27 wherein a selected one of the actions is accessible to the user only if the selected data object type of the data object is one of one or more acceptable ones of the two or more data object types.
31. The computer system of claim 27 wherein performance of a selected one of the actions acts upon one or more of the data attributes of the data object.
32. The computer system of claim 27 wherein a selected one of the actions is accessible to the user depending upon user data representing characteristics of the user.
33. The computer system of claim 32 wherein the user data includes specification of a mobile data services provider.
Type: Application
Filed: Jun 7, 2006
Publication Date: Sep 28, 2006
Inventors: John McNulty (Oakland, CA), James Sullivan (San Francisco, CA), Jonathan Sheena (Oakland, CA), Ajit George (San Francisco, CA)
Application Number: 11/422,848
International Classification: G06F 15/16 (20060101);