README.md
This project is under active development and is not stable yet.
Planck.js is JavaScript rewrite of Box2D physics engine for cross-platform HTML5 game development. Check out demos!
Motivations
Key motivations in development of this project are:
- Taking advantage of Box2D's efforts and achievements
- Developing readable and maintainable JavaScript code
- Optimizing the library for web and mobile platforms
- Providing a JavaScript-friendly API
Try it
To try Planck.js, simply add planck-with-testbed.js
script to your HTML code and call planck.testbed(callback)
with your code in callback. For example:
<html><body><scriptsrc="https://cdn.jsdelivr.net/planck/0.1/planck-with-testbed.js"></script><script>planck.testbed(function(testbed) {var world =planck.World();// rest of your codereturn world; // make sure you return the world });</script></body></html>
Check out Car example on JS Bin to try it in practice.
Also see example
directory for more testbed usage examples.
Install
To receive updates about changes and progress follow @piqnt on twitter.
Download
Latest builds are available on releases page.
CDN
Planck.js is available on jsDelivr.
NPM
npm install planck-js --save
Bower
bower install planck-js --save
Usage
Planck.js does not use any renderer by default. To use or integrate it with a rendering library all you need to do
is calling world.step(1/hz)
in each frame, and then iterating over world entities to draw or update them.
You may also want to listen to world events to remove objects which are removed from the world. For example:
<scriptsrc="./path/to/planck.min.js"></script><script>var world =planck.World();window.requestAnimationFrame(function() {// in each frame call word.step(1/hz) with fixed frequencyworld.step(1/60);// iterate over bodies and fixturesfor (var body =world.getBodyList(); body; body =body.getNext()) {for (var fixture =body.getFixtureList(); fixture; fixture =fixture.getNext()) {// draw or update fixture } } });world.on('remove-fixture', function(fixture) {// remove fixture from ui });</script>
API
Planck.js public API closely follows Box2D API (see Resources), with following differences:
b2
prefix is dropped from class names, for exampleb2World
is now available asplanck.World
.- Method names are converted from UpperCamelCase to lowerCamelCase.
- Definition classes/objects (BodyDef, FixtureDef, etc.) are replaced by inline JavaScript objects (
{}
). - Shapes are made immutable and are not cloned when used to create fixtures.
World#on(eventName, listenerFn)
andWorld#off(eventName, listenerFn)
are added to add and remove event listeners. Currently supported events are:'contact-begin'
'contact-end'
'pre-solve'
'post-solve'
'joint-removed'
'fixture-removed'
'body-removed'
Resources
- Box2D Manual and FAQ are highly recommended to get started.
- iforce2d website includes a collection of helpful tutorials and resources to learn Box2D.
Following resources are recommended if you are interested in learning about Box2D/Planck.js's internal details.
If you know any other useful resource, please add it or submit an issue.
Testbed
Another way to use testbed and try included examples (in example
directory) is running testbed with live build locally:
Install
git
,npm
andbower
Clone or download this repository
Install npm and bower dependencies:
npm install bower install
Run testbed and open it in your web browser (see command-line output for URL to open):
npm run testbed
Architecture
Planck.js includes Box2D algorithms without modification and its internal architecture and public API are very similar to Box2D. However some changes and refactoring are made during rewrite to address differences between C++ and JavaScript.
Credits
Box2D is a popular C++ 2D rigid-body physics engine created by Erin Catto. Box2D is used in several popular games, such as Angry Birds, Limbo and Crayon Physics, as well as game development tools and libraries such as Apple's SpriteKit.
Planck.js is developed and maintained by Ali Shakiba.
License
Planck.js is available under the zlib license.