Construct
In this guide you will learn how to use the Construct2 AirConsole plugin to add local multiplayer to your game.
data:image/s3,"s3://crabby-images/294e5/294e58408a9a8765a71b6ec2ec33248b88ea751a" alt="Document image Document image"
Crystal Control - made with Construct2
You can download the plugin files at our airconsole-construct2 github repository.
- Open Construct2.
- Drag and drop the airconsole.c2addon file into the Construct2 window.
To be able to use the AirConsole in a Construct2 game you have to add a new object type. You will find the AirConsole Plugin in the "Web" category.
data:image/s3,"s3://crabby-images/f82f9/f82f94b58be38d4c0f256f82450fd0f386cb4507" alt="Document image Document image"
If you create a new event in an event sheet, then you will find the following condition options:
data:image/s3,"s3://crabby-images/debbb/debbb636ec770e340d28d600eb483a28f8fb7ea5" alt="Document image Document image"
Conditions reference:
Name | Description |
---|---|
On device custom state check | Triggered when a device custom state matches a value (E.g. when calling airconsole.setCustomDeviceState({key: value}) on a controller). |
On message | Triggered when a device sends a message ({message: "your-value"}) to the screen and the device id matches |
On specific message | Triggered when a specific message is received from a specific device. |
On message from | Triggered when any message is received from a specific device. |
On message key | Triggered when a device sends a message ({key: "your-value"}) and the key matches (Use this if the sender device id does not matter - e.g. for an action to start the game) |
On device join | Triggered when a device joins |
On device left | Triggered when a specific device disconnects |
On any device left | Triggered when any device disconnects. |
On too many players | Triggered when max players is exceeded. |
OnPause | Triggered to pause the game. Pause should also pause any audio. |
onResume | Triggered to resume the game again. |
The following actions are available:
data:image/s3,"s3://crabby-images/8b9aa/8b9aaaa93c03f05743a8b07d1341011bb1ce066c" alt="Document image Document image"
Actions reference:
Name | Description |
---|---|
Broadcast data | Sends a message to all connected devices |
Send data | Sends a message to a specified device id |
Game ready | Sends a message to all devices that the game is ready (Use this always on game start!). |
Set custom device state | Sets the screen-device custom state (Same as calling airconsole.setCustomDeviceState({key: value}) in the API). |
Set active players | Takes all currently connected controllers and assigns them a player number. Can only be called by the screen. The assigned player numbers always start with 0 and are consecutive. You can hardcode player numbers, but not device_ids. Once the screen has called setActivePlayers you can get the device_id of the first player by calling convertPlayerNumberToDeviceId(0), the device_id of the second player by using ConvertPlayerNumberToDeviceId(1). You can also convert device_ids to player numbers by using ConvertDeviceIdToPlayerNumber(device_id). You can get all device_ids that are active players by using GetActivePlayerDeviceIds(). |
Show ad | Show ad on every connected controller and screen. onAdComplete is called when showing ad is over |
data:image/s3,"s3://crabby-images/ee61c/ee61c008a7437580aafffbf86d38dcb69bc41148" alt="Document image Document image"
Update December 2022:
Name | Description |
---|---|
GetLanguage | Gets the language ISO Code (E.g. 'en', 'es') |
GetTranslation | Gets the translation for a translation-key |
You can find more about expressions in this tutorial.
Max players | Sets the maximum amount of players the game can handle. (All other players who join after that should get a message like "Game is full") |
---|---|
Use translations | Set to True if your game uses translations and you want to load them |
Look at some of the examples on how to use the methods.
ControllerDeviceIds
data:image/s3,"s3://crabby-images/22967/22967d527886523738a2a87a8ee9a5ba37630c6b" alt="Document image Document image"
MasterControllerDeviceID
data:image/s3,"s3://crabby-images/d8720/d87208048cc22089d62e33a7838b55e23dc3c8f4" alt="Document image Document image"
ActivePlayerDeviceId
data:image/s3,"s3://crabby-images/fc53f/fc53ffaf88a80e1bc725382ed81d0f62a97ad14c" alt="Document image Document image"
Storage
data:image/s3,"s3://crabby-images/3dd87/3dd87f3dbe758b21e84d353d0db7ad1ebec4a24d" alt="Document image Document image"
For a usual HTML5 game we would normally just wait for the screen.html to load and then handle the devices. With Construct2 we have to wait for the entire game to initialize, because we are "talking" with AirConsole in the Construct2 context.
Construct2 game ready event - Asking "who is here?"
Simply call theAirConsole.GameReadyaction once as soon as the game has started. This will broadcast a message to every already connected controller with the data{ handshake: true }.
data:image/s3,"s3://crabby-images/0f0f6/0f0f6aed471f08a017f454435492ab4448c27e8e" alt="Document image Document image"
Code in controller.html - Replying "me is here"
The controller listens for the{ handshake: true }data in theonMessagemethod:
The controller will send a message back to the screen and triggerAirConsole.onDeviceJoinevents in Construct2, which you will also have to add. :)
To send a message from a controller to the screen you have to stick to certain keys in the JSON data you send, so that the Construct2 plugin knows which condition you want to trigger.
Key | Type | Description |
---|---|---|
handshake | <Boolean> | Send this as soon as the game is loaded and to register the controller. |
key | <String> | Applied to the AirConsole.MessageKey expression |
message | <String> | Applied to the AirConsole.Message expression |
For example
Export the game as a usual HTML5 game. AirConsole will request a/screen.html, which is why you should rename theindex.htmlintoscreen.html. And of course, don't forget to create acontroller.htmlin the same directory, which includes the functionality for the controllers.
As soon as your game is ready make a zip file of the whole directory (screen.html and controller.html in the root) and publish it on AirConsole.
To show you how all of this works together we will go through our example (very basic) pong game.
data:image/s3,"s3://crabby-images/9775d/9775d24948c6ccf9f2583eedf7243050d2a08e2d" alt="Document image Document image"
Event sheet
data:image/s3,"s3://crabby-images/0d73e/0d73e230120dcea78b7a6f23b0200a8c8bbfdc20" alt="Document image Document image"
Trigger the GameReady Event
As mentioned before, you ALWAYS have to trigger a Game ready event when the game has loaded, so that the controllers can tell us they are there.
data:image/s3,"s3://crabby-images/90b71/90b715cdb70713b456091b57264c8fb0cb7a4cde" alt="Document image Document image"
Store and assign device_ids
Every controller owns a paddle-sprite. Which means if controller-2 presses the up-button, then we want the right paddle to move up. That means we have to know which device belongs to which sprite. We can achieve this by creating global vars for each device the game will support (In pong two global vars, because we will just have two players in our game).
data:image/s3,"s3://crabby-images/a870b/a870ba2c9a442e3af939fba816d1e6b02ef687d7" alt="Document image Document image"
If the first controller connects "On device join", then we assign the joined AirConsole.device_id to the global DeviceID1_Move. The second devices which connects get assigned to DeviceID2_Move.
Device joins, set the device_id
With the conditionAirConsole.onDeviceJoinwe can listen for events when a new device joins. If device joins, then assign the global variable device_id to the value ofAirConsole.DeviceIDJoin. The tricky part here is to have the order of devices which join in mind. This means the first player who joins should be assigned to DeviceID1. The second player should be the DeviceID2. Consequently we also have to check if the DeviceID1 already has a value. If yes, we check if the DeviceID2 var has none and if that is true we assign the device_id.
Move paddles
To move our paddles we create another two global vars calledDeviceID1_MoveandDeviceID2_Move. Each of them can have one of the 3 values:
- -1 = Move up
- 0 = Stop
- 1 = Move down
Send a message from a controller to the screen
Our controller will only consist of two buttons: move up and move down. If we press one of this buttons we will send a message to the game (screen) and the corresponding paddle-sprite object should move - or if we release a button it should stop.
Ourcontroller.htmlcontains the following code:
Now the game has to listen to a message which has the content "up", "down" or "stop".
In our event sheet, you can see two events of "On receive message data". They were added by the AirConsole.onMessage event like this:
data:image/s3,"s3://crabby-images/44458/444587239c344ddf16d4ae4b9f5742aef4bea9f3" alt="Document image Document image"
To sum it up: IF message == "up" AND device_id matches the value of DeviceID1 THEN we set the variableDeviceID1_Moveto -1, which means our sprite moves down.
The same happens with message == 'stop' or message == 'down'.
Game won't work because of Javascript errors
If you get any javascript errors try to export your game without checking the "Minify script" checkbox.