A Babylon.js sample project using typescript, latest babylon.js es6 core module, webpack 4 with webpack dev server, hot loading, eslint, vscode support and more.
This is a basic demo using Babylon's core module only. It is based on the Getting started guide at the documentation page. A lot of the engine's features are not covered here. I will slowly add more and more projects and more examples.
If you have any questions, you are very much invited to the Babylon.js forum where I am hanging around almost daily.
To run the basic scene:
- Clone / download this repository
- run
npm install
to install the needed dependencies. - run
npm start
- A new window should open in your default browser. if it doesn't, open
http://localhost:8080
- ????
- Profit
Running npm start
will start the webpack dev server with hot-reloading turned on. Open your favorite editor (mine is VSCode, but you can use nano. we don't discriminate) and start editing.
The entry point for the entire TypeScript application is ./src/index.ts
. Any other file imported in this file will be included in the build.
To debug, open the browser's dev tool. Source maps are ready to be used. In case you are using VSCode, simply run the default debugger task (Launch Chrome against localhost
) while making sure npm start
is still running. This will allow you to debug your application straight in your editor.
The ./src/scenes
directory contains a few examples of scenes that can be loaded. To load a specific scene, add a ?scene=FILENAME
to the URL (i.e. to load the ammo physics demo, use http://localhost:8080/?scene=physicsWithAmmo
).
More and more scenes will be slowly added.
Open the URL in a webgpu-enabled browser and add "?engine=webgpu" to the URL. If you want to add a different scene, add it as a query parameter: http://localhost:8080/?scene=physicsWithAmmo&engine=webgpu
.
To lint your source code run npm run lint
To build the bundle in order to host it, run npm run build
. This will bundle your code in production mode, meaning is will minify the code.
Building will take some time, as it will build each sample (and create a different module for each). If you want to speed up the process, define the scene you want to render in createScene.ts
(you can see the comment there)
That's an abstract question! What is which one of those wonderful things?
Babylon.js is the world's leading WebGL engine that starts with a 'b'. You should give it a try and leave those other numbers and letters behind. To read more about it and see some amazing samples, go to the Babylon.js website, Babylon's Playground or Babylon's documentation.
The rest? You should know already, this is why you are here.
- Latest typescript version
- Simple texture loading (using url-loader)
- dev-server will start on command (webpack-dev-server)
- A working core-only example of babylon
- Full debugging with any browser AND VS Code
- (production) bundle builder.
- eslint default typescript rules integrated