AirConsole Unity Plugin
The Unity-Plugin is a C# wrapper for the AirConsole Javascript API. With the plugin, Unity serves you the needed screen.html file inside the Editor and creates a screen.html file after an WebGL build export.
Before you start installing the plugin, be aware that because we support such a wide range of Unity versions, some Unity versions have some known issues when importing the plugin or when building for a specific platform. Below you will find the list of known issues and their fixes:
Affected versions | Description | Solution |
---|---|---|
Unity 2022+ | After trying to build for Android TV you may get this error: mainTemplate.gradle is using the old aaptOptions noCompress property definition does not include types defined in unityStreamingAssets constant. | Edit Assets/Plugins/Android/mainTemplate.gradle and launcherTemplate.gradle to add/replace the aaptOptions section to the following: aaptOptions {
noCompress = ['.ress', '.resource', '.obb'] + unityStreamingAssets.tokenize(', ')
ignoreAssetsPattern = "!.svn:!.git:!.ds_store:!*.scc:.*:!CVS:!thumbs.db:!picasa.ini:!*~"
}**PACKAGING_OPTIONS** Check Unity support for more details. |
Unity 2021+ | After importing the AirConsole plugin into Unity you may get this error: Multiple precompiled assemblies with the same name Newtonsoft.Json.dll included on the current platform. [...] | Delete the following plugin file (It is now included in Unity directly and is not needed in newer Unity versions): Assets/AirConsole/plugins/Newtonsoft.Json.dll |
Unity 2018.3 | After importing the AirConsole plugin into Unity you may get: The type or namespace name 'ILGenerator' could not be found (are you missing a using directive or an assembly reference?) and The type or namespace name 'DynamicMethod' could not be found (are you missing a using directive or an assembly reference?) | Set the API Compatibility Level to .NET 4.x in the Player Settings of your selected Platform. Check AirConsole FAQ for more details. |
Download from Github
Download the newest AirConsole-Unity-Plugin on our GitHub repository. You can find the newest ".unitypackage" file in the "Builds" folder.
Download from Assetstore
Learn the basics of how to make an AirConsole game in Unity in just 4 minutes.
To import the plugin, click on Assets > Import Package -> Custom Package and choose the downloaded *.unitypackage file.
data:image/s3,"s3://crabby-images/5f47d/5f47d0c93721cf6dbb86af2066f94159bd2bbacc" alt="Document image Document image"
Make sure that all assets are selected and click on "Import".
data:image/s3,"s3://crabby-images/36156/3615677725db5d20dac7e7e4bbc302e380548819" alt="Document image Document image"
Instantiate AirConsole object
To set up the communication inside a scene, you have to instantiate the AirConsole object. In the Hierarchy window, click on Create > Create Other > AirConsole.
data:image/s3,"s3://crabby-images/9291f/9291f1526ae59d3be9db2ed8d59754baba2c6364" alt="Document image Document image"
The AirConsole object offers you the following options:
Option | Description |
---|---|
Browser Start Mode | As soon as you press the “Play” button in Unity, your default browser will open the AirConsole simulator in the chosen mode. |
Controller Html | Link your controller.html file to this inspector variable, otherwise you can’t start the AirConsole simulator and you will get an error message. (Note: if your controller needs additional files like images or fonts, put them in the folder “Assets/WebGLTemplates/AirConsole”) |
Auto Scale Canvas | This option is enabled by default and scales your final webgl canvas automatically to the window size. The aspect ratio will be kept during the scaling. |
data:image/s3,"s3://crabby-images/57f21/57f21f9d3174940368d6891665fd60c42efee6c8" alt="Document image Document image"
Here is a simple example where the controller sends "How are you?" to the screen and the screen replies with "Full of pixels!"
Include the AirConsole Javascript API in your controller.html file:
/controller.html
Unity
To be able to receive a message in Unity, create a new Unity MonoBehaviour class and include these namespaces:
Add an event handler in the Start method of the MonoBehaviour class:
When you send an object like this one on the controller.html side:
You can parse the object in Unity like this:
To send the same data from Unity you can use dynamic vars:
To test your game, just hit the “Play” button inside the Unity-Editor. If you want to test the final WebGL-Build, choose the right AirConsole Template in the PlayerSettings first (For Unity versions 2020 and up choose the AirConsole-2020 template, for previous Unity versions choose the AirConsole template):
data:image/s3,"s3://crabby-images/f7774/f7774b6e3f3da403dc366e0685cfd971be19da95" alt="Document image Document image"
Now you can export your Unity project in the Build-Settings (choose “Build” instead of the “Build and run” button). As soon as your build is exported, the button “Open Exported Port” on the AirConsole object in your scene will appear. By pressing this button, the AirConsole simulator will start with your final build.
data:image/s3,"s3://crabby-images/9283a/9283a85ec925e27237bfedccb849911a72c5e2cf" alt="Document image Document image"
- AirConsole/Examples/Basic/basic.scene: In this example all possible API functions are listed & used.
- AirConsole/Examples/Pong/pong.scene: This example contains a simple pong game with a specific controller.
data:image/s3,"s3://crabby-images/1e8f1/1e8f19cc826ecf24b9f397b55f64784e7cdc4dfe" alt="Document image Document image"
You can open the settings window by clicking on the "Settings" button on the inspector of the AirConsole object or by navigating over the menu bar AirConsole > Settings.
data:image/s3,"s3://crabby-images/ae6e7/ae6e7f5bf723cc9b72641569655844acb2df6a03" alt="Document image Document image"
In the "Settings" window, the ports for the internal web socket and web server can be changed, should the default ports already be occupied.
You can stop and restart the internal web server in case the AirConsole simulator isn't working properly.
data:image/s3,"s3://crabby-images/a7c45/a7c456ccd2a64a617ce102a2aa17ca9d5dd23fd7" alt="Document image Document image"
AirConsole also provides an AndroidTV app, so that user can play your games also on a smart-tv. Please read the "AirConsole Unity on AndroidTv" documentation to adapt your game for AndroidTV.