U.S. Pat. No. 9,579,561
ALLOWING INTERACTIVE POST OF AN ONLINE GAME WITHIN A SOCIAL NETWORK
AssigneeZynga Inc.
Issue DateDecember 21, 2012
Illustrative Figure
Abstract
Methods, systems, and computer programs for sharing a game play over a social network include executing a play session of a game. During execution of the play session, an option is provided to share a portion of the game on a social network. In response to receiving a request to share the portion of the game, an instance of the game is generated at a time when the request is received and is posted to a stream of the social network. The instance of the game inherits a current state of the play session. A reward is generated to a user account that plays the instance in the stream and to the user that initiates the sharing of the portion of the game upon the user playing the instance of the game claims the reward.
Description
DETAILED DESCRIPTION The following embodiments describe a method and apparatus for executing a game. It will be apparent, that the present embodiments may be practiced without some or all of these specific details. In other instances, well known process operations have not been described in detail in order not to unnecessarily obscure the present embodiments. The embodiments provide a way for users to play the online game, share game state of the online game with one or more social contacts within one or more of their social groups using social network and to seek assistance from the one or more of their social contacts to achieve a desired target, perform a challenging task, to enhance their winnings or to overcome certain challenges in the online game. The game state and game controls to participate in the online game are provided within the social network to enable the social contacts to participate in the online game from within the social network and contribute to the winnings of the user. The game rewards obtained in the online game through the game play of the social contacts are shared between the user and the respective social contacts, thereby providing an incentive for the social contacts to participate in the online game. The various embodiments discussed herein provide an interactive and collaborative online game that uses the social network as a collaboration site for enabling social contacts within the one or more social groups of the user to access and participate in the online game. The social contacts need not have to leave the confines of the social network in order to participate in the online game as the game state and the controls to access and participate are provided within a stream of the social network. With the general understanding of the invention, ...
DETAILED DESCRIPTION
The following embodiments describe a method and apparatus for executing a game. It will be apparent, that the present embodiments may be practiced without some or all of these specific details. In other instances, well known process operations have not been described in detail in order not to unnecessarily obscure the present embodiments.
The embodiments provide a way for users to play the online game, share game state of the online game with one or more social contacts within one or more of their social groups using social network and to seek assistance from the one or more of their social contacts to achieve a desired target, perform a challenging task, to enhance their winnings or to overcome certain challenges in the online game. The game state and game controls to participate in the online game are provided within the social network to enable the social contacts to participate in the online game from within the social network and contribute to the winnings of the user. The game rewards obtained in the online game through the game play of the social contacts are shared between the user and the respective social contacts, thereby providing an incentive for the social contacts to participate in the online game.
The various embodiments discussed herein provide an interactive and collaborative online game that uses the social network as a collaboration site for enabling social contacts within the one or more social groups of the user to access and participate in the online game. The social contacts need not have to leave the confines of the social network in order to participate in the online game as the game state and the controls to access and participate are provided within a stream of the social network. With the general understanding of the invention, various embodiments for managing participation and distributing rewards in an online game will now be described with reference to the enclosed drawings.
As used herein, a “social contact” of a user refers to a person that has established a social link or social relationship with the user within a social network. The social contact may belong to one or more social groups within one or more social network of the user. For example, a social contact may be a friend, a relative, or a person that shares a common interest and/or that the user has met/interacted with in real-life or over the internet. In some embodiments, the social contact may be an acquaintance established through a social network, such as a friend of a friend of the user in the social network become friends of the user. It should be noted that two persons who may be friends in real-life may not be social contacts of one another if the two have not established an interrelationship online. Alternately, if two persons do not know each other in real life but have established interrelationship online, then these two persons will be social contacts of one another for all or some of the social interactions performed online.
It should also be noted that the various embodiments are described herein with reference to a slots online game, to provide an understanding. It should, however, be noted that the principles may be extended to other online games or applications that require or benefit from social collaboration described in the various embodiments. The embodiments described herein should therefore not be interpreted to be exclusive or limiting, but rather exemplary or illustrative.
FIG. 1is an illustrative embodiment of a system used for allowing sharing of an online game within a social network. The system includes a server104, such as a game server, executing the online game, according to one embodiment. The server104hosting the online game includes a game manager120having a plurality of modules, such as an access manager module110, an update manager module112, a share manager module114, and a distribution manager module116. The server104also includes game related data128, such as game data118, user data122, social data124and game design data126. A user P1, in one embodiment, initiates access to the online game executing on the server utilizing a game interface108on a client device102executing a computer program, such as a web browser. In another embodiment, the client may execute other computer programs other than the web browser to interact with the game interface for transmitting command and data between the client and the various modules of the game manager executing on the server104.
In one embodiment, the game manager120provides access to the online game and manages the game operations for each of the players. The various modules within the game manager are configured to interact with each other to perform the respective game operations of the online game. In addition, the various modules within the game manager access and manage game related data stored in the various databases during the execution of the online game. In one embodiment, the access manager110is configured to validate a user and provide access to the online game executing on the server104. The access manager110provides the online game interface and data/information that is used to populate the various fields within, at the client102. For instance, the access manager110provides the game state of the online game, which is a current view of the game, as well as any game rewards awarded to the user during game play. The game rewards, in one embodiment, may include points, prizes, incentives, tools, etc., in response to the user's participation or interest in the online game. The access manager110interacts with game data118and user data122to retrieve the information related to the online game and presents the game state and the game rewards at the client device102for the user. In addition, the access manager110provides one or more controls for accessing and participating in the online game. When the user accesses the game through the client, the access manager110synchronizes game operations with the client102, manages communications with the client102, etc.
Update manager112manages updates to the game state and game rewards at the game interface and in the respective databases, such as user data122and the game data118, in response to the user interactions at the online game. In one embodiment, the update manager112includes game mechanics logic (not shown) to receive the interaction from a user, interpret the interaction and to compute game state and game awards based on the interpretation. For example, in an online game, such as a slot machine game, the game mechanics logic receives the user interaction, interprets the user interaction and performs game simulation to determine outcome of the game and computes possible game rewards won related to the user's interaction, such as spinning of the game. The game rewards won by the user are commensurate with the status of the online game based on the user's game play in the online game. For example, the slot game is a game of chance and the computation of game rewards to be awarded to the user is based on game rules and a degree of randomness related to the game of chance. The probability of each outcome of the online game is driven by data and logic set up by game designers. The game design data126stores the various logics associated with the online game and make it available to the update manager112and to distribution manager116. The game design data126may, in one embodiment related to slot machine game, specify the various symbols provided in the online game, the combinations that result in generating game rewards, the odds of obtaining the combinations and winning game rewards, etc.
Additionally, the update manager112receives requests to share a portion of the game with one or more users on a social network. The request for sharing the game may be received through a share manager114and the share manager114may interact with the update manager112to provide an instance of the game in response to the request. The update manager112, in response to the request for sharing, retrieves the game state at the time the request for sharing was received, possible game rewards and/or incentives from the respective databases and generates an instance of the game for sharing. The instance of the game, based on the information retrieved, includes the current game state of the game and other attributes of the game and of the user that initiated (i.e. publisher or initiator) the sharing of the game. The instance of the game also includes one or more controls to access and play the game.
The update manager112forwards the instance of the game and the game related information back to the client game interface108on the client102in a content stream of a social network so that one or more social contacts of the social network selected for sharing can access and play the game. The updated game state presents a current view of the online game for social contacts of the social network.
FIG. 2aillustrates a graphical user interface (GUI) representation of the online game interface provided by the access manager at the client for the user to interact and play the game and also includes updates provided by the update manager112. The updates include the game state310and game rewards311accrued by the user during game play of the online game. The game state provides a current view of the game including the level of the game being played, number of chances remaining, etc. The game rewards include points accrued, special tools acquired, etc.
Referring toFIGS. 1 and 2a, when the share manager114within the game manager120receives a request from the user to share the online game with other users in a social network, the share manager114generates an instance of the game of the user initiating the sharing request. The instance of the game inherits current state of the play session resulting from the user's interaction at the game, for sharing in a stream of the social network. One or more controls are provided at the online game interface at the client device102that are user selectable, for enabling a user to share the game with other users.FIG. 2aillustrates one exemplary ‘share’ control304provided by the access manager that can be selected by the user for sharing the online game with one or more users within one or more social networks of the user. The share control illustrated inFIG. 2ais exemplary and should not be considered restrictive or limiting. Other forms of share control may be provided at the game interface rendered on the client for enabling the user to share the online game with other social contacts within one or more social groups in the social network of the user.
In one embodiment, when the user selects the share control304, the user is provided with one or more social networks, one or more social groups within one or more social networks and/or one or more social contacts available within one or more social groups of the user to select for sharing an instance of the online game.FIG. 2aillustrates an exemplary view of the social contacts of the user that is provided by the share manager114. In order to provide this information, the share manager114interrogates the user data122and social data124and retrieves the one or more social groups and one or more social contacts within each of the social groups associated with the user from the social data124and returns this information to the client for rendering and user selection at the share control box304. When a user selects the social networks and/or social groups of the user, the user is presented with social contacts from the selected social networks and/or social groups in a social-contact-selection-interface302for the user to select other users to share the instance of the online game. The user who initiates the sharing of an instance of the online game is the initiator.
In addition to the one or more controls for sharing, the share manager114may also provide game incentives303ain accordance to pre-defined game rules, which the initiator can extend to other users. The initiator can use the game incentives to encourage the other users to play the shared online game. The initiator interacts with the social-contact-selection-interface302to identify the social contacts with whom to share the instance of the online game and provide the game incentives to the other users encouraging the other users to play the game. In one embodiment, the initiator may select a subset of the identified social contacts to share the game incentives. In another embodiment, the initiator may select to share the game incentives with all of the identified social contacts with whom he shares the instance of the game.FIG. 2aillustrates the user interface of the instance of the online game rendered at the client device of the initiator identifying the social groups304and social contacts302from the selected social groups of the initiator for sharing the game.
The share manager114receives the user selection of one or more social groups. and one or more social contacts within the one or more social groups to share the online game.FIG. 2billustrates a user interface of the game rendered at the initiator's client device after the initiator has selected the social contacts303bto share the instance of the game.FIG. 2balso shows the game incentives303athat the initiator is offering to the selected social contacts to encourage the social contacts to play the instance of the online game.
Continuing to refer toFIGS. 1 and 2a, the share manager114receives the selection of the social contacts from the client, retrieves the respective social contact information from the social data, such as transmitting information, etc., retrieves information related to the online game from game data, such as current state, game rewards, and game incentives provided by the user from the user data, social data and from user interface, generates an instance of the game at the time the request was received at the share manager114and forwards the retrieved/generated information related to the online game to the selected social contacts in a post to a stream of the social network. In one embodiment, the information related to the online game includes rewards, scores, game level, game tools, game options, available game incentives and game graphics related to the current state of the game. The game state, in one embodiment, is provided in a Shockwave Flash (SWF) file format, which is an interactive application component. The SWF file is a file format that is commonly used in browser games for rendering multimedia, vector graphics, etc. The SWF file can contain animations or applets of varying degrees of interactivity and function. The SWF file is formatted for displaying animated vector graphics on the Internet. The SWF file format is an exemplary format for providing the instance of the game and should not be considered limiting. Other formats may be used to provide the instance of the game.
In one embodiment, the posting of the instance of the online game with current state information is active for a pre-defined life span. In this embodiment, upon expiration of the life span, the post in the stream of the social network with information related to the online game provided to the one or more social contacts is invalidated.
In one embodiment, in addition to the general incentives, a periodic incentive308may also be extended to all the social contacts to encourage the social contacts to participate in the online game and contribute toward achieving a goal for the user. In one embodiment, the periodic incentive may be in the form of free points, chips, awards, etc. In one embodiment, the periodic incentive may be extended during the life span the post is active in the stream or once every pre-defined period to encourage the social contacts to take advantage of the periodic incentive offer.FIG. 2aillustrates an exemplary period306extended with the periodic incentive offer to the social contacts, in one embodiment. The period306illustrated inFIG. 2ais provided as a count-down digital timer. As noted, the period306illustrated inFIG. 2ais exemplary and should not be considered limiting. Other forms of providing period306may be used.
Referring toFIG. 2a, the user interface of the game rendered for the initiator will not have any social contacts contributing initially. This may be the case as the initiator may not yet have shared the game. As a result, the contributing-user box313will be empty, as illustrated inFIG. 2a. When the initiator initiates sharing by posting the instance of the game in the stream of the social network of selected social contacts and the one or more of the selected social contacts play the game in the stream and accept the winning awards, the share manager114updates the contributing-user box313and provides visible indication of the social contacts that have accessed the online game provided in the stream of the social network and interacted to contribute toward achieving a goal for the user, at the client102. In one embodiment, the visible indicator is in the form of images of the social contacts that are provided in the contributing-user box313. Referring now toFIG. 2b, images of the social contacts that have contributed toward achieving the goal for the user are illustrated in a contributing-users box313at the initiator's game user interface. The contributing-users box313is an aggregate of all the social contacts that have played the online game shared by the user, accepted the rewards/awards (i.e. clicked in the game to accept the award) and each social contact's contribution (in the form of game rewards, for example) toward the initiator's subsequent game play. User interaction, such as mouse over, at each contributor's image in the contributing-users box313will display the extent of influence the contributing social contact has on the winnings of the initiator's subsequent game play. For example, as illustrated inFIG. 2b, when the initiator interacts at a social contact's image by ‘mousing over’ the image, for example, the social contact's contribution to the initiator's subsequent game play is shown in box321. In the example, the social contact, Andy, contributed to a5fold increase in the winnings for the initiator's subsequent game. As a result, during a subsequent game play of the slot game by the initiator, the initiator is awarded 5 times his winnings awarded during the game. In one embodiment, the social contact's contribution, in the form of award multiplier, is active for the current session of the initiator.
In one embodiment, in addition to information related to the game rewards, periodic incentives and game incentives, the share manager may also provide options to provide additional incentives that are different in scope than the aforementioned incentives. The additional incentives may be in the form of tools, levels, etc., while the aforementioned incentives may be in the form of game points. The additional incentives may be provided to selective one or more social contacts for their contribution and/or to encourage them to continue contributing to the online game of the user.
FIGS. 2c-1and2c-2illustrate the user interface of the game played by the initiator after the social contacts have played the online game in the stream and accepted awards. As mentioned earlier, when the initiator plays the game after the social contacts have played the game and accepted the awards, the game winnings for the initiator are increased multiple folds. The number of folds of increase may be based on the number of social contacts that have played the game and accepted the winnings. When more social contacts contribute to the online game, the multiplier applied for the initiator's game winnings increases. For example, if three social contacts contributed to the online game by playing and accepting the awards, the initiator's winnings during subsequent game play may be increased 3 folds. This is illustrated inFIG. 2c-1in box321. Similarly, if five social contacts played the online game and accepted the awards, the winnings of the initiator during the initiator's subsequent game play increases 5 folds, as illustrated in box321ofFIG. 2b, and so on.FIGS. 2c-1and2c-2illustrate the user interface of the game rendered at the initiator's client device when the initiator selects the control312-afor initiating game play and the updated control312-bthat is rendered in response to user interaction with control312-aofFIG. 2c-1.
Referring now toFIGS. 1 and 3, the content stream with the information related to the online game is presented to a social contact when the social contact accesses his/her stream in the social network.FIG. 3illustrates an exemplary GUI representation of the posting316with an instance of the game and the information related to the online game provided in a content stream314, by the share manager114at the social contact's social network, in response to a request for sharing the online game received from the user. The information related to the online game includes a game state of the online game of the user and one or more controls312to access and participate in the online game from within the social network.
Referring toFIGS. 1, 3 and 4a, when the social contact accesses the online game from within the social network stream and plays the game using the control312, the interactive component of the online game allows expansion of the online game interface within the content stream in the social network so as to allow the social contacts to interact and participate in the online game in the stream without leaving the social network. The expanded online game rendered in the social network of the social contact is an actual instance of the initiator's online game capturing the current state of the game including game state, image, score, etc., from the initiator's client102at a time when the initiator decided to share the online game with the one or more social contacts. In addition to the game state, one or more controls are provided for the social contact to participate in the online game within the social network.FIG. 4aillustrates an exemplary GUI representation of the online game provided in the stream of the social network of a social contact. As illustrated, the content stream314of the social network for the social contact includes the game interface with the game state and controls for playing the online game from within the social network. When the online game controls are accessed through the access control312ofFIG. 3, an expanded version of the online game interface310is provided along with an interaction control312-ato enable a social contact to interact with the online game and contribute to the online game of the user. When the user completes playing the game or after playing for a period of time, the social contact may decide to claim his rewards.FIG. 4billustrates the interaction control312-cthat allows the social contact to claim his rewards. The social contact may use the interaction control312-cto “click into” the game to claim the rewards. The “click into” option is implemented as a “claim” button312-c. When the social contact claims his awards, the user data and the game data for the social contact is updated with the social contact's winnings.
Referring back toFIG. 1, the distribution manager116keeps track of the interactions at the online game from within the stream of the social network by the various social contacts with whom the initiating user has shared the online game. In one embodiment, when the social contact claims his awards, the distribution manager116then interacts with the update manager112to determine the game state and game rewards to be awarded to the social contact based on the social contact's interactions at the online game interface in the social network. The game state and game rewards, as explained earlier, are determined by the game mechanics logic within the update manager112. The distribution manager116distributes the game rewards to the respective social contact in response to the social contact's selection of the claim button and awards an equivalent game multiplier to the initiator. In one embodiment, the distribution manager uses a pre-defined distribution algorithm to determine proportion of allocation of the game rewards to the social contact's based on the social contact's game play and the magnitude of game multiplier to be awarded for the initiator. In one embodiment, the game reward allocation may depend on attributes associated with the online game and the attributes associated with the social contact playing the online game. For instance, some of the attributes of the online game for the game reward allocation may include skill level of the online game played, number of challenges met, type and quantity of game rewards awarded, etc., and some of the attributes of the social contact may include amount of time spent interacting at the online game, skill level of the social contact, reliability of the social contact, etc. In one embodiment, game reward awarded to the initiator from each of the social contacts participation is received and aggregated and the aggregated game reward is used to determine the multiplier to be awarded to the initiator. The update manager updates the game rewards to the respective social contact's account within the game data and/or user data upon the social contact's acceptance of the reward and the game multiplier is updated to the initiator's account within the game data. In one embodiment, the aggregation and updating of the game rewards to the user accounts within the game data for the social contacts and the initiator is done periodically. The distribution manager also updates the game state of the online game for the initiator by aggregating the game states of all the social contacts and using the aggregated game state to update the game state of the initiator so that the initiator is presented with the most up-to-date view of the online game. This includes updating the game state, image, game rewards, etc. In one embodiment, the updates to the user accounts of the social contacts and the initiator are performed only upon the social contacts clicking into the game and accepting the game rewards. The game state of the online game for the initiator is saved in the game data and retrieved when the initiator next initiates online game play.
With the general understanding of the various modules of the system, methods for managing rewards in online games will now be described with reference toFIGS. 5 and 6.FIG. 5illustrates method operations for sharing online game play over a social network, in one embodiment of the invention. The method begins at operation810, wherein a play session of the online game is established on a server. The server, such as a game server, provides access to the online game executing on the server and allows the user to interact with the game during a play session. The access may be provided through a game portal or from within a social network available to the user. The access may be provided as a link within the social network. During the play session, the user interaction at the online game are tracked and information related to play session of the online game by the user are received and updated to appropriate user and game data maintained by a game manager executing on the server. The information related to the online game play affects the game state and the game rewards awarded to the user. The game manager may engage game mechanics logic to evaluate the game play in order to determine game state and the game rewards. In online games, such as slot machine games, the game state may be a result of random probability.
During the engagement of the user in the online game, the game manager may receive a request from the user for sharing a portion of the online game with one or more social contacts within one or more social groups of the social network, as illustrated in operation820. The user initiating the request is the initiator or publisher.
In response to the request, the game manager captures the game state of the online game of the user at the time the request to share was initiated by the user and generates an instance of the game. The instance of the game inherits the captured game state of the online game of the play session of the user. The game state includes the status, image, game rewards (i.e. game score), etc of the online game of the user. The game manager then posts the instance of game along with one or more controls to a stream of the social network of selected ones of the social contacts. The controls provided with the instance of the game allow the social contacts to access and participate in the online game from within the stream of the social network. In one embodiment, the game manager retrieves online contact information (i.e. information used for transmitting the online game state) of the selected ones of the social contacts and uses the contact information to post the instance of the game in a stream of the social network that is accessible to the respective social contacts. The social contacts, in turn, access the instance of the game in the stream of the social network, participate and contribute to the online game of the user from within the social network using the provided controls and accept the awards. The participation of the social contacts in the game affects the game state and generates game rewards for the social contacts to claim. When the social contacts claim the awards, the game rewards are credited to the user account of the social contacts and the game rewards are used to compute a game multiplier for the user, as illustrated in operation830. The game multiplier is updated to the user's account and is used in computing the winnings of the user when the user subsequently accesses and plays the online game.
FIG. 6illustrates an alternate embodiment of a method for sharing game play over of an online game over a social network. The method begins at operation910wherein a posting of an instance of a game in a stream of a social network, is detected. The instance of the game captures a current state of a play session for a portion of the game of a user at a time the user generates a request to share the game on the social network and also includes one or more controls to play the game. In response to the detection, a social contact associated with the stream may initiate a game play request by accessing the one or more controls. In response to the social contact's interaction at the controls of the game in the stream, an expanded interactive component of the game and one or more additional controls to play the game from within the stream is presented, as illustrated in operation920. As mentioned earlier, in one embodiment, the instance of the game depicting the current state and the controls for interacting with the instance are provided as a SWF file that allows expansion of the online game within the stream of the social network enabling the social contacts to interact with the online game without having to leave the confines of the social network. When the social contact interacts with the controls of the online game from within the social network post, the information related to game play resulting from participation of the social contact in the online game is captured and is used to determine the game state and to generate game rewards for crediting to a user account of the social contact, as illustrated in operation930.
The game manager monitors the interaction of the social contact at the online game interface within the stream in the social network and uses the game mechanics logic within to determine the game rewards to be awarded and the game state of the online game based on the game play. When the social contact clicks into the game by interacting with a claim option, the game manager identifies the share of the game rewards that are to be awarded to the social contact playing the instance of the game from within the social network and a game multiplier for the user initiating the sharing based on a pre-defined distribution algorithm and updates the user and the social contact's accounts with the respective share of game multiplier/game rewards. The game rewards generated to the social contact may include incentives that are extended to the social contact for participating in the online game. The game manager also updates the game state of the online game of the user initiating the sharing to reflect a current view of the online game. When more than one social contact responds to the request to participate in the online game and accepts by claiming the game rewards, the game manager aggregates the game rewards of the social contacts and computes the game multiplier for the user initiating the sharing using the aggregated game rewards and updates the user's account in the game data with the game multiplier. The game multiplier is used in determining the user's winnings when the user subsequently accesses and plays the game. It is understood that not all the social contacts that received the invitation may participate in the online game or participate at the same time. In recognition of this fact, the game manager monitors each social contact's interaction and participation in the online game in an ongoing manner and periodically performs the aggregation based on the rewards generated due to the one or more social contacts' participation during that period and dynamically updates the appropriate share of the game rewards to the respective social contact's game account and the multiplier to the user's account.
It should be noted that the various embodiments described herein, the instance of the game based on a user's desire to share a portion of the online game over the social network is generated at the game server executing the game play and is distributed to the social network server through the respective posts in the respective streams of the one or more social networks. It is also noted that the reward to a user account is generated in response to the social contacts interaction at the social network server that is executing the instance of the online game shared by the user in the stream and credited to the respective user's accounts in response to the social contacts clicking into the game and claiming the awards. The game reward and game multiplier is computed by a game mechanics logic or processing logic contained in the instance of the game executing on the social network server and updated to respective databases (i.e., user data, game data, etc.) available to the game server executing the play session of the user initiating the share request.
The various embodiments of the invention identify an interactive online game that can be accessed and played directly from a stream of a social network and the users need not have to leave the social network page. The online game interface provided to the social contacts is an actual instance of the online game of a user and is not a link that would direct the social contact to a different page for playing the online game. When the social contact desires to play the game, the access controls allow expansion of the online game interface in the stream of the social network and the interaction controls provided in the instance of the game enables the social contact to participate in the online game of the user and claim game awards without leaving the stream or the social network. When the social contact is done playing the game, the social contact can continue browsing the content streams within the news feed in the social network, making this a robust and efficient way for collaborating with other users to achieve a desired goal in the online game.
FIG. 7shows a block diagram illustrating exemplary social-gaming network architecture, according to one embodiment. In some implementations, a plurality of players (e.g.,251a-251f) may be utilizing a social gaming network250. Each player interacts with the social gaming network via one or more client devices (e.g., client devices252a-252f). The clients may communicate with each other and with other entities affiliated with the gaming platform via communications network255. Further, the players may be utilizing a social networking service provided by a social networking server (e.g., social networking servers253) to interact with each other.
When a player provides an input into the player's client device, the client device may in response send a message via the communications network to the social networking server. The social networking server may update the player profile, save the message to a database, send messages to other players, etc. The social gaming network may include a social graph database254, which stores player relationships, social player profiles, player messages, and player social data.
The gaming servers261host one or more gaming applications, and perform the computations necessary to provide the gaming features to the players and clients. One or more gaming databases262store data related to the gaming services, such as the gaming applications and modules, virtual gaming environment data, player gaming session data, player scores, player virtual gaming profiles, game stage levels, etc. The gaming servers may utilize the data from the gaming databases to perform the computations related to providing gaming services for the players.
Room Servers272manage the slot rooms system in the game, including the creation, tracking, expiration, abandonment, and deletion of rooms. In addition, a room database270holds room information, and design db268holds information data.
FIG. 8illustrates an implementation of an online game infrastructure, according to one embodiment. The online game infrastructure476includes one or more game servers458, web servers (not shown), one or more social network management servers462, and databases to store game related information. In one embodiment, game server458provides a user interface460for players452to play the online game. In one embodiment, game server458includes a Web server for players452to access the game via web browser454, but the Web server may also be hosted in a server different from game server458. Network456interconnects players452with the one or more game servers458.
Each game server458has access to one or more game databases466for keeping game data. In addition, a single database can store game data for one or more online games. Each game server458may also include one or more levels of caching. Game data cache464is a game data cache for the game data stored in game databases466. For increased performance, caching may be performed in several levels of caching. For instance, data more frequently used is stored in a high priority cache, while data requiring less access during a session will be cached and updated less frequently.
The number of game servers458changes over time, as the gaming platform is an extensible platform that changes the number of game servers according to the load on the gaming infrastructure. As a result, the number of game servers will be higher during peak playing times, and the number of game servers will be lower during off-peak hours. In one embodiment, the increase or decrease of bandwidth is executed automatically, based on current line usage or based on historical data.
One or more social network management servers462provide support for the social features incorporated into the online games. The social network management servers462access social data478from one or more social networks474via Application Programming Interfaces (API)472made available by the social network providers. An example of a social network is Facebook®, but it is possible to have other embodiments implemented in other social networks. Each social network474includes social data478, and this social data478, or a fraction of the social data, is made available via API472. As in the case of the game servers, the number of social network management servers462that are active at a point in time changes according to the load on the infrastructure. As the demand for social data increases, the number of social network management servers462increases. Social network management servers462cache user data in database468, and social data in database470. The social data may include the social networks where a player is present, the social relationships for the player, the frequency of interaction of the player with the social network and with other players, etc. Additionally, the user data kept in database468may include the player's name, demographics, e-mail, games played, frequency of access to the game infrastructure, etc.
It is noted that the embodiment illustrated inFIG. 9is an exemplary online gaming infrastructure. Other embodiments may utilize different types of servers, databases, APIs, etc., and the functionality of several servers can be provided by a single server, or the functionality can be spread across a plurality of distributed servers. The embodiment illustrated inFIG. 9should therefore not be interpreted to be exclusive or limiting, but rather exemplary or illustrative.
FIG. 9illustrates an example network environment550suitable for implementing embodiments. Network environment550includes a network560coupling one or more servers570and one or more clients580to each other. In particular embodiments, network560is an intranet, an extranet, a virtual private network (VPN), a local area network (LAN), a wireless LAN (WLAN), a wide area network (WAN), a metropolitan area network (MAN), a portion of the Internet, another network, or a combination of two or more such networks560.
One or more links552couple a server570or a client580to network560. In particular embodiments, one or more links552each includes one or more wired, wireless, or optical links552. In particular embodiments, one or more links552each includes an intranet, an extranet, a VPN, a LAN, a WLAN, a WAN, a MAN, a portion of the Internet, or another link552or a combination of two or more such links552.
Each server570may be a stand-alone server or may be a distributed server spanning multiple computers or multiple datacenters. Servers570may be of various types, such as, for example and without limitation, slots server, jackpot server, gambling server, web server, news server, mail server, message server, advertising server, file server, application server, exchange server, database server, or proxy server. Each server570may include hardware, software, embedded logic components, or a combination of two or more such components for carrying out the appropriate functionalities implemented or supported by server570. For example, a web server is generally capable of hosting websites containing web pages or particular elements of web pages. More specifically, a web server may host HyperText Markup Language (HTML) files or other file types, or may dynamically create or constitute files upon a request, and communicate them to clients580in response to Hypertext Transfer Protocol (HTTP) or other requests from clients580. A mail server is generally capable of providing electronic mail services to various clients580. A database server is generally capable of providing an interface for managing data stored in one or more data stores.
In particular embodiments, one or more data storages590may be communicatively linked to one or more servers570via one or more links552. Data storages590may be used to store various types of information. The information stored in data storages590may be organized according to specific data structures. In particular embodiments, each data storage590may be a relational database. Particular embodiments may provide interfaces that enable servers570or clients580to manage, e.g., retrieve, modify, add, or delete, the information stored in data storage590.
In particular embodiments, each client580may be an electronic device including hardware, software, or embedded logic components or a combination of two or more such components and capable of carrying out the appropriate functionalities implemented or supported by client580. For example and without limitation, a client580may be a desktop computer system, a notebook computer system, a notebook computer system, a handheld electronic device, or a mobile telephone. A client580may enable a network player at client580to access network580. A client580may enable its player to communicate with other players at other clients580. Further, each client580may be a computing device, such as a desktop computer or a work station, or a mobile device, such as a notebook computer, a network computer, or a smart telephone.
In particular embodiments, a client580may have a web browser582, such as Microsoft Internet Explorer, Google Chrome, Or Mozilla Firefox, and may have one or more add-ons, plug-ins, or other extensions. A player at client580may enter a Uniform Resource Locator (URL) or other address directing the web browser582to a server570, and the web browser582may generate a Hyper Text Transfer Protocol (HTTP) request and communicate the HTTP request to server570. Server570may accept the HTTP request and communicate to client580one or more Hyper Text Markup Language (HTML) files responsive to the HTTP request. Client580may render a web page based on the HTML files from server570for presentation to the user. The present disclosure contemplates any suitable web page files. As an example and not by way of limitation, web pages may render from HTML files, Extensible Hyper Text Markup Language (XHTML) files, or Extensible Markup Language (XML) files, according to particular needs. Such pages may also execute scripts such as, for example and without limitation, those written in Javascript, Java, Microsoft Silverlight, combinations of markup language and scripts such as AJAX (Asynchronous Javascript and XML), and the like. Herein, reference to a web page encompasses one or more corresponding web page files (which a browser may use to render the web page) and vice versa, where appropriate.
Web browser582may be adapted for the type of client580where the web browser executes. For example, a web browser residing on a desktop computer may differ (e.g., in functionalities) from a web browser residing on a mobile device. A user of a social networking system may access the website via web browser582.
FIG. 10illustrates an example computer system650for implementing embodiments. In particular embodiments, software running on one or more computer systems650performs one or more operations of one or more methods described or illustrated herein or provides functionality described or illustrated herein. Although methods for implementing embodiments were described with a particular sequence of operations, it is noted that the method operations may be performed in different order, or the timing for the execution of operations may be adjusted, or the operations may be performed in a distributed system by several entities, as long as the processing of the operations are performed in the desired way.
As example and not by way of limitation, computer system650may be an embedded computer system, a system-on-chip (SOC), a single-board computer system (SBC) (such as, for example, a computer-on-module (COM) or system-on-module (SOM)), a desktop computer system, a laptop or notebook computer system, an interactive kiosk, a mainframe, a mesh of computer systems, a mobile telephone, a personal digital assistant (PDA), a server, or a combination of two or more of these. Where appropriate, computer system650may include one or more computer systems650; be stand-alone or distributed; span multiple locations; span multiple machines; or reside in a cloud, which may include one or more cloud components in one or more networks. The one or more computer systems650may perform in real time or in batch mode one or more operations of one or more methods described or illustrated herein.
In particular embodiments, computer system650includes a processor652, memory654, storage656, an input/output (I/O) interface658, a communication interface660, and a bus662. Although this disclosure describes and illustrates a particular computer system having a particular number of particular components in a particular arrangement, embodiments may be implemented with any suitable computer system having any suitable number of any suitable components in any suitable arrangement.
In particular embodiments, processor652includes hardware for executing instructions, such as those making up a computer program. As an example and not by way of limitation, to execute instructions, processor652may retrieve (or fetch) the instructions from an internal register, an internal cache, memory654, or storage656; decode and execute them; and then write one or more results to an internal register, an internal cache, memory654, or storage656. The present disclosure contemplates processor652including any suitable number of any suitable internal registers, where appropriate. Where appropriate, processor652may include one or more arithmetic logic units (ALUs); be a multi-core processor; or include one or more processors652. Although this disclosure describes and illustrates a particular processor, this disclosure contemplates any suitable processor.
In particular embodiments, memory654includes main memory for storing instructions for processor652to execute, or data that can be manipulated by processor652. As an example and not by way of limitation, computer system650may load instructions from storage656or another source (such as, for example, another computer system650) to memory654. Processor652may then load the instructions from memory654to an internal register or internal cache. During or after execution of the instructions, processor652may write one or more results (which may be intermediate or final results) to the internal register or internal cache. Processor652may then write one or more of those results to memory654. One or more memory buses (which may each include an address bus and a data bus) may couple processor652to memory654. Bus662may include one or more memory buses, as described below. One or more memory management units (MMUs) reside between processor652and memory654and facilitate accesses to memory654requested by processor652. Memory654includes random access memory (RAM).
As an example and not by way of limitation, storage656may include a Hard Disk Drive (HDD), a floppy disk drive, flash memory, an optical disc, a magneto-optical disc, magnetic tape, or a Universal Serial Bus (USB) drive or a combination of two or more of these. Storage656may include removable or non-removable (or fixed) media, where appropriate. In particular embodiments, storage656includes read-only memory (ROM). Where appropriate, this ROM may be mask-programmed ROM, programmable ROM (PROM), erasable PROM (EPROM), electrically erasable PROM (EEPROM), electrically alterable ROM (EAROM), or flash memory or a combination of two or more of these.
In particular embodiments, I/O interface658includes hardware, software, or both providing one or more interfaces for communication between computer system650and one or more I/O devices. One or more of these I/O devices may enable communication between a person and computer system650. As an example and not by way of limitation, an I/O device may include a keyboard, keypad, microphone, monitor, mouse, printer, scanner, speaker, still camera, stylus, tablet, touch screen, trackball, video camera, another suitable I/O device or a combination of two or more of these.
Communication interface660includes hardware, software, or both providing one or more interfaces for communication between computer system650and one or more other computer systems650on one or more networks. As an example and not by way of limitation, communication interface660may include a network interface controller (NIC) or network adapter for communicating with an Ethernet or other wire-based network or a wireless NIC (WNIC) or wireless adapter for communicating with a wireless network, such as a WI-FI network. As an example, computer system650may communicate with a wireless PAN (WPAN) (such as, for example, a BLUETOOTH WPAN), a WI-FI network, a WI-MAX network, a cellular telephone network (such as, for example, a Global System for Mobile Communications (GSM) network), or other suitable wireless network or a combination of two or more of these.
In particular embodiments, bus662includes hardware, software, or both coupling components of computer system650to each other. As an example and not by way of limitation, bus662may include an Accelerated Graphics Port (AGP) or other graphics bus, an Enhanced Industry Standard Architecture (EISA) bus, a front-side bus (FSB), a HYPERTRANSPORT (HT) interconnect, an Industry Standard Architecture (ISA) bus, an INFINIBAND interconnect, a low-pin-count (LPC) bus, a memory bus, a Micro Channel Architecture (MCA) bus, a Peripheral Component Interconnect (PCI) bus, a PCI-Express (PCI-X) bus, a serial advanced technology attachment (SATA) bus, a Video Electronics Standards Association local (VLB) bus, or another suitable bus or a combination of two or more of these. Bus662may include one or more buses662, where appropriate. Although this disclosure describes and illustrates a particular bus, this disclosure contemplates any suitable bus or interconnects.
Herein, reference to a computer-readable storage medium encompasses one or more non-transitory, tangible computer-readable storage media possessing structure that may store a computer program or data. As an example and not by way of limitation, a computer-readable storage medium may include a semiconductor-based or other integrated circuit (IC) (such, as for example, a field-programmable gate array (FPGA) or an application-specific IC (ASIC)), a hard disk, an HDD, a hybrid hard drive (HHD), an optical disc, an optical disc drive (ODD), a magneto-optical disc, a magneto-optical drive, a floppy disk, a floppy disk drive (FDD), magnetic tape, a holographic storage medium, a solid-state drive (SSD), a RAM-drive, a Secure Digital card, a Secure Digital drive, or another suitable computer-readable storage medium or a combination of two or more of these, where appropriate. Herein, reference to a computer-readable storage medium excludes any medium that is not eligible for patent protection under 35 U.S.C. §101.
One or more embodiments can also be fabricated as computer readable code on a non-transitory computer readable medium. Herein, reference to software may encompass one or more applications, bytecode, one or more computer programs, one or more executables, one or more instructions, logic, machine code, one or more scripts, or source code, and vice versa, where appropriate.
The present disclosure encompasses all changes, substitutions, variations, alterations, and modifications to the example embodiments herein that a person having ordinary skill in the art would comprehend.
Claims
- A method for sharing game play over a social network, comprising: executing a play session of a game by a game server, during execution of the play session providing an option to share a portion of the game for game play on the social network;in response to receiving a request to share the portion of the game, generating an instance of the game at a time when the request is received, the instance of the game inheriting a current state of the play session and including game controls for allowing interaction related to game play for the portion of the game from within a stream of the social network, and posting the instance of the game to the stream of the social network of one or more social contacts of a user initiating the request, wherein posting the instance of the game includes providing an expandable interactive application component of the game, wherein the one or more social contacts of the user are obtained from the social network in response to an application programming interface call made by the game server;computing a reward for each of the social contacts that plays the instance of the game from within the stream of the social network, and a game multiplier for rewarding the user that initiated the request, upon respective one of the social contacts playing the instance of the game claiming the reward, wherein the reward and the game multiplier are computed by, evaluating interactions provided by the social contacts during the playing of the instance of the game within the social network to determine a game state of the game, the game state used in computing the reward and the game multiplier;and dynamically updating the reward generated by the update manager to a user account of each of the social contacts that played the instance of the game and the game multiplier to the user account of the user, wherein operations of the method are executed by a game manager running on a processor of the game server.
- The method of claim 1 , wherein the generating of the instance of the game is performed on the game server executing the play session of the game and distributed to the social network server through the post.
- The method of claim 1 , wherein the generating of the reward to a user account is performed on the social network server executing the instance of the game in the stream, the reward computed using processing logic contained in the instance of the game executing on the social network server and updated to the game server.
- The method of claim 1 , wherein inheriting a current state includes inheriting one or more game attributes of the play session of the game including one or more of a game score, a game level, game tools, rewards, game options, available game incentives and game graphics related to the current state of the game.
- The method of claim 1 , wherein the posting of the instance of the game in the stream is active for a predefined life span.
- The method of claim 5 , wherein upon expiration of the predefined life span, invalidating the instance of the game in the stream of the social network.
- The method of claim 1 , wherein generating the reward to the user account that initiated the request further includes, aggregating the rewards awarded to the one or more social contacts that play the instance of the game from within the social network;and computing the game multiplier for the user that initiated the request as a function of the reward awarded to the social contacts, the game multiplier used in determining rewards for the user initiating the request during the initiating user's subsequent play of the game.
- The method of claim 1 , wherein generating a reward further includes, providing a visual indicator at the play session of the game for the user initiating the request, the visual indicator identifying the social contact playing the instance in the stream and the rewards credited to the user account of the user initiating the request and the social contact playing the instance in the stream, wherein the visual indicator is provided by the share manager.
- The method of claim 1 , further includes presenting game related incentives periodically to the social contacts to encourage participation in the game play of the portion of the game shared by the user.
- The method of claim 1 , wherein generating the reward and the game multiplier further includes, interpreting, by the update manager, user interaction detected in the portion of the game from the social contact playing with the instance of the game from within the social network;and performing game simulation to determine outcome of the game, the outcome from the game simulation used in determining the reward and the game multiplier.
- A method for sharing game play over a social network, comprising: detecting a posting of an instance of a game in a stream of one or more social contacts within the social network of a user, by a share manager within a game manager executing on at least one processor of at least one computing device, the instance of the game providing a current state of a play session for a portion of the game at a time when a request to share the game on the social network is received from the user and including controls for allowing interaction related to game play, the posting of the instance includes an expandable interactive component of the game, wherein the one or more social contacts of the user are obtained from the social network in response to an application programming interface call made by the computing device;in response to receiving a request to play the instance of the game in the stream from a user, activating the expandable interactive component of the game so as to provide an expanded online game interface within the stream, and one or more controls to play the game from within the stream of the social network by the game manager;and generating, by an update manager within the game manager, a reward for a social contact that plays the instance of the game and a game multiplier for the user sharing the instance of the game in response to game play by the social contact within the social network, the generating includes evaluating input provided by the social contact during game play to determine a game state of the game, and using the game state to determine the reward for the social contact and the game multiplier for the user;dynamically updating, by a distribution manager within the game manager, the reward generated by the update manager to a user account of the social contact that played the instance of the game and the game multiplier generated by the update manager to the user account of the user that shared the instance of the game in the stream of the social network, wherein operations of the method are executed by a processor.
- The method of claim 11 , wherein the post is active in the stream of the social network for a pre-defined life span and is automatically invalidated in the stream after expiration of the pre-defined life span.
- The method of claim 11 , wherein updating a reward further includes updating a visual indicator at a user interface rendering the play session of the game for the user that shared the instance of the game, the visual indicator identifying the user that played the instance in the stream and the reward credited to the user account of the user playing the instance in the stream, wherein the visual indicator is provided by a share manager of the game manager.
- The method of claim 11 , wherein distributing the reward to the user account that shared the instance further includes, aggregating the rewards of the one or more users that played the instance of the game in response to the user claiming the rewards;and computing the game multiplier for the user that initiated the sharing of the instance as a function of the reward provided to the one or more users, the game multiplier used in determining rewards for the user that initiated the sharing when the user initiating the sharing subsequently accesses and plays the game.
- The method of claim 11 , wherein providing the current state further includes providing one or more game attributes of the play session of the game including one or more of a game score, a game level, game tools, rewards, game options, available game incentives and game graphics related to the current state of the game.
- A non-transitory computer-readable storage medium embedding program instructions which when executed on a processor of a computer performs a method for sharing game play over a social network, the computer-readable storage medium comprising: program instructions for executing a play session of a game, during execution of the play session providing an option to share a portion of the game on the social network;program instructions for receiving a request to share the portion of the game, the program instructions for receiving is further configured to, in response to receiving the request, generating an instance of the game at a time when the request is received, the instance of the game inheriting a current state of the play session and including game controls for allowing interaction related to game play for the portion of the game from within a stream of the social network, and posting the instance of the game to the stream of the social network of one or more social contacts of a user initiating the request, wherein posting the instance of the game includes providing an expandable interactive application component of the game, wherein the program instructions for receiving further includes program instructions for making an application programming interface call to obtain the one or more social contacts of the user from the social network;program instructions for generating a reward for each of the social contacts that plays the instance of the game from within the stream of the social network and a game multiplier for rewarding the user that initiated the request, upon each one of the social contacts playing the instance of the game claiming the reward, wherein program instructions for generating the reward for each social contact and the game multiplier for the user include program instructions for evaluating interactions provided by the social contact during the playing of the instance of the game within the social network to determine a game state of the game, and program instructions for computing the reward and the game multiplier based on the game state;and program instructions for dynamically updating the reward to a user account of each of the social contacts that played the instance of the game and updating the game multiplier to the user account of the user initiating the request.
- The computer-readable storage medium of claim 16 , wherein the program instructions for generating an instance of the game further includes program instructions to inherit one or more game attributes of the play session of the game including one or more of a game score, a game level, game tools, rewards, game options, available game incentives and game graphics related to the current state of the game.
- The computer-readable storage medium of claim 16 , wherein the program instructions for generating a reward further includes program instructions for providing a visual indicator at the play session of the game for the user initiating the request, the visual indicator identifying the social contact playing the instance in the stream and the rewards credited to the user account of the user initiating the request and the social contact playing the instance in the stream.
Disclaimer: Data collected from the USPTO and may be malformed, incomplete, and/or otherwise inaccurate.