A mini-game framework aiming at game jams.
The main idea behind this framework is to be able to aggregate mini-games, like in WarioWare. Each mini-game can be developed independently, and then integrated into the game through this framework and a simple API. We only deal with Web-based games here, but you should be able to use plugin-based Web technologies like flash or Unity3D as well.
The framework handles the global state of the game, with lifes, level and the score.
The current stylesheet of the framework is quite ugly, it is up to you to customise it to your needs ;)
Your mini-game must be in a folder with the following structure:
- YourMiniGame folder
- index.html: the main page that will be loaded by the framework
- manifest.json: a manifest describing your game (more on that later)
- thumbnail.jpg: (optional) a thumbnail of your game, 800x480
There is no other restriction in the content of the folder. When it's done, you can put this folder in the CoinWare folder and modify the config.js file to include your mini-game name in the gamesId array.
To simplify the development of your mini-game during a game jam, we assume that it will have a fixed size of 800x480.
The manifest.json file should have the following structure:
{
"id": "YourMiniGame",
"name": "My Mini-Game",
"description": "My elevator pitch goes here",
"teamName": "MyTeam",
"credits": [{
"name": "Bob",
"job": "Graphism",
"url": "http://your-homepage-here.org"
}, {
"name": "Jack",
"job": "Music",
"url": "http://your-homepage-here.org"
}
}, {
"name": "Paul",
"job": "Code",
"url": "http://your-homepage-here.org"
}
]
}
- id: it should correspond to the folder name
- name: it is obviously the name of your mini-game
- description: describe in a few words what it is, what it does
- teamName: the name of your team if you have one
- credits: an array in which you can put an object describing each member of the team.
This information is only useful for the generation of the Credits screen in the game.
Then, you have to integrate your mini-game with the Game API provided by the framework. Basically it provides a mean to load, start and stop your mini-game, but also to know the difficulty level and to report the score.
This API is really simple:
- the gameLoad function: when the framework loads your game it will search for a function named gameLoad and then execute it. Think of it as a DOM ready function but for mini-games. When you are in this function, the CWGame object is available as a parameter.
- the CWGame object:
- CWGame.ready(): call this when your game finished loading all the assets and is ready to run.
- CWGame.onStart(function(params) { }): pass a callback function with one parameter, an object containing parameters. This callback function will be called by the framework when your mini-game should start (in fact your mini-game will be loaded by the framework but it should do nothing at first. Your callback function will start the game). params.difficulty is the difficulty level of the game. Please note that you must register your onStart handler before calling CWGame.ready();
- CWGame.end(wonGame, score): you must call this when the mini-game is over. It has two parameters: wonGame (boolean), score (integer)
You can find in the HelloWorld folder a very simple game example.
When coding your game, you can easily test it by including (preferably before all your own scripts) in your index.html the two following JavaScript files, like this:
<script type="text/javascript" src="../GameMgr/CWGame.js"></script>
<script type="text/javascript" src="../GameMgr/MockGame.js"></script>
Then you can load your index.html directly in your Web browser.
But if you want to try your game in the CoinWare framework chrome, you have another option: you can append a parameter to the end of the url with the name of your game, e.g. index.html?HelloWorld and it will only launch HelloWorld. Please note that your game should be mentioned in config.js in this case.
CoinWare currently supports the integration with the following technologies:
- Flash: see FlashSample folder
- Unity: see UnitySample folder
- Construct2: see C2Sample folder
- CraftStudio: see this article on the CraftStudio blog
- Alain Vagner: code
- Vincent Lark: architecture & code review
- Aymeric Girault: Unity sample
- Thomas Altenburger: html5 sample
- I developed a game, but it does not seem to load properly in the framework.
Are you sure you called GameMgr.ready() ? If this is the case, it is possible that your framework is not compatible with the framework preloading system. In this case, you can add the following attribute value in your manifest file : preload: "false"