vrum.js is a bunch of code which aims to help the development of cross platform games. Think of it as a game engine based on three.js. It started off as a card game similar to Hearthstone which I never finished. I did however extract a game engine out of it.
I used it in Ludum Dare (but not only) and made a few games:
- http://mess110.github.io/html-games/ld/040/index.html
- http://mess110.github.io/html-games/ld/ld-30-connected-worlds/
- http://mess110.github.io/html-games/pew/
- http://mess110.github.io/html-games/crossy-road/
- http://mess110.github.io/html-games/stage/
The engine changed quite a bit over time. Looking in the source code might not be of much help. I also feel the API got decently stable and I want to gather feedback from different people, so I am writing this tutorial.
I learned about game development by making crappy games. Hopefully, I learned enough to also make good ones in the future. Here are some of the game engines I used and learned from:
- Ogre3D
- jMonkeyEngine
- AndEngine
I also play a bunch of games. Won't list them, but I would like to talk about Worms. Team17 made Worms. Team17 also made Overcooked. And Overcooked seems like a good game to learn how to build.
Oh.. And the name? Think of the sound a car engine makes. vrum vrum.
"Atwood's Law: any application that can be written in JavaScript, will eventually be written in JavaScript." And here we are. Install node.js (tested version can be found in package.json of vrum). If you need different versions of node.js, you can use nvm. I also recommend using yarn.
npm install -g yarn
git clone https://github.com/mess110/vrum.git
cd vrum
yarn install
This should create a folder called vrum and install node.js dependencies.
Are we ready to go? Lets check:
yarn http
Now open http://127.0.0.1:8080/workspace/games/test/
in a decent browser.
You will see a list of tests to choose from. If you click on the main tests
you should see quite a chaotic scene with a lot going on. Its testing a bunch
of vrum.js features. It should look something like this:
You can switch between different tests by pressing 1,2,3 etc.
Create a new game. The template from which the game is built can be found in
workspace/games/project
.
yarn new_game
When prompted, specify a name for your game. It will initially be created in
workspace/games/
under the game name of your choosing. It contains all the
source code needed to run/develop the game.
The code is rather easy to understand. There is an index.html file which needs to be opened in the browser and a game.js file which is included by index.html. In index.html, the main noteworthy thing is how vrum.js is imported. There are 2 ways:
- dev
- prod
<!-- switching between dev/prod is as easy. just pick one: -->
<script src="/src/tools/dependencies.dev.js"></script>
<!-- <script src="/vrum.min.js"></script> -->
<script>
// In this example, if we are in dev, we load all scripts one by one
// plus 'scene.js' and 'main.js'
// However, if we are in prod, we only load 'scene.js' and 'main.js'
// because all the vrum js scripts are loaded with 'vrum.min.js'
loadVrumScripts([
'scene.js',
'main.js',
])
</script>
You should only use one of these methods as they do the same thing. When deploying, you NEED to use the 2nd one. Main reasoning for this is that we don't want to deploy all the source code of vrum.js as several files. Also, we don't want to live reload assets in production because they don't change.
Regardless of dev/prod, don't include js files though script tags. Instead, use:
loadVrumScripts([
'game.js'
])
This makes sure all the assets are loaded in order. In dev
mode, this
loads each js script dynamically, while in prod
, it only loads the scripts
mentioned by you. vrum.js scripts are already loaded in vrum.min.js
There are a few tools which can aid you during development: