A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent disclosure, as it appears in the Patent and Trademark Office patent files or records, but otherwise reserves all copyright rights whatsoever. Copyright 2014, WMS Gaming, Inc.
Embodiments of the inventive subject matter relate generally to wagering game systems, and more particularly to wagering game systems including an application programming interface for presenting content on gaming devices.
Wager gaming, such as casino-based gaming on slot machines, has been a cornerstone of the gaming industry for several years. More recently, web-based wager gaming has become popular. For both web-based gaming and casino-style machines, the popularity of games depends on the likelihood (or perceived likelihood) of winning money and the intrinsic entertainment value of the games relative to other available gaming options. Where there are competing gaming options for which there are similar expectations of winning, players are likely to play the most entertaining and exciting games. Shrewd operators consequently strive to develop the most entertaining and exciting games, features, and enhancements to attract frequent play, and hence increase profitability to gaming operators. Therefore, there is a continuing need for wagering game providers to continuously develop new games and gaming enhancements that will attract frequent play.
Embodiments of the invention are illustrated in the Figures of the accompanying drawings in which:
This section provides an introduction to some embodiments of the invention.
Players are often loyal to particular games and game makers. Some players consistently return to a particular game because they are comfortable and familiar with the game's overall experience. Over time, players may develop an understanding about a game's graphics, sounds, animations, features, etc. Such an understanding leads the player to being comfortable with the game. After establishing a comfort level with certain games, players may resist trying new and unfamiliar games. Some embodiments of the inventive subject matter enable computing devices (e.g., smartphones, tablets, etc.) to present games from different gaming providers, while maintaining a consistent gaming experience. For example, a tablet computer may present video card games from Game Company X, and slots games from Game Company Y. The tablet computer can use similar graphics and sound to present both the card games and slots games. Additionally, there may be consistent branding and other features despite having different game providers. As a result, some embodiments enable players to play a greater variety of games, while having a consistent and familiar gaming experience.
Some embodiments provide such a common gaming experience in the form of a social casino. The social casino can facilitate social networking between players (chat, player pages, social contact lists, etc.), and offer a platform for playing wagering games. The social casino can offer meta-games by tracking game play, and offering various awards based on the game play. For example, one meta-game may unlock new games for players who achieve certain game results (e.g., slots reel combination). Another meta-game may offer a new game episode for players who have played a number of different games for a given time duration.
To facilitate the functionality described above, some embodiments utilize a computing device (e.g., tablet computer) that includes a browser, code for one or more games, and an application programing interface (API). Initially, a player may browse to a website (e.g., the social casino website) that serves web pages for configuring the browser to play games (i.e., webpages that facilitate acquisition of the wagering game code, API, and any other necessary content).
After the initial configuration, players use the browser to play games originating from one or more game makers. In some embodiments, the wagering game code controls games (e.g., determines game results), and uses the API to present graphics and audio in the browser. Some embodiments of the wagering game code do not communicate directly with the browser. Instead, they communicate with the API residing on the player's computing device. The API can receive program calls and parameters (e.g., game results) from the wagering game. The API can specify gaming content for presentation by the browser. The browser can present the content using graphics, audio, animations, etc. that create a particular gaming experience. Embodiments of the API allow the browser to present gaming content from any wagering game capable of calling the API. The discussion of
In
The system 100 can also include a meta-game module (not shown) for conducting meta-games. Meta-games can award prizes for game play and results related to the wagering games controlled by the wagering game modules 102, 103. For example, the meta-game module can unlock various content (games, episodes, etc.) based on play duration, game results, money spent, etc.
During operation (see stage 1), a player can direct the computing device's browser 106 to request a first wagering game controlled by the wagering game module 102. In turn (see stage 2), the browser 106 transmits a gameplay request to the wagering game module 102. The wagering game module 102 responds to the gameplay request by calling the API 108 to initiate a wagering game in the browser 106. In response to the API call, the API 108 executes program code associated with the call. The API program code transmits parameters, data, content, and other information to the browser 106, and the browser 106 presents content representing wagering game.
In some embodiments, the API 108 acts as an “adapter” enabling any wagering game module capable of calling the API 108 to present wagering games in the browser 106. Furthermore, in some embodiments, the API 108 assumes responsibility for formatting information to be compatible with the browser 106. Therefore, in some embodiments, the wagering game modules 102, 103 need not contain components capable of formatting content for presentation on the browser 106. In
Although the browser 106 presents games created by different game makers, embodiments provide players with a consistent gaming experience on the computing device 104. The game window 110 shows a game controlled by wagering game module 102, whereas the game window 112 shows a game controlled by wagering game module 103. Although each game was made by a different game maker, both game windows include similar controls 115, avatars 113, messaging 114, and branding 116. As a result, irrespective of which wagering game module controls the wagering games, players have a consistent game experience.
Although
The computer system also includes a bus 203 (e.g., PCI, ISA, PCI-Express, HyperTransport®, InfiniBand®, NuBus, etc.), a network interface 205 (e.g., an ATM interface, an Ethernet interface, a Frame Relay interface, SONET interface, wireless interface, etc.), and a storage device(s) 209 (e.g., optical storage, magnetic storage, etc.).
The system memory 207 includes components to implement embodiments described above. For example, the system memory 207 includes a browser 204, meta-game module 206, and API 208. The browser 204 can fetch and present information stored locally, and information received over a network (e.g., World Wide Web). In some embodiments, the browser 204 can include any suitable off-the-shelf browser (e.g., Google's Chrome browser, Microsoft's Internet Explorer, etc.). Such an off-the-shelf browser may be augmented with various components to achieve the functionality described herein. For example, the browser 204 can include a programming language interpreter, such as a Javascipt interpreter, Java® interpreter, etc. In some instances, the browser 204 includes a meta-game module 206. The meta-game module 206 can include any suitable code (e.g., Java® code) configured to conduct meta-games based on results of games controlled by The meta-game module 206 may use locally stored graphics, animations, audio, etc. to present the wagering games in the browser 204.
The wagering game API 208 can include program code for processing calls from the wagering game module(s) 207. Various components can call the API 208 to provide a set of functionality including wagering-game-specific services (e.g., see discussion of
In responding to calls, embodiments of the API 208 execute functionality corresponding to the calls (e.g., the keywords). For some calls, the API communicates with remote devices (e.g., account servers, advertising servers, wagering game machines, social networking servers, etc.) to determine results for the call. For other calls, the API 208 may use only local functionality. For some calls, the API 208 can return information to the caller, or otherwise provide information to the caller and other devices (e.g., the web browser 204). Referring back to the example call from above, the API 208 can execute functionality associated with the “CreditInfo” call, and provide credit information back to the wagering game module 207.
According to some embodiments, wagering game modules can utilize the API 208 to facilitate presentation of wagering games. For example, a player may want to play wagering games in the web browser 204 on the computing device 200 (e.g., a tablet computer). Because the computing device 200 includes the API 208, a wagering game module 207 can utilize the API 208 and to present content (e.g., game results, etc.) on the browser 204. The wagering game module 207 need not be equipped with logic for formatting content for presentation on the browser 204. Instead, the wagering game module 207 can utilize the API 208 to facilitate presentation of content by the browser 204. In some embodiments, the API 208 can service calls from a plurality of wagering game modules, while providing content to the tablet's browser in a consistent format. That is, regardless of which wagering game module calls the API 208, the API 208 causes the browser to present content in a particular format. Such a consistent format enables the browser to present a consistent gaming experience, even if the browser is presenting content in response to different wagering game modules.
The memory 207 also includes a messaging service 209 that receives and publishes event messages indicating operations and events occurring in the computing device 200. The events can be game results, timer events indicating durations of game play or other operations, coin-in events, win award events, or any other suitable events. In some embodiments, the meta-game module conducts meta-games based on events occurring in the computing device 200. For example, the meta-game module may conduct a meta-game in which game pieces progress based on winning/losing events in wagering games (see discussion of
Some embodiments may include fewer or additional components not illustrated in
As noted above, the computing device can communicate with remote devices, such as wagering game servers.
The computer system also includes a bus 303 (e.g., PCI, ISA, PCI-Express, HyperTransport®, InfiniBand®, NuBus, etc.), a network interface 305 (e.g., an ATM interface, an Ethernet interface, a Frame Relay interface, SONET interface, wireless interface, etc.), and a storage device(s) 309 (e.g., optical storage, magnetic storage, etc.).
The system memory 307 includes components to implement embodiments described above. For example, the system memory 307 includes a wagering game module 304 that can determine results for wagering games, such as slots, keno, blackjack, poker, baccarat, etc. The wagering game unit 304 can provide wagering game content (e.g., wagering game results, graphics, audio, video, etc.) to any number of remote devices. For example, the wagering game module 304 can provide results to wagering game machines and computing devices residing at disparate locations (e.g., casinos in Las Vegas, Nev. and Atlantic City, N.J.). In some embodiments, the wagering game unit 304 makes calls to remote APIs, as part of a process for presenting wagering games on remote devices. Some embodiments of the wagering game server perform operations described below (e.g., see
Although not shown, the wagering game server 300 can include components for producing and transmitting web pages to remote web clients. For example, the system memory 307 can include a web server that provides web pages to remote devices.
Any component described herein can include hardware, firmware, and any computer readable media including instructions (e.g., program code) for performing the operations described herein. Any combination of one or more computer-readable medium(s) may be utilized. The computer-readable medium may be a computer-readable signal medium or a computer-readable storage medium. Some examples (a non-exhaustive list) of the computer-readable storage medium include the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer-readable storage medium may be any tangible medium that can store a program for use by or in connection with an instruction execution system, apparatus, or device.
A computer-readable signal medium may include a propagated data signal with computer-readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer-readable signal medium may be any computer-readable medium that is not a computer-readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code embodied on a computer-readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
This discussion continues with a description of several operational flows for utilizing an API to present wagering games in a browser. In the discussion below, sequence diagrams describe communications between a browser, API, and wagering game module. In some embodiments, the API, browser, and wagering game module reside on a computing device (e.g., see
In
In the sequence diagram 400, stage 2 shows how the components handle a general error. The discussion about error handling will postponed until later (see discussion of stage 2 below).
At stage 3, the API 408 responds to the wagering game module's request for credit information by sending a message including the credit information (e.g., initial bet denominations, credits per bet line, etc.). As noted, the API 408 may have received this information from a remote service. The wagering game module 406 verifies that the player has enough credits to play by checking whether the player's credit balance will cover any initial bet. If the credit balance will not cover the initial bet, the system proceeds to stage 4. If credit balance is sufficient to cover the initial bet, the system proceeds to stage 5.
During stage 4, the wagering game module 406 transmits to the API 408 a message indicating there are not enough credits to cover the initial bet. The API 408 responds by transmitting a “pause” event back to the wagering game module 406. The wagering game module 406 remains in a “pause” state until the credit issue is resolved. Because there are not enough credits, the API 406 instructs the browser 404 to present content for acquiring or credits from the player 402 (see “pop payment” message). Although not shown, the browser 404 may communicate with other devices (e.g., a remote bank website, a player account website, etc.) to acquire enough credits to play the game. In turn, the browser 404 transmits to the API 408 a message indicating the payment event has concluded. At this point, there are enough credits to play the wagering game. Next, the API 408 transmits to the wagering game module 406 a message to resume the wagering game (i.e., the message prompts the module 406 to move out of the “pause” state).
At stage 5, the player plays the wagering game. For a slots game, the module 406 presents spinning reels, and the results. The stages continue in
After the player has played the base game and any bonus game, the system updates credit meters and performs other tasks, as shown in stages 7-9. In stage 7, if player has won the game, the module 406 generates a win amount. Next, the module 406 calls the API 408 to save results of the game. In response, the API sends a “pause” event to the module 406, causing the module 406 to remain in a paused state. If errors occur, stage 8 shows error handling operations (described later). During stage 9, the API 408 instructs the browser 404 to update credit meters. In some embodiments, this communication prompts the browser 404 to update data structures tracking credits on the credit meters, and credit meter graphics in the browser's user interface.
After the player 402 has achieved a result of the wagering game, the result (or other factors) may cause the game to “level-up”, and new content may be unlocked. Stages 10-12 show operations and communications associated with these events.
During stage 11, the API 408 transmits a series of messages to the browser 404. Among the messages, the API 408 transmits content that instructs the browser to increment a “level-up” indicator in the user interface (e.g., on the gaming webpage). Additionally, the API 408 instructs the browser to present celebrations for the level-up, where the celebrations include graphics for the level-up. The API 408 also transmit content that instructs the browser to present animations that update the credit meter amounts earned from the level-up. As part of unlocking the new level, the API 408 initializes a play time progress bar in the browser 404. That is, the API 408 resets a graphical bar indicating how much time a player has been playing the game (referred to as XP progress bar in
Stage 12 shows operations and communications for unlocking a new game. In some instances, results from the wagering game may cause the system to unlock a completely new wagering game (e.g., a different wagering game). During stage 12, the API 408 transmits content that instructs the browser 404 to display information related to unlocking the new game, such as a passcode for unlocking the new game. Alternatively, the API's message may automatically unlock new content, and the browser 404 may display information about the new game. The API 408 also transmits a message instructing the browser 404 to that the game results have been saved, and the API 408 transmits a resume event to the wagering game module 406 and any other listeners. Additionally, the wagering game module 406 updates the new game with a new credit balance amount.
As discussed above, the system may encounter general errors. Stage 2 shows operations communications for handling such errors. Upon encountering a general error, the API 408 publishes (e.g., via the messaging service described herein) a pause event to listeners including the wagering game module 406. In response, the wagering game module 406 enters a paused state. Next, the API 408 transmits content instructing the browser 402 to present an error message in the user interface. In response to presenting the error message, the browser 402 may receive input from the player 400. The player input may (explicitly or implicitly) instruct the browser 402 to terminate the error handling sequence. In turn, the browser 402 transmits to the API 408 a request to terminate the error event. In response to the request to close the error event, the API 408 transmits a “resume event” message to the module 406, causing the server to resume operation.
This discussion continues with a description of operations for configuring a computing device (e.g. tablet computer, mobile phone, etc.) to present wagering games in a browser. After the computing device is configured to include all necessary components, it can present wagering games (including meta-games).
The flow 700 begins at block 702, where a browser requests a webpage for wagering game website. At block 704, the browser receives the webpage from the wagering game website. In some embodiments, the webpage includes code for determining whether the computing device includes a wagering game API that facilitates wagering games in the browser. The flow continues at block 706.
At block 706, code in the webpage (or code accessed via a link in a webpage) determines whether the wagering game API is available on the computing device. If the API is not available, the flow continues at block 708. Otherwise, the flow continues at block 710.
At block 708, the computing device downloads the wagering game API. This and other operations in this flow can be performed under control of code in the webpage, code accessible by a link in the web page, code downloaded to the browser from a website, etc. In some embodiments, the browser executes the code regardless of its source. After downloading the API, the flow continues at block 710.
At block 710, code in the webpage (or otherwise available from accessing webpage) determines whether games have been downloaded to the computing device. If not, the code downloads one or more wagering game modules to the computing device. The code may also download a meta-game module. In some embodiments, the modules include code executable on the browser. In some embodiments the modules can be browser extensions or plug-ins configured to operate via the browser, and present content in the browser. If modules have already been downloaded to the browser, the flow continues at block 714.
At this point, the gaming device, which includes a browser, has been configured with the wagering game API, wagering game modules, and meta-game module. At block 714, the browser presents game options. Some embodiments include code for controlling presentation of game options and other content. For example, the meta-game module may control presentation of game options. The flow continues at block 716.
At block 716, a game selection is received. The meta-game (or other control code) receives the game selection, and passes control to the wagering game module responsible for controlling the selected wagering game. At block 718, a wagering game module presents the wagering game. At block 720, the meta-game module (or other code, as noted above) presents post-game content, such as celebrations, information, etc. The post-game content can include information about the wagering game, such as credits won/lost, time playing game, total bets made, total bets won, total bets lost, etc. The post-game content can include the same graphics and sound for wagering games from different game manufacturers, so players have a common gaming experience across games (e.g. a social casino provides a common gaming experience for all games). After block 720, the flow ends.
As noted above, some embodiments offer a meta-game. The meta-game can use results from other games to cause progress of the meta-game. For example, if a player plays a particular game for a given time duration, the meta-game can unlock new content for the particular game. As another example, the player achieves a given result in a slots game, the result may cause movement of game pieces in the meta-game. Events that may be relevant to meta-games can include events arising from wagering games (e.g., a combination of slot reels), events arising from interactions with the browser (e.g., use of particular buttons), events arising from interactions with certain websites (e.g., use particular URLs), etc.
At block 804, the meta-game module receives one or more event messages arising from operations of the wagering game modules (e.g., game results), API (e.g., duration of game play, credit information), browser (e.g., player input), etc. At block 806, the meta-game module determines whether one or more events are relevant to progress of the meta-game. If the events are irrelevant, the flow loops back to block 804.
If the events are relevant, the flow continues at block 808, where the meta-game progresses based on the one or more events. At block 810, the meta-game module determines whether to present an award. For example, if the meta-game progressed to an award state (e.g., winning pay line in slots game), the meta-game module presents an award to the player. In some embodiments, presenting the award may include paying money to the player account or other operations for providing monetary value to the player. In some embodiments, the award may include unlocking content (e.g., game episodes, new games, etc.). The flow continues at block 814.
At block 814, the meta-game module determines whether the meta-game is over. If the meta-game is over the flow ends. Otherwise, the flow loops back to block 804.
Each casino 912 includes a local area network 916, which includes an access point 904, a wagering game server 906, and wagering game machines 902. The access point 904 provides wireless communication links 910 and wired communication links 908. The wired and wireless communication links can employ any suitable connection technology, such as Bluetooth, 802.11, Ethernet, public switched telephone networks, SONET, etc. In some embodiments, the wagering game server 906 can serve wagering games and distribute content to devices located in other casinos 912 or at other locations on the communications network 914.
The wagering game machines 902 described herein can take any suitable form, such as floor standing models, handheld mobile units, bartop models, workstation-type console models, etc. Further, the wagering game machines 902 can be primarily dedicated for use in conducting wagering games, or can include non-dedicated devices, such as mobile phones, personal digital assistants, personal computers, etc. In one embodiment, the wagering game network 900 can include other network devices, such as accounting servers, wide area progressive servers, player tracking servers, and other devices suitable for use in connection with embodiments of the invention.
In some embodiments, wagering game machines 902 and wagering game servers 906 work together such that a wagering game machine 902 can be operated as a thin, thick, or intermediate client. For example, one or more elements of game play may be controlled by the wagering game machine 902 (client) or the wagering game server 906 (server). Game play elements can include executable game code, lookup tables, configuration files, game outcome, audio or visual representations of the game, game assets or the like. In a thin-client example, the wagering game server 906 can perform functions such as determining game outcome or managing assets, while the wagering game machine 902 can present a graphical representation of such outcome or asset modification to the player (e.g., player). In some embodiments, the wagering game machine 902 includes a browser and API, as described above. In such embodiments, the wagering game machines 902 can provide the functionality described herein (e.g., perform operations and communications similar to those described above).
In some embodiments, either the wagering game machines 902 (client) or the wagering game server 906 can provide functionality that is not directly related to game play. For example, account transactions and account rules may be managed centrally (e.g., by the wagering game server 906) or locally (e.g., by the wagering game machine 902). Other functionality not directly related to game play may include power management, presentation of advertising, software or firmware updates, system quality or security checks, etc.
Any of the wagering game network components (e.g., the wagering game machines 902) can include hardware and machine-readable media including instructions for performing the operations described herein.
While the inventive subject matter is susceptible of embodiment in many different forms, there is shown in the drawings and herein described in detail preferred embodiments with the understanding that the present disclosure is to be considered as an exemplification of the principles of the inventive subject matter and is not intended to limit the broad aspect of the inventive subject matter to the embodiments illustrated. For purposes of the present detailed description, the singular includes the plural and vice versa (unless specifically disclaimed); the words “and” and “or” shall be both conjunctive and disjunctive; the word “all” means “any and all”; the word “any” means “any and all”; and the word “including” means “including without limitation.”
For purposes of the present detailed description, the terms “wagering games,” “gambling,” “slot game,” “casino game,” and the like include games in which a player places at risk a sum of money or other representation of value, whether or not redeemable for cash, on an event with an uncertain outcome, including without limitation those having some element of skill. In some embodiments, the wagering game may involve wagers of real money, as found with typical land-based or on-line casino games. In other embodiments, the wagering game may additionally, or alternatively, involve wagers of non-cash values, such as virtual currency, and therefore may be considered a social or casual game, such as would be typically available on a social networking web site, other web sites, across computer networks, or applications on mobile devices (e.g., phones, tablets, etc.). When provided in a social or casual game format, the wagering game may closely resemble a traditional casino game, or it may take another form that more closely resembles other types of social/casual games.
This detailed description refers to specific examples in the drawings and illustrations. These examples are described in sufficient detail to enable those skilled in the art to practice the inventive subject matter. These examples also serve to illustrate how the inventive subject matter can be applied to various purposes or embodiments. Other embodiments are included within the inventive subject matter, as logical, mechanical, electrical, and other changes can be made to the example embodiments described herein. Features of various embodiments described herein, however essential to the example embodiments in which they are incorporated, do not limit the inventive subject matter as a whole, and any reference to the invention, its elements, operation, and application are not limiting as a whole, but serve only to define these example embodiments. This detailed description does not, therefore, limit embodiments of the invention, which are defined only by the appended claims. Each of the embodiments described herein are contemplated as falling within the inventive subject matter, which is set forth in the following claims.