I. Field of the Invention
This invention generally relates to computer networks and wireless communications. More specifically, the present invention relates to managing remote applications in a wireless communications network where threshold events occur during the execution of the applications.
II. Description of the Related Art
Mobile communications devices, such as the cellular telephones and personal digital assistants, have computer platforms capable of providing more services than simple voice or data communications services. Extant mobile telephones can receive “short messages,” such as paging messages, or electronic mails. A mobile telephone can also act as a web browser, enabling users to surf the Internet. The processor of current mobile devices typically manages any resident applications, and the device processor will solely execute the application and not interact with a server or other computer device on the wireless network.
In existing wireless networks, unidirectional communications are common, with an example being a short message downloaded from a server to a mobile device, such as a page or email. These unidirectional communications generally use a limited amount of the expensive bandwidth of the cellular network. Bidirectional communications are then reserved for voice calls between parties on the network.
It is also known to have a multiple user environment and a substantially real-time interaction between personal computer devices on a wire-based LAN or the Internet. Such interaction typically occurs either through, or in selective communication with, a server on the Internet or LAN, and the server can store records of the multiple user interactions for whatever purpose the host desires, such as application management, gathering marketing data, and dissemination of software patches and updates. However, such application interaction and management has been unnecessary and impractical in wireless devices due to the bandwidth constraint and lack of a multi-user interactive environment.
Accordingly, it would be advantageous to provide a system and method that allows remote application management on remote and mobile computer devices in a wireless network. It is thus to the provision of such a system and method that the present invention is primarily directed.
The present invention is a system, method and program for providing interactive games or applications among multiple users located in different geographical locations, wherein the system manages the applications depending threshold events occurring in the applications. Such threshold events can occur for individual users or a collective group of users in a shared application.
The system includes a server connected to a wireless communications network, and optionally a database accessible by the server. The server communicates with a plurality of wireless communications devices, such as mobile telephones or other hand-held devices, through the wireless communications network. One or more users can start an application by connecting to the server and selecting an application. The server identifies the user through identification information associated with the hand held device and retrieves the appropriate level or access or applications available for the one or more users. The server can also send out an invitation for other users who are identified teammates for the user, or can acquire other users for a multi-user environment if so desired. If the application involves an opponent, the server can send a list of opponents and let the user to choose an opponent. After the user has chosen an opponent, the server can send out an invitation to the opponent and sets up the application between the two parties.
In one embodiment, the server selects applications available to the user according to the user's previous application data, such as score achieved or duration of use of application. The server thus compares the application data to determine if a threshold event has been reached by that user or group of users, and if the threshold event has been reached, the server can alter the application present at the user, provide a different level of access to the user, or otherwise record the event having been reached. A server or other database tracks and stores the application event data for the user or group for a particular remotely used application, thus eliminating the possibility of the threshold data being tampered with by the user.
In another embodiment, the server executes the selected application with display information sent to the screens on each mobile communications device, with each user inputting data from his mobile communications device, and the inputs are transmitted from the mobile device to the server through the wireless communications network. The server takes the inputs and incorporates them into the application. The output from the application is broadcasted by the server to each hand held device for display with the server tracking the events of the multi-user interaction.
In an alternate embodiment, the selected application can be downloaded to each mobile device and executed thereon. In this embodiment, the user enters input and the mobile device executes the input locally and also transmits the application data to a server on the network. In such manner, a server-side user can determine threshold events occurring at a single mobile device.
The system, method, and program therefore provide an advantage in managing applications on the remote mobile devices, and controlling access to server-side application and provide benefits to users through the server-side determination of threshold events. The invention can be used with one or a team of users of a common application on the devices, which is thus scalable to a multi-user application. And because the application data for the mobile device is at least maintained on the server-side, the data is secure from user tampering.
Other objects, advantages, and features of the present invention will become apparent after review of the hereinafter set forth Brief Description of the Drawings, Detailed Description of the Invention, and the claims.
In this description, the terms “game” and “application” are used interchangeably; “score” and “threshold event” are used interchangeably; and like numerals refer to like elements throughout the several views. As technologies for third generation (3G) wireless communications mature, more and more service providers are beginning to update the data rate and communication capabilities of wireless networks. With 3G technology, transmission speed can be boosted up to 2.4 million bits per second (mbps) in a fixed environment or 500 kilo bits per second (kbps) in a mobile environment. This increase of the transmission speed provides more bandwidth for mobile communications as well as other mobile applications that can communicate data between other mobile and fixed computer devices across the wireless network.
Mobile communications devices, such as the cellular telephones and personal digital assistants, have computer platforms capable of providing more services than simple voice or data communications services. A 3G mobile telephone can act as a web browser, enabling users to surf the Internet, or connect to servers and download software applications. With higher data rates possible in 3G cellular telephone networks, very rapid unidirectional or bidirectional communication is possible that can allow an interactive computer session with multiple users. Such interactive sessions can include games or other computer applications that require the mobile units to engage in significant data downloading and uploading during application execution.
This increase of bandwidth in the wireless communications network permits interactive applications with graphics display to be played among several users, in addition to providing normal telecommunications services among these users. A wireless communications network 100 shown in
The data from each user is sent from the communication tower 102 to a base station (BS) 104, and forwarded to a mobile switching center (MSC) 108, which may be connected to a public switched telephone network (PSTN) 110. The MSC 108 sends the data to a server 112 that may connect directly to the MSC 108 or to the PSTN 110.
The server 112 executes an application, which may be a special computer program that analyzes the data and provides a response accordingly. The response can be a graphical display, a command, or a data. The response is broadcasted to one or more users through the wireless communications network 100.
The application executed by the server 112 may have an architecture 200 shown in the block diagram of
An alternate embodiment of the architecture 300 is shown in the block diagram of
The applet on the server, block 304, is also responsible for tracking scores or threshold events and accessing application data on the database, block 204. When a user at communication device 1 scores against the other user at communication device 2, the score or the event is transmitted from the communication device 1 to the server. The applet at the server receives the score, or the event, and broadcasts it to communication device 2. At the end of the application, the applet stores the score or event information in the server-side database 204. By storing scoring information in the database 204, the system prevents possible score tampering by the users. The score or other threshold data, such as duration of application usage or other criteria of application usage, can be stored on the database whereby the network host can provide special serves to the user (s) of the application, such as advanced application availability, contest entry, application updates, or other benefits provided to a user(s) upon the occurrence of a threshold event.
After sending the identification information, the communication device 106 receives a menu tailored to the user, block 404, and displays it on a display screen on the communication device 106. The menu received by the communication device can change depending on the user. The menu may be a list of applications available to the user and can include a list of levels. The user's access to more advanced levels depends on the user's past performance at lower levels, and the user's score at a lower level is stored preferably in the database 204. For applications that do not involve prizes or competitions, the user's score may be stored locally at the communication device 106.
The user can select an application from the menu, block 406, and if there are multiple levels for the selected application, the user can also select an application level. However, in a multiple level application, the server 112 may automatically determine the application level. The server 112 determines the application level by retrieving the user's score associated with such application and comparing the score with a score table. The result of the comparison determines the level that the user should play. Thus, if the user achieves a threshold event of duration of play, the advanced game application can be served to the user's communication device 106.
After the user selects the application, the selection is sent to the server 112, block 408, and the server 112 will dispatch the application to the communication device 106 for execution. The communication device 106 receives the application, block 410, and executes the application, block 412. The application execution at the communication device is further explained in
After the user makes a selection, the server receives the selection, block 506, and retrieves the user's score from the database, block 508. The score is associated with each application and stored in the database. The server compares the user's score with a score table to determine whether the user is qualified to play the application or to play the application at certain level, block 510. The server then selects an application based on the score, block 512, and dispatches the application to the communication device 106, block 514.
If the application selected is a team application, i.e., involves more than one user and communication device 106, then the server can inquire the user for information about other teammates, and then invites the teammates, block 518. The invitation can occur from locating and sending a message to other communication devices 106 that have indicated they wish to play a team game when members are available. The teammate information may also be stored in the database, and the server can retrieve it from the database before inviting them.
If the application selected is a competition application, i.e., involves opponents, then the server may retrieve an opponent list from the database and send the opponent list to the communication device, block 522. The opponent list can be predefined by all users who have played this application previously or can be predefined by the user. After the user selects the opponent, who may be an individual or a team of several people, the server receives the opponent selection and invites the opponent, block 526.
When the teammates and/or the opponents have accepted the invitation, the server broadcasts the application to each one of them, block 528, and the server executes the application or its applet, block 530. At the end of the application, the server stores the score and application information in the database, block 532.
The communication device 106 also checks for commands from the server, block 608. When commands are received from the server, the communication device 106 executes them, block 610. The execution of commands may include updating screen displays, producing audio effects, or other effects that the communication device 106 is equipped to do. The communication device 106 executes the steps shown in
After the server broadcasts the commands to the communication devices, the server 112 stores the score, block 538, in its internal register. The score is stored to the database when the application is ended. The server 112 executes the steps shown in
In addition to coordinating actions among communication devices 106 and tracking the score or other threshold data, the server 112 may also be responsible for billing. The users may be billed for the access time or per application basis.
The system can thus execute a multiple user competition application, where multiple teams compete against each other. For example, a user may choose to select a basketball game against another team. When the user connects to the server 112, his identification information, such as the ESN of his hand held device, is sent to the server 112. The server 112 validates his identification information against a database to ensure the user has the permission to access its services. As part of validation, the server may also ask the user to enter a PIN.
After making sure that the user has the permission to access its services, the server 112 provides a menu of games for the user to select from. The user selects the basketball game, and the selection is sent to the server. The server 112 checks if the user belongs to a predefined team, and if the user does belong to a team, the server 112 sends invitations to his teammates. The server 112 also checks the previous score obtained by the user's team and selects a list of opponents. The list of opponents is sent to the user, and the user can select one opponent team. After the opponent team is selected, the server 112 sends the invitation to the members of the opponent team.
With all the team members and the opponents in place, the server 112 then broadcasts the game to all the participants. Each communication device 106 receives a copy of the game and executes it locally. The screen display is controlled locally from the output of the game relayed by the server 112.
During the game, inputs from each user is executed locally and also uploaded to the server. After receiving the inputs from a user, the server broadcasts them to all the players in the same game. When the communication devices 106 receive the inputs, each device executes the inputs and updates its screen accordingly. For example, if user 1 inputs a jump shot, his communication device 106 executes the jump shoot and uploads the jump shot with all the supporting information to the server 112. The supporting information may include user's location, angle of jump shot, force of jump shot, etc. The jump shot, with all the supporting information, is received by the server 112 and broadcasted by the server to all the communication devices 106. Each device executes the jump shot and if the jump shot is good, then every communication device shows the jump shot as points to user's team. The server 112 keeps track of the score during the game by receiving information from the communication devices 106. At the end of the game, the server 112 stores the score in the database, and the score will be available next time the user chooses the basketball game.
While the invention has been particularly shown and described with several embodiments thereof, it will be understood by those skilled in the art that various changes in form and detail maybe made without departing from the spirit and scope of the present invention as set for the in the following claims. Furthermore, although elements of the invention may be described or claimed in the singular, the plural is contemplated unless limitation to the singular is explicitly stated.
Number | Name | Date | Kind |
---|---|---|---|
5218631 | Katz | Jun 1993 | A |
5285494 | Sprecher et al. | Feb 1994 | A |
5618045 | Kagan et al. | Apr 1997 | A |
5999808 | LaDue | Dec 1999 | A |
6024640 | Walker et al. | Feb 2000 | A |
6115680 | Coffee et al. | Sep 2000 | A |
6141565 | Feuerstein et al. | Oct 2000 | A |
6233449 | Glitho et al. | May 2001 | B1 |
6397256 | Chan et al. | May 2002 | B1 |
6405034 | Tijerino | Jun 2002 | B1 |
6434398 | Inselberg | Aug 2002 | B1 |
6527641 | Sinclair et al. | Mar 2003 | B1 |
6561809 | Lynch et al. | May 2003 | B1 |
6585598 | Nguyen et al. | Jul 2003 | B2 |
6628939 | Paulsen | Sep 2003 | B2 |
6650892 | Thiriet | Nov 2003 | B1 |
6712702 | Goldberg et al. | Mar 2004 | B2 |
6735435 | Newell et al. | May 2004 | B2 |
6745011 | Hendrickson et al. | Jun 2004 | B1 |
6760595 | Inselberg | Jul 2004 | B2 |
6778820 | Tendler | Aug 2004 | B2 |
6792269 | Boehmke | Sep 2004 | B2 |
6893347 | Zilliacus et al. | May 2005 | B1 |
6939233 | Emmerson | Sep 2005 | B2 |
6947761 | Hutcheson et al. | Sep 2005 | B2 |
6985721 | Khorram | Jan 2006 | B1 |
6993577 | Shavit et al. | Jan 2006 | B2 |
6996444 | Ach, III | Feb 2006 | B2 |
7029394 | Leen et al. | Apr 2006 | B2 |
7103356 | Pawlas | Sep 2006 | B2 |
20010036825 | Martin | Nov 2001 | A1 |
20020095427 | Kaplan | Jul 2002 | A1 |
20020142759 | Newell et al. | Oct 2002 | A1 |
20030087652 | Simon et al. | May 2003 | A1 |
20040005926 | LeFroy | Jan 2004 | A1 |
Number | Date | Country |
---|---|---|
1322429 | Nov 2001 | CN |
0032410 | Jul 1981 | EP |
1124368 | Aug 2001 | EP |
1229701 | Aug 2002 | EP |
10-240493 | Sep 1998 | JP |
11-122202 | Apr 1999 | JP |
11-203127 | Jul 1999 | JP |
2000-350801 | Dec 2000 | JP |
2001-27552 | Jan 2001 | JP |
2001-327749 | Nov 2001 | JP |
2002-27552 | Feb 2002 | JP |
2002-177651 | Jun 2002 | JP |
2004-512767 | Apr 2004 | JP |
2095112 | Nov 1997 | RU |
2102790 | Jan 1998 | RU |
2160970 | Dec 2000 | RU |
02035769 | Feb 2002 | WO |
WO0211347 | Feb 2002 | WO |
02017250 | May 2002 | WO |
Number | Date | Country | |
---|---|---|---|
20040002326 A1 | Jan 2004 | US |