In recent years, massively multiplayer online (“MMO”) computer applications, such as massively multiplayer online role-playing games (“MMORPGs”), have become extremely popular not only with serious gamers, but also with casual gamers and other Internet users. One example of a MMO computer application enables a participant to create and develop a fictional character in a virtual world. The fictional character is usually associated with an avatar or some other visual representation that enables other participants to recognize the particular fictional character. A given participant may develop, among other things, a storyline, a reputation, and attributes of her fictional character by interacting in the virtual world via the fictional character. Other examples of MMO computer applications may not involve the creation of a virtual world representation of the participant.
The virtual world typically includes an environment with a variety of virtual locations containing a variety of virtual objects. In some cases, the virtual locations and the virtual objects mimic realistic locations and objects, while in other cases, the virtual locations and virtual objects are fanciful creations. MMO computer applications generally permit the fictional character to travel across the virtual locations and interact with the virtual objects and other fictional characters.
A virtual world may provide a way for participants to share real world information with other participants in the virtual world. For example, the virtual world may contain a status text feature whereby a participant can enter text regarding her status. Thus, if Jane is having lunch with Jack in the real world, Jane may update her virtual world status to state “Jane is having lunch with Jack”. The virtual world may then broadcast Jane's status text to other participants within the virtual world.
Status features, such as status text, are conventionally implemented in MMO and other applications as way to provide a limited social function. For example, the status text may enable a participant to share relevant and interesting information about her real world life with her virtual world friends. However, the utilization of status features outside of basic social applications has not been explored.
It is with respect to these and other considerations that the disclosure made herein is presented.
Technologies are described herein for providing real-time or near real-time tracking in a virtual world. As used herein, the term “tracking” generally refers to following the status of an entity (e.g., a participant, item, or process) within the virtual world and/or the real world. An entity in the virtual world may be referred to herein as a virtual world entity, as a virtual participant, virtual item, or virtual process. An entity in the real world may be referred to herein as a real world entity, such as a real participant, a real item, or a real process. According to embodiments, each virtual world entity in the virtual world may correspond to a particular real world entity in the real world. For example, the virtual world entity may be visual representation of the real world entity.
The status of an entity may include a variety of information, such as location, progress, condition, and the like. Thus, a change in status may refer to a change in location, progress, condition, and the like. When the status of a real world entity changes, then a corresponding virtual world entity may be updated to reflect the changed status of the real world entity. Further, when the status of a virtual world entity changes, then a real world process may be dictated according to the changed status of the virtual world entity.
According to one embodiment, a method is provided herein for providing tracking in a virtual world. A status update of a real world entity is received. A previous status of a virtual world entity is transformed into a current status of the virtual world entity based on the status update of the real world entity. The virtual world entity may be part of a virtual world and may correspond to the real world entity in a real world. Further, the virtual world entity and the virtual world may be generated by computer.
It should be appreciated that although the features presented herein are described in the context of a MMO computer application, these features may be utilized with any type of virtual world or environment including, but not limited to, other types of games as well as online social communities. It should also be appreciated that the above-described subject matter may also be implemented as a computer-controlled apparatus, a computer process, a computing system, or as an article of manufacture such as a computer-storage medium. These and various other features will be apparent from a reading of the following Detailed Description and a review of the associated drawings.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended that this Summary be used to limit the scope of the claimed subject matter. Furthermore, the claimed subject matter is not limited to implementations that solve any or all of the disadvantages noted in any part of this disclosure.
The following detailed description is directed to technologies for providing tracking in a virtual world. Through the utilization of the technologies and concepts presented herein, the status of real world entities in the real world and virtual world entities in the virtual world may be tracked in real-time or near real-time. Any status changes to real world entities in the real world may be mimicked by virtual world entities in the virtual world. Further, any status changes to virtual world entities in the virtual world may be utilized to dictate real processes in the real world.
While the subject matter described herein is presented in the general context of program modules that execute in conjunction with the execution of an operating system and application programs on a computer system, those skilled in the art will recognize that other implementations may be performed in combination with other types of program modules. Generally, program modules include routines, programs, components, data structures, and other types of structures that perform particular tasks or implement particular abstract data types. Moreover, those skilled in the art will appreciate that the subject matter described herein may be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers, and the like.
As used herein, the term virtual world refers to a computer-implemented environment, which may include simulated, lifelike environments as well as fanciful, non-existing environments. Examples of virtual worlds may include any massively multiplayer online (“MMO”) computer application including, but not limited to, massively multiplayer online role-playing games (“MMORPGs”), virtual social communities, and virtual reality computer applications. In one embodiment, the MMO computer application simulates a real world environment. For example, the virtual world may be defined by a number of rules, such as the presence of gravity or the lack thereof. In other embodiments, the MMO computer application includes a fanciful environment that does not simulate a real world environment.
The virtual world may be inhabited by avatars, which are virtual or symbolic representations of real world participants (hereinafter referred to as participants). As such, each avatar is typically associated with and controlled by a particular participant. Avatars may include two-dimensional and/or three-dimensional images. Through the virtual world, the avatars may interact with other avatars, as well as with virtual objects. Virtual objects may include virtual representations of real world objects, such as houses, cars, billboards, clothes, packages, and soda cans, as well as fanciful creations, such as a teleportation machine or a flying car. The avatars and the virtual objects utilized in the virtual world may or may not be animated images.
As used herein, a “real world entity” may refer to a participant, item, or process in the real world. According to embodiments, each real world entity corresponds to a “virtual world entity”, which may refer to a corresponding virtual representation of the participant, item, or process. For example, an avatar in the virtual world may correspond to a participant.
In the following detailed description, references are made to the accompanying drawings that form a part hereof, and which are shown by way of illustration specific embodiments or examples. Referring now to the drawings, in which like numerals represent like elements through the several figures, aspects of a computing system and methodology for implementing a virtual world will be described. In particular,
The client device 104 may be any suitable processor-based device, such as a computer or a gaming device. Exemplary gaming devices include the XBOX and the XBOX 360 from MICROSOFT CORPORATION, the WII from NINTENDO COMPANY, LIMITED, and the PLAYSTATION 3 and the PSP from SONY CORPORATION. Although not so illustrated in
As shown in
The virtual world client module 120 may include any suitable component for accessing the virtual world server module 110. In one example, the virtual world client module 120 may be a computer application configured to locally provide at least a portion of the virtual world for the client device 104. In this way, the amount of data retrieved from the server computer 102 by the client device 104 to generate the virtual world may be reduced. In another example, the virtual world client module 120 may be a web browser configured to retrieve the virtual world from the virtual world server module 110. Since many public computers, such as those found in Internet cafes, commonly have a web browser installed and prohibit the installation of new computer applications, providing participants a way to access the virtual world via the web browser may provide greater accessibility and convenience. It should be appreciated that a participant may be able to access the virtual world without “entering” the virtual world. For example, the participant may access the virtual world through a third party program (e.g., a social networking service, a blogging service, etc.) that is operative to access data from the virtual world.
As shown in
In some embodiments, updates to the status of a real world entity may be reflected in the corresponding virtual world entity. In particular, updates to the status of the real world entity may be received at the real world status module 124. The real world status module 124 may receive the status update through another computer or device (not shown) in an automated manner or through manual human input. Upon receiving the status update of the real world entity, the real world status module 124 may inform the virtual world status module 122 of the status update. The virtual world status module 122 may then update the status of the virtual world entity that corresponds to the real world entity. The virtual world status module 122 may cause the virtual world server module 110 to update the virtual world in order to reflect the status update of the real world entity.
In one embodiment, the virtual world server module 110 notifies each client, such as the virtual world client module 120, of the update to the virtual world. In another embodiment, the virtual world server module 110 stores the update to the virtual world in a database (not shown). In this way, the virtual world client module 120 may retrieve the update to the virtual world from the database as necessary.
In further embodiments, updates to the status of a virtual world entity may dictate a real world process. In particular, updates to the status of the virtual world entity may be received at the virtual world status module 122. The virtual world status module 122 may receive the status update through another computer or device (not shown) in an automated manner or through manual human input. As previously described, the virtual world status module 122 may also update the status of the virtual world entity based on input from the real world status module 124. Upon receiving the status update of the virtual world entity, the virtual world status module 122 may inform the process module 126 of the status update. The process module 126 may then dictate real processes based on the status update of the virtual world entity.
When a participant desires to access the virtual world, the participant may initiate the virtual world client module 120 to establish a session with the virtual world server module 110 via the network 108. During the session, the virtual world server module 110 may transmit data (e.g., environment layouts, avatar movements of other participants) associated with the virtual world to the virtual world client module 120. Similarly, the virtual world client module 120 may transmit data from associated input devices to the virtual world server module 110.
Referring now to
It should be appreciated that the logical operations described herein are implemented (1) as a sequence of computer implemented acts or program modules running on a computing system and/or (2) as interconnected machine logic circuits or circuit modules within the computing system. The implementation is a matter of choice dependent on the performance and other requirements of the computing system. Accordingly, the logical operations described herein are referred to variously as states operations, structural devices, acts, or modules. These operations, structural devices, acts, and modules may be implemented in software, in firmware, in special purpose digital logic, and any combination thereof. It should be appreciated that more or fewer operations may be performed than shown in the figures and described herein. These operations may also be performed in a different order than those described herein.
Referring to
In one example, the status update of the real world entity may refer to a change in location of a participant. As the participant travels within the real world, the real world status module 124 may track any changes in location. In this case, the real world status module 124 may utilize a Global Positioning System (“GPS”) receiver on the participant's cellular device or other suitable technologies to determine the location of the participant. In another example, the status update may refer to a change in the condition of a package during transit. In yet another example, the status update may refer to a change in the delivery schedule or delivery location by a courier service. Numerous other status changes may be contemplated by those skilled in the art.
Upon receiving the status update of the real world entity, the real world status module 124 may inform the virtual world status module 122 of the status update. The routine 200 then proceeds to operation 204, where the virtual world status module 122 may update the virtual world based on the status update of the real world entity. In particular, the virtual world status module 122 may instruct the virtual world server module 110 to transform the status of a virtual world entity that corresponds to the real world entity.
In the previous example where the status update of the real world entity refers to a change in location of a participant, the virtual world status module 122 may instruct the virtual world server module 110 to transform the status of an avatar that corresponds to the participant. In particular, the avatar may be transformed to indicate that the location of the participant has changed and possibly the new location of the participant. For example, the virtual world may be designed to include a virtual representation of the person's home, office, and gym. As the participant travels from between her home, office, and gym, the participant's avatar may be correspondingly transformed to reflect whether the participant is at her home, office, or gym.
In the previous example where the status update of the real world entity refers to a change in the condition of a package during transit, the virtual world status module 122 may instruct the virtual world server module 110 to update the status of an animated image or model of the package in the virtual world. In particular, the animated image or model of the package may be altered to mimic the actual physical damage to the package. In this way, a user viewing the animated image or model in the virtual world can quickly identify that the real world package has been damaged.
In the previous example where the status update of the real world entity refers to a change in the delivery schedule or delivery location by a courier service, the virtual world status module 122 may instruct the virtual world server module 110 to update the status of an animated image of a real world delivery truck in the virtual world. In one example, if the delivery truck suffers a flat tire while performing deliveries, the animated image may be altered to show a virtual flat tire. In another example, as the delivery truck travels through its route to make deliveries, the animated image may be relocated across the virtual world to reflect the current location of the delivery truck.
Referring to
Upon receiving the status update of the virtual world entity, the virtual world status module 122 may inform the process module 126 of the status update. The routine 300 then proceeds to operation 304, where the process module 126 may dictate a real world process based on the status update received from the virtual world status module 122. In particular, the process module 126 may transform the real world process flow based on input from the virtual world status module 122.
In the previous example where the status update of the virtual world entity refers to a change in the virtual location of an avatar, the change in the virtual location of the avatar may reflect a change in the location of the corresponding participant. In this case, the process module 126 may transform the delivery destination of a package, based on the change in the virtual location of the avatar, in order to accommodate the change in the location of the participant.
Referring to
At operation 404, the real world status module 124 receives a location of the package. In one example, the real world status module 124 receives the location of the package via a GPS device located at the delivery truck carrying the package. In another example, the real world status module 124 receives the location of the package from a manual location update from the delivery truck driver. In yet another example, the real world status module 124 receives the location of the package by accessing a location database associated with the package courier. Upon receiving the location of the package, the real world status module 124 may inform the virtual world status module 122 of the current location of the package. The routine 400 proceeds to operation 406.
At operation 406, the virtual world status module 122 updates the scanned image of the package based on the location of the package. In particular, the virtual world status module 122 may instruct the virtual world server module 110 to transform the display of the scanned image in the virtual world to reflect the change in location of the package. The routine 400 then proceeds to operation 408, where a determination is made as to whether the package has arrived at its destination. If the package has not yet arrived at its destination, then operations 406-408 may be repeated. That is, the virtual world status module 122 may continue to transform the scanned image of the package based on the most current location of the package. If the package has arrived at its destination, then the routine 400 terminates.
In the example of
Referring to
At operation 506, the virtual world status module 122 determines whether the participant is located at the original destination where the package is intended to be delivered (e.g., the delivery address written on the package). If the virtual world status module 122 determines that the participant is located at the original destination where the package is intended to be delivered, then the virtual world status module 122 may inform the process module 126 that the participant is located at the original destination. The routine 500 then proceeds to operation 508, where the process module 126 maintains the original delivery route where the delivery truck driver delivers the package at the original destination.
If the virtual world status module 122 determines that the participant is not located at the original destination where the package is intended to be delivered, then the routine 500 proceeds to operation 510, where the virtual world status module 122 further determines whether the participant is located at or near an alternate destination where the package can still be delivered. For example, there may only be certain authorized or permission locations where the package can be delivered. Further, the participant may permit or restrict deliveries to predefined locations.
If the virtual status module 122 determines that the participant is located at an alternate destination where the package can still be delivered, then the virtual status module 122 may inform the process module 126 that the participant is located at an alternate destination. The process module 126 may transform the original delivery route that included the original destination into an alternate delivery route that replaces the original destination with the alternate destination. The routine 500 then proceeds to operation 512, where the process module 126 implements the alternate delivery route so that the delivery truck driver delivers the package to the alternate destination.
If the virtual status module 122 determines that the participant is not located at an alternate destination where the package can still be delivered, then the virtual status module 122 may inform the process module 126 that the participant is located somewhere that is not the original destination or a suitable alternate destination. The process module 126 may then transform the original delivery route by suspending the delivery of the package until a later time.
In another example, if a courier service has shipped a package and the courier service has set rules in a virtual world that indicate if the package is damaged (e.g., through the animated image or model). If a determination is made that the package has been damaged, then the assigned delivery route may be halted such that damage to the package can manually examined before proceeding. Such a manual inspection may prevent further damage to the package. In this example, the virtual world status module 122 may inform the process module 126 of the condition or damage of the package. The process module 126 may then alter the delivery route or delivery process according to the condition or damage or the package.
Referring now to
By way of example, and not limitation, computer-storage media may include volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information such as computer-storage instructions, data structures, program modules, or other data. For example, computer-storage media includes, but is not limited to, RAM, ROM, EPROM, EEPROM, flash memory or other solid state memory technology, CD-ROM, digital versatile disks (“DVD”), HD-DVD, BLU-RAY, or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by the computer 600.
According to various embodiments, the computer 600 may operate in a networked environment using logical connections to remote computers through a network such as the network 108. The computer 600 may connect to the network 108 through a network interface unit 610 connected to the bus 606. It should be appreciated that the network interface unit 610 may also be utilized to connect to other types of networks and remote computer systems. The computer 600 may also include an input/output controller 608 for receiving and processing input from a number of input devices (not shown), including a keyboard, a mouse, a microphone, and a game controller. Similarly, the input/output controller 608 may provide output to a display or other type of output device (not shown).
The bus 606 may enable the processing unit 602 to read code and/or data to/from the mass storage device 612 or other computer-storage media. The computer-storage media may represent apparatus in the form of storage elements that are implemented using any suitable technology, including but not limited to semiconductors, magnetic materials, optics, or the like. The computer-storage media may represent memory components, whether characterized as RAM, ROM, flash, or other types of technology. The computer-storage media may also represent secondary storage, whether implemented as hard drives or otherwise. Hard drive implementations may be characterized as solid state, or may include rotating media storing magnetically-encoded information.
The program modules 614 may include software instructions that, when loaded into the processing unit 602 and executed, cause the computer 600 to facilitate non-linguistic interaction with users via surface stimulation. The program modules 614 may also provide various tools or techniques by which the computer 600 may participate within the overall systems or operating environments using the components, flows, and data structures discussed throughout this description. For example, the program modules 614 may implement interfaces that facilitate non-linguistic interaction between the computer 600 and any number of users.
In general, the program modules 614 may, when loaded into the processors 106 and executed, transform the processing unit 602 and the overall computer 600 from a general-purpose computing system into a special-purpose computing system customized to facilitate non-linguistic interaction with computer systems via surface stimulation. The processing unit 602 may be constructed from any number of transistors or other discrete circuit elements, which may individually or collectively assume any number of states. More specifically, the processing unit 602 may operate as a finite-state machine, in response to executable instructions contained within the program modules 614. These computer-executable instructions may transform the processing unit 602 by specifying how the processing unit 602 transitions between states, thereby transforming the transistors or other discrete hardware elements constituting the processing unit 602.
Encoding the program modules 614 may also transform the physical structure of the computer-storage media. The specific transformation of physical structure may depend on various factors, in different implementations of this description. Examples of such factors may include, but are not limited to: the technology used to implement the computer-storage media, whether the computer-storage media are characterized as primary or secondary storage, and the like. For example, if the computer-storage media are implemented as semiconductor-based memory, the program modules 614 may transform the physical state of the semiconductor memory, when the software is encoded therein. For example, the program modules 614 may transform the state of transistors, capacitors, or other discrete circuit elements constituting the semiconductor memory.
As another example, the computer-storage media may be implemented using magnetic or optical technology. In such implementations, the program modules 614 may transform the physical state of magnetic or optical media, when the software is encoded therein. These transformations may include altering the magnetic characteristics of particular locations within given magnetic media. These transformations may also include altering the physical features or characteristics of particular locations within given optical media, to change the optical characteristics of those locations. Other transformations of physical media are possible without departing from the scope of the present description, with the foregoing examples provided only to facilitate this discussion.
Based on the foregoing, it should be appreciated that technologies for providing tracking in a virtual world are presented herein. Although the subject matter presented herein has been described in language specific to computer structural features, methodological acts, and computer readable media, it is to be understood that the invention defined in the appended claims is not necessarily limited to the specific features, acts, or media described herein. Rather, the specific features, acts and mediums are disclosed as example forms of implementing the claims.
The subject matter described above is provided by way of illustration only and should not be construed as limiting. Various modifications and changes may be made to the subject matter described herein without following the example embodiments and applications illustrated and described, and without departing from the true spirit and scope of the present invention, which is set forth in the following claims.