This project is more an experiment than really a game (it could lead to a game though). The concept is :
- you open the website on your desktop browser
- you snap the QR code with your smartphones (yours and friends’s or coworkers’s)
- then you control your ball which is on the desktop monitor by tilting your phone … like a wiimote.
This is multiplayer (each player has a ball of a certain color – moving on the monitor and identified on his phone), there is a little chat (if you play with multiple monitors).
If you don’t have any phone, you can even run the device motion emulator ! (thanks to remote-tilt).
It runs with :
The site is hosted on a free heroku instance (I recently enabled the WebSockets which weren’t available on heroku before – caused socket.io to fallback to xhr polling) so it’s not the best server ever, but it does the job for the demo …
The source code is on github, it’s MIT licensed if you want to fork it or whatever.
I’m aware it’s not perfect (if you’re on multiple monitors, you may experiment little display differences), but it could lead to an idea of game or whatever …!
Test Topheman Playground 2
PS : Besides of socket.io and little bugs I had to deal with (such as the express sessions linked to the sockets), this project forced me to learn how to publish a project on heroku, which is (when you never have done it before) not something as easy as uploading your files via ftp like you would for a php project for example 🙂 …
I released a first version of Topheman Bombs in april 2012 which worked in the browser for the iOs devices and in an app for the android devices (both platforms were sharing the same source code, thanks to phonegap). The game is simple, it takes advantage of the gyroscope/accelerometer of your device :
- Tilt your device to manage the blue dot
- Tap the screen to drop bombs and kill the red dots
- Grab the green dots to get more bombs
- offline gaming (using Application Cache with the HTML5 manifest)
- optimized build file (refactored my source code to use require.js and generate a minified build file with r.js/grunt)
- built-in device motion emulator (using remote-tilt)
Try Topheman Bombs
I started Topheman Bombs to test the accelerometer features of HTML5 (almost two years ago), but I surely finished it to release a real project that was using Ball.js at the time.
You can find the Ball.js source code on github as well as a documented API.
The little Story
Topheman Bombs sources are on github under Creative Commons license, if you want, you can also take a look at the grunt workflow I implemented.