U.S. Pat. No. 8,062,130
ALLOWING AN ALTERNATIVE ACTION IN A VIRTUAL WORLD
AssigneeActivision Publishing Inc
Issue DateNovember 16, 2007
Illustrative Figure
Abstract
A method for allowing an alternative action in a virtual world may include permitting a user to request an original action for an avatar of the user in the virtual world. The method may also include receiving the request for the original action and storing the request in a queue in response to the original action being unavailable to the user's avatar. The method may additionally include determining if an alternative action is available for the user's avatar in response to the original action being unavailable to the user's avatar and presenting an interface to the user to permit the user to accept the alternative action in response to the alternative action being available. The method may yet further include allowing the user's avatar to perform the alternative action in response to the user accepting the alternative action and permitting the user's avatar to perform the alternative action while the request for the original action is still in the queue.
Description
DETAILED DESCRIPTION OF THE INVENTION The following detailed description of embodiments refers to the accompanying drawings, which illustrate specific embodiments of the invention. Other embodiments having different structures and operations do not depart from the scope of the present invention. As will be appreciated by one of skill in the art, the present invention may be embodied as a method, system, or computer program product. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, the present invention may take the form of a computer program product on a computer-usable storage medium having computer-usable program code embodied in the medium. Any suitable computer usable or computer readable medium may be utilized. The computer-usable or computer-readable medium may be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium. More specific examples (a non-exhaustive list) of the computer-readable medium would include the following: an electrical connection having one or more wires, a tangible medium such as a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), or other tangible optical or magnetic storage device; or transmission media such as those supporting the Internet or an intranet. Note that the computer-usable or computer-readable medium could even be paper or another suitable medium upon which the program is printed, as the program can be electronically captured, via, for instance, optical scanning of the paper or other medium, then compiled, interpreted, or otherwise ...
DETAILED DESCRIPTION OF THE INVENTION
The following detailed description of embodiments refers to the accompanying drawings, which illustrate specific embodiments of the invention. Other embodiments having different structures and operations do not depart from the scope of the present invention.
As will be appreciated by one of skill in the art, the present invention may be embodied as a method, system, or computer program product. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, the present invention may take the form of a computer program product on a computer-usable storage medium having computer-usable program code embodied in the medium.
Any suitable computer usable or computer readable medium may be utilized. The computer-usable or computer-readable medium may be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium. More specific examples (a non-exhaustive list) of the computer-readable medium would include the following: an electrical connection having one or more wires, a tangible medium such as a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), or other tangible optical or magnetic storage device; or transmission media such as those supporting the Internet or an intranet. Note that the computer-usable or computer-readable medium could even be paper or another suitable medium upon which the program is printed, as the program can be electronically captured, via, for instance, optical scanning of the paper or other medium, then compiled, interpreted, or otherwise processed in a suitable manner, if necessary, and then stored in a computer memory. In the context of this document, a computer-usable or computer-readable medium may be any medium that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device. The computer-usable medium may include a propagated data signal with the computer-usable program code embodied therewith, either in baseband or as part of a carrier wave. The computer usable program code may be transmitted using any appropriate medium, including but not limited to the Internet, wireline, optical fiber cable, radio frequency (RF) or other means.
Computer program code for carrying out operations of the present invention may be written in an object oriented programming language such as Java, Smalltalk, C++ or the like. However, the computer program code for carrying out operations of the present invention may also be written in conventional procedural programming languages, such as the “C” programming language or similar programming languages, or in functional programming languages, such as Haskell, Standard Meta Language (SML) or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
The present invention is described below with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
These computer program instructions may also be stored in a computer-readable memory that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory produce an article of manufacture including instruction means which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide steps for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
FIGS. 1A and 1B(collectivelyFIG. 1) are a flow chart of an example of a method100for satisfying a request for an action in a virtual world in accordance with an embodiment of the present invention. In block101, a user102may desire that the user's avatar access a feature or an action in the virtual world. An action may include any action in a virtual world that an avatar may perform or which may be performed for an avatar. Examples of an action may include, but are not limited to, transporting the avatar to a specific location (e.g., taking a virtual trip or vacation), performing a service for the avatar (e.g. buying tickets for a concert, attending a concert, buying goods/services from a store, interacting with a concierge desk, interacting with a sales representative, and the like), etc.
In block103, one or more predetermined GUIs may be presented to a user102for the user102to select the action for the avatar to perform. The GUI presented to the user102may be automatically displayed to the user102in response to the avatar triggering some stimulus in the virtual world, or the GUI may be displayed based on some input by the user102, such as the user102pressing certain keys or clicking on an icon.
In block104, once the GUI is presented to the user102, the user102may then request the action or actions to be performed for the avatar. This may include entering information in the GUI. Alternatively, if no GUI has been presented, an action for the avatar may be requested solely in response to triggering some stimulus in the virtual world and thus a GUI would not be necessary. For example, if an avatar would like to request entry to a retail store in the virtual world, the avatar could open the door and enter the virtual store without a GUI being presented to ask the user if the user would like to request this service.
In block106, a determination may be made whether the requested action is available. Once the request for an action is entered by the user102, the request may be sent to a server or some other processing equipment. The server will process the request and determine whether or not the requested action is available, or whether the action is unavailable for some reason, such as the requested action is at full capacity. For example, the server will locate the action that is requested and determine what the capacity of that action is. The capacity of the action may be set by a variable in computer software code associated with the requested action. The server will determine if the capacity is at its maximum threshold limit.
If a determination is made in block106that the requested action is available or that the capacity for the selected action is not at its maximum threshold limit, the method100may advance to block108. In block108, the requested action may be performed for the avatar. The capacity of the action may then be incremented accordingly.
Conversely, if a determination is made in block106that the capacity of the action is at its maximum threshold limit or for some other reason is unavailable, the method100may advance to block110and the user's request may be placed in a queue. When placed in the queue, the user's request is assigned a priority. Each user's request has a priority according to the order in which the request is received. Once the capacity of the requested action is first lower than the maximum threshold limit, the queue is processed to allow the avatar in the queue with the highest priority (i.e. the avatar who had the earliest request) access to the requested action.
In block112a notification may be generated to advise the user102that the requested action is not available and that the user's request has been placed in the queue. The notification may also advise the user102that she will not lose her place in the queue until further notice. The notification may further advise the user102that the user's avatar may perform other actions in the virtual world without losing the user's priority in the queue, so long as the user's original request remains in the queue. The notification may be presented visually or any other way, such as a synthesized voice or other type indication, to alert and advise the user102. The notification may additionally present an option for the user102to remove the request from the queue at any time that the user102exercises such option. The option may be presented to the user102in a GUI and the option to remove the request from the queue may be selected by the user102depressing certain keys on a computer keyboard, clicking an icon or other feature in the GUI using a computer pointing device or by other means. The notification may also be presented to the user102immediately after the action is deemed to be unavailable for the avatar. Optionally, while the user's request remains in the queue, the notification may be displayed periodically or constantly to the user to remind the user102that her request is in the queue. For example, a small window, icon or the like may be presented in the corner of a computer screen, in a tool bar, banner, or elsewhere on the screen or display. Other information may be provided with the notification, such as the user's priority in the queue, an approximate time until the action may become available, other actions that are similar to the requested action or similar information related to the requested action.
The user102may also be notified as to what position or priority her request is in the queue, especially when an active avatar is removed from the requested action. This may be accomplished by presenting the user102a notification every time an active avatar stops performing or completes the requested action. Alternatively, the user102could be constantly updated as to what position or priority in the queue the user102has by displaying a priority notification constantly (or periodically) on the screen until the user102is removed from the queue.
In block114, after the user's request is placed in the queue, a server or some other processing equipment may then determine alternative actions for the user. These alternative actions could be any actions in the virtual world. By way of example, the alternative actions could be actions that are related in some way to the originally unavailable action, actions that could be preselected by the provider of the originally unavailable action so as to leverage partnerships, actions that could be preselected by other providers, etc. For example, if an avatar tries to go to a Circuit City® that is full, the user may be presented with a Sony® location because Sony® and Circuit City® have a partnership or because the avatar is looking for a Sony® camera. By way of another example, while an avatar waits in a virtual line for Rolling Stones concert tickets, the user may be offered preselected transports to other virtual recordings of artists under the same label or to band related sites that the band is promoting.
The alternative actions may be determined by any factors, such as avatar demographics, user searches (Internet searches, searches within the virtual world or similar searches), previous user requests for actions, preselected alternative actions, or other factors. Avatar demographics, such as race, age, income, disabilities, mobility (in terms of travel time to work or number of vehicles available), educational attainment, home ownership, hobbies, marital status, employment status, location, and the like, may be used as one or more factors to determine what alternative action will most likely be of interest to that avatar. For example, an avatar that is a 30 year old single male may be interested in dating services or local bars/clubs near his home. Also, previous user requests may also be a factor in determining alternative actions. For example, if a user has frequently requested entering a gym, the user's avatar could be offered access to the gym as an alternative action while the user waits for another action to become available. Another factor for determining an alternative action could be a previous user searches. If a user has repeatedly searched for a particular action, that may be an action that the user may be interested in and thus, may be presented to the user as an alternative action. Additionally, providers of unavailable or overloaded actions may preselect alternative actions for the user in the case that their action become unavailable or overloaded. For example, if a user's avatar desires to go to Wal-mart® but it is unavailable for the user's avatar, Wal-mart® may have preselected alternative locations, such as Sams Club®, a store owned by Wal-mart, to transport the user to.
Another factor that may be used to determine an alternative action may be the relevance to the requested action. If the requested action is unavailable or overloaded, another action that is related to the requested action may be presented as an alternative to fulfill the desire of the user's avatar. For example, if the user desires to go bowling, but the requested bowling alley is full, the user may be presented other bowling alleys or maybe even other recreational facilities, such as a pool hall, any of which is related to the original requested action in some sense. The alternative action only has to be related to the requested action in some manner. The relevance factors may be anything about the action, including the type of the action, the geographical location of the action, the services or products provided by the action, the type of avatars that request the action, the advantages of the action, any of the features of the action, etc. In the above example, the pool hall is related to the bowling alley because both activities are recreational activities or both are indoor games.
If an alternative action is determined to be relevant to the requested action, the alternative action may be ranked according to its relevance to the requested action. The more common factors the alternative action has with respect to the requested action, the higher the ranking of the alternative action will be given. For example, in the previous example, the pool hall will receive a high ranking. The pool hall has several common factors with the bowling alley, such as being a recreational activity, a game that may be played with one or more players, an indoor game, a game that may be played at night, a game that does not involve a whole lot of physical exertion, etc. Thus, since many factors match, this would receive a high ranking, maybe being displayed as a 90% ranking. This ranking may or may not be displayed for the user102as it could only be an option.
Additionally, after each alternative action is determined, the alternative actions may be ranked or prioritized with respect to the other alternative actions. The factors to consider in ranking or setting a priority for each alternative action may be based on how relevant each alternative action is to the requested action. For example, in the above example, another bowling alley may rank higher than the pool hall because a bowling alley has many more commonalities to another bowling alley than does a pool hall.
In block115, a GUI is presented to the user to allow the user102to select the alternative action or to select one of a plurality of alternative actions, if more than one is available. This GUI may be presented to the user102immediately after the user102is notified that the requested action is unavailable. Furthermore, this GUI may not only provide the user102with an alternative action or alternative actions that the user102may select, but may also include marketing or advertising information or present other relevant information to the user102.
As shown in block116, after the GUI is presented to the user102, the user102may make a decision whether or not to select the alternative action or one of the plurality of alternative actions presented in the GUI. If the user102does not select any of the alternative actions, then the method100may advance to block117. Optionally, the user102may be given a certain predetermined time to accept one of the alternative actions. If the user102does not select an alternative action within the predetermined time, the method100may advance to block117.
In block117, the user's avatar may remain in the queue until the originally requested action becomes available. During this time, the avatar may be allowed to perform other operations in the virtual world. This allows the avatar to continue exploring the virtual world while still waiting for the request for the original action to be processed. This also allows service providers, such as virtual stores, virtual consultants, virtual support, etc., to provide better service with minimal negative impact to the customers.
Alternatively, if the user accepts the alternative action or selects any of the alternative actions, the method100may advance to block118. In block118, the user102is sent a notification stating that the user102will not lose her place in the queue for the originally request action. In block120, the user's avatar is allowed to perform the alternative action while the user's request for the original action is still in the queue.
The present invention is not necessarily limited to the avatar being placed in only one queue if multiple actions that the user requests are unavailable. Many times numerous actions that the user requests may also be unavailable and therefore, the user may be in multiple queues while still exploring the virtual world.
In block121, a determination may be made if the originally requested action becomes available for the avatar. Continual checks may be performed to determine if the requested action's capacity is below the maximum threshold value or for some other reason the requested action has become available, such as a maintenance or repair issue has been resolved. If the originally requested action is still unavailable in decision block121, then the method100may return to block120. The method100may loop from block120to block121until the original requested action becomes available or the user102removes her request from the queue. The method100may advance to block122in response to the original requested action becoming available in block121.
When the capacity drops below the maximum threshold limit for the requested action or the requested action otherwise becomes available, the requested action becomes available for the avatar in the queue having the highest priority, as described above with reference to block110. In block122, a notification that the requested action has become available may be sent to the user102associated with the avatar. Such notification may inform the user102that the originally requested action is now available for the avatar and that a spot in the requested action is being held for the avatar for a predetermined time period (e.g. one minute, five minutes, etc.). The user102will then have the predetermined time period to accept the requested action.
In block123, a determination may be made whether the user102has accepted the original action within the predetermined time limit or period. If the user102has not accepted the originally requested action within the predetermined time period, the method100may advance to block124. In block124, the user's originally requested action for the avatar will be dropped from the queue. The user's avatar may continue to perform the alternative action chosen by the user102. Alternatively, the user102may not accept the originally requested action by either rejecting the offer to accept the requested action or by simply not responding within the predetermined time.
If the user accepts the originally requested action in block123, the method100may advance to block126. In block126, the user's avatar is allowed to perform the requested action and the user's request for the requested action is then dropped from the queue. Additionally, the user's avatar may stop performing any other actions, including any alternative actions, in the virtual world chosen by the user while in the queue so that the avatar can perform the originally requested action. However, if the avatar is performing another action, including any alternative action, while waiting for the requested action to become available, the user102may desire to continue the other action before accepting the requested action. Thus, when the requested action becomes available and the avatar is performing another action, a GUI may be presented to the user102for accepting the originally requested action that may include an option to delay acceptance of the requested action or commencement of the requested action for a chosen time period or until the user102is finished performing the other action. Accordingly, when the avatar is finished performing the other action, including any alternative action, the user102may then reactivate the acceptance GUI and accept the originally requested action. Accepting the originally requested action would then drop the request from the queue and allow the user's avatar to perform the originally requested action. In accordance with an aspect of the present invention, if the user's avatar does not finish the other actions within the chosen time period, the user's originally requested action may be dropped from the queue and the user's avatar would simply continue performing the other action.
In accordance with another aspect of the invention, the GUI presented to the user102for accepting the originally requested action may also include an option for the user102to reset the user's request to a lower priority in the queue. The user's request may be remove from the queue and then reinserted in the queue at a lower priority. When the user's request for the original action becomes available, the method100may then return to block123.
FIG. 2is a block schematic diagram of an example of a system200for allowing an alternative action in a virtual world in response to a requested action being unavailable in accordance with an embodiment of the present invention. The system200may include a module202for allowing an alternative action in a virtual world in response to a requested action being unavailable (hereinafter “alternative action module202”). The method100may be embodied in or performed by the alternative action module202.
The alternative action module202may be part of a virtual world simulation system or program, such as Second Life™ or similar virtual world system. The alternative action module202may also be a self contained system with embedded logic, decision making, state based operations and other functions that may operate in conjunction with a virtual world simulation, such as Second Life™. The self contained system may allow businesses, individuals, services, locations, and the like in the virtual world to interact with the avatar while the avatar is waiting for another action to become available.
The alternative action module202may be stored on a file system205or memory of a server206or other suitable data processing equipment. The alternative action module202may be accessed by a plurality of users207, similar to user102inFIG. 1, or participants via a network208using an Internet browser on a personal computer210or by similar means. The network208may be the Internet, a private network or other network.
The alternative action module202may present one or more predetermined graphical user interfaces220, similar to the GUIs described with respect to the method100, to permit satisfying a request for an action, such as a virtual location, goods, services or other actions, for a user's avatar in a virtual world or simulation.
The GUIs220may include a GUI to present one or more alternative actions for a user's avatar in response to an original requested action being unavailable, similar to that previously described. The user may continue to perform a selected alternative action in the virtual world while waiting for an originally requested action to become available. The predetermined GUIs220may be generated by the alternative action module202as described herein and may be presented on a display212of the personal computer210to the user207.
The alternative action module202may also include a queue216. The queue216is where the request for an action may be stored when an availability determination module218determines that a request for a particular action has exceeded capacity (maximum threshold limit) or is not available for some reason. Each request may be assigned a priority based on when the request was received and also each request is associated with the action requested. The earlier the request is received, the higher the priority that is assigned to the request. When a requested action has less than the maximum capacity or is available and there are requests in the queue216for the action, the highest priority request for the action will be removed from the queue216and the avatar associated with that request will be given access to the action.
The alternative action module202may also include an acceptance module219. Portions of the method100inFIGS. 1A and 1Bmay be embodied in the acceptance module219. The acceptance module219may present GUIs to the user207to inform the user207of the requested action's availability and to permit the user207to accept or rejected the requested action. Internet communications technologies or applications, such as Local Chat, Instant Messaging, e-mail, or similar communications means, may be used to permit informing the user207of availability and acceptance or non-acceptance of the request by the user207.
The alternative action module202may also include an alternative actions determination module217. The alternative actions determination module217determines what alternative actions may be available for presentation to the user207. The alternative actions determination module217may select and retrieve any of the alternative actions from a database224. Additionally, any of the alternative actions may be preselected, stored in the database224and then retrieved by the alternative actions determination module217.
In determining the alternative actions, the alternative actions determination module217may take into account the unavailable requested action and information relative to the avatar similar to that previously described with respect to block114inFIG. 1. The alternative actions may be ranked based on certain criteria and presented to the user207in a ranked fashion. For example, the alternative actions may be ranked based on a relevance to the unavailable requested action. This may provide the user207with the closest alternative options to the requested action. Also, in determining the alternative actions, the avatar's profile may be taken into account or any other information related to the avatar. For example, the alternative actions determination module217may take into account the avatar's demographics or the avatar's previous requested actions to determine what alternative actions the avatar may be interested in. This caters the alternative actions to each individual avatar.
The alternative action module202may further include an options feature222. The options feature222may include any future enhancements, configurations, and extensions to the existing system or any additions relating to the alternative action module202. As an example, a notification system221could be added to the alternative action module202which could be configured as an option to email updates or provide notification by some other mechanism.
The system200may also include a database224, server, or other mechanism to store actions and to present any requested actions in response to being requested by any of the users207for the respective user's avatar. As previously discussed, the actions may include, but are not necessarily limited to different locations that may be visited by avatars corresponding to the users207or participants, different services that may be provided to a user's avatar or other actions. Additionally, preselected alternative actions, information about avatars, previous request actions by avatars, or any other virtual information may be stored in the database224.
The flowcharts and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems which perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
Although specific embodiments have been illustrated and described herein, those of ordinary skill in the art appreciate that any arrangement which is calculated to achieve the same purpose may be substituted for the specific embodiments shown and that the invention has other applications in other environments. This application is intended to cover any adaptations or variations of the present invention. The following claims are in no way intended to limit the scope of the invention to the specific embodiments described herein.
Claims
- A method for allowing an alternative action in a virtual world, comprising: permitting a user to request an original action for an avatar of the user in the virtual world;receiving the request for the original action;storing the request in a queue in response to the original action being unavailable to the user's avatar;determining, using a computer, if an alternative action is available for the user's avatar in response to the original action being unavailable to the user's avatar;presenting an interface to the user to permit the user to accept the alternative action in response to the alternative action being available;allowing the user's avatar to perform the alternative action in response to the user accepting the alternative action;and permitting the user's avatar to perform the alternative action while the request for the original action is still in the queue.
- The method of claim 1 , further comprising: determining if the original action becomes available for the user's avatar;providing a graphical user interface to the user to allow the user to accept the original action in response to the original action becoming available for the user's avatar;and allowing the user's avatar to perform the original action in response to the user accepting the original action.
- The method of claim 2 , further comprising allowing the user's avatar to continue to perform the alternative action in response to the user not accepting the original action when the original action became available.
- The method of claim 2 , further comprising: providing a predetermined time period for the user to accept the original action in response to the original action being available;and dropping the user's request from the queue in response to the user not accepting the original action within the predetermined time period.
- The method of claim 1 , further comprising providing a predetermined time period for the user to accept the alternative action in response to the original action being unavailable.
- The method of claim 1 , wherein permitting the user to request the original action comprises permitting the user to request at least one of transporting the user's avatar to a selected location in the virtual world and the user's avatar receiving a chosen service;and wherein allowing the user to accept the alternative action comprises allowing the user to accept at least one of transporting the user's avatar to another selected location in the virtual world and the user's avatar receiving another chosen service.
- The method of claim 2 , further comprising providing the user with an option to select one of accepting the original action and delaying acceptance of the original action for a predetermined time period to finish the alternative action in response to the original action becoming available.
- The method of claim 1 , further comprising determining any alternative action to present to the user based on at least one of virtual demographics, information about the user's avatar, previously requested actions by the user, user searches and any other actions that are relevant to the original action.
- The method of claim 1 , further comprising: determining if a plurality of alternative actions are available for the user's avatar;ranking the alternative actions based on a predetermined criteria in response to the plurality of alternative actions being available;and presenting the ranked alternative actions to the user.
- The method of claim 9 , wherein ranking the alternative actions comprises ranking the alternative actions based on a relevance factor to the original action.
- A method for allowing an alternative action in a virtual world, comprising: permitting a user to request an original action for an avatar of the user in the virtual world;determining if the original action is available for the user's avatar at the time of the request;determining, using a computer, if at least one alternative action is available for the user's avatar in response to the original action being unavailable to the user's avatar;presenting the at least one alternative action as an option to the user, and allowing the user's avatar to perform the at least one alternative action in response to the user selecting the at least one alternative action.
- The method of claim 11 , further comprising: determining if the original action becomes available for the user's avatar in response to the original action being unavailable to the user's avatar when the user initially requested the original action;notifying the user that the original action has become available for the user's avatar in response to the original action becoming available;allowing the user to accept the original action;and allowing the user's avatar to perform the original action in response to the user accepting the original action.
- The method of claim 11 , further comprising determining the at least one alternative action to present to the user based on at least one of virtual demographics, information about the user's avatar, previously requested actions by the user, user searches and other actions that are relevant to the original action.
- The method of claim 11 , further comprising ranking the at least one alternative action based on a predetermined criteria;and presenting the ranking of the at least one alternative action to the user.
- The method of claim 12 , further comprising allowing the user's avatar to continue the alternative action in response to the user not accepting the original action when the original action becomes available to the user's avatar.
- The method of claim 12 , further comprising providing a predetermined time period for the user to accept the original action in response to the original action becoming available to allow the user's avatar to continue performing the alternative action.
- The method of claim 16 , further comprising rescinding the request for the original action in response to the user not accepting the original action within the predetermined time period.
- The method of claim 11 , further comprising storing the user's request for the original action in a queue in response to the request for the original action being unavailable.
- The method of claim 11 , wherein the original action is an action selected from one of transporting the user's avatar to a selected location in the virtual world and the user's avatar receiving a chosen service;and wherein the alternative action is an action selected from one of transporting the user's avatar to another selected location in the virtual world and the user's avatar receiving another chosen service.
- The method of claim 11 , further comprising permitting the user to perform the alternative action while the request for the original action is pending.
- A method for allowing an alternative action in a virtual world, comprising: presenting an original graphical user interface to permit a user to request an original action for the user's avatar in the virtual world;receiving a request for the original action;performing the original action in response to the original action being available for the user's avatar;and in response to the original action being unavailable for the user's avatar at the time that the user requests the original action: providing a notification that the original action is unavailable;storing the request for the original action in a queue;determining, using a computer, an alternative action to present to the user based on at least one of the group of virtual demographics, information about the user's avatar, previously requested actions by the user and other actions that are relevant to the original action;determining if the alternative action for the user's avatar is available;presenting a second graphical interface to the user to allow the user to request the alternative action receiving a request for the alternative action;permitting the user's avatar to perform the alternative action while the request for the original action is still in the queue;determining if the original action is available for the user's avatar;sending a notification of availability of the original action in response to the original action being determined to be available for the user's avatar;providing a graphical user interface to the user in response to the original action being determined to be available for the user's avatar;providing a predetermined time period for allowing the user to accept the original action;performing the original action in response to the user accepting the original action within the predetermined time period;allowing the user's avatar to continue to perform the alternative action in response to the user not accepting the original action within the predetermined time period;and dropping the user's request for the original action from the queue in response to the user not accepting the original action within the predetermined time period.
Disclaimer: Data collected from the USPTO and may be malformed, incomplete, and/or otherwise inaccurate.