Awesome
Azure App Services for Unity3d
Contains a Unity 5 project featuring two demo scenes for Azure App Services (previously Mobile Services).
- Highscores demo scene
- Inventory demo scene
:octocat: Download instructions
This project contains git submodule dependencies so use:
git clone --recursive https://github.com/Unity3dAzure/AppServicesDemo.git
Or if you've already done a git clone then use:
git submodule update --init --recursive
Highscore demo features
- Client-directed login with Facebook
- Insert Highscore
- Update Highscore
- Read list of Highscores using infinite scrolling (hall of fame)
- Query for today's top ten highscores (daily leaderboard)
- Query for username (user's scores)
Inventory demo features
- Client-directed login with Facebook
- Load User's inventory.
- Save User's inventory. (Inserts if new or Updates existing record)
Developer blogs
Setup Azure App Services for Unity
- Create an Azure Mobile App
- Create 'Highscores' and 'Inventory' table for storing app data using Easy Tables.
- In Unity open scene file(s) inside the Scenes folder:
- HighscoresDemo.unity
- InventoryDemo.unity
- Then select the AppServicesController gameobject in the Unity Hierarchy window and paste your Azure App Service URL into the Editor Inspector field.
Setup Azure App Services with Authentication
This demo uses Facebook identity to save user's highscore or inventory items:
- Create Facebook app
- Fill in the Azure App Services Authentication settings with Facebook App Id & App Secret.
- Paste Facebook access user token into Unity access token field to enable Login button.
- Modify 'Highscores' and 'Inventory' table script (using 'Insert' snippet below) to save
user.id
Easy Table Insert script (tables/Highscores.js, tables/Inventory.js)
var table = module.exports = require('azure-mobile-apps').table();
table.insert(function (context) {
if (context.user) {
context.item.userId = context.user.id;
}
return context.execute();
});
Setup Azure App Services custom APIs with Easy APIs
With Azure App Services you can create custom APIs using Easy APIs.
- Create a 'hello' api (using "get" method) to say hello! (Example Easy API message script below)
- Create a 'GenerateScores' api (using "post" method) to generate 10 random scores. (Example Easy API query script below)
Easy API 'hello' script (api/hello.js)
module.exports = {
"get": function (req, res, next) {
res.send(200, { message : "Hello Unity!" });
}
}
Easy API 'GenerateScores' script (api/GenerateScores.js)
var util = require('util');
module.exports = {
"post": function (req, res, next) {
var insert = "INSERT INTO Highscores (username,score) VALUES ";
var i = 10;
while (i--) {
var min = 1;
var max = 1000;
var rand = Math.floor(Math.random() * (max - min)) + min;
var values = util.format("('%s',%d),", 'Zumo', rand);
insert = insert + values;
}
insert = insert.slice(0, -1); // remove last ','
var query = {
sql: insert
};
req.azureMobile.data.execute(query).then(function(results){
res.send(200, { message : "Zumo set some highscores!" });
});
}
}
Known issues
- There is an issue with PATCH on Android using UnityWebRequest with Azure App Services.
Android doesn't support PATCH requests made with UnityWebRequest needed to perform Azure App Service updates.
One workaround is to enable the
X-HTTP-Method-Override
header. Here's the quick fix for App Services running node backend:- Install the "method-override" package.
npm install method-override --save
- In 'app.js' file insert:
var methodOverride = require('method-override'); // after the line "var app = express();" add app.use(methodOverride('X-HTTP-Method-Override'));
- Install the "method-override" package.
This will enable PATCH requests to be sent on Android.
Credits
- Inventory uses pixel art icons designed by Henrique Lazarini
Dependencies included
- TSTableView is used to display recyclable list of results.
Dependencies installed as git submodules
- AppServices for Unity.
- RESTClient for Unity.
Refer to the download instructions above to install these submodules.
Questions or tweet #Azure #GameDev @deadlyfingers