World

Each instance of p5play has its own world object, that can be used to control the Box2D physics simulation. Its most important property is gravity, which has x and y components.

Note that the physics simulation is deterministic. That means if you run the same code twice, unless you're using random values, you'll get the same result!

Sleeping

world.allowSleeping is true by default.

A sprite starts "sleeping" when it stops moving and doesn't collide with anything new. "Sleeping" sprites get ignored during physics simulation, which usually prevents the Box2D physics engine solver from having to make unnecessary calculations. While this is good for performance, sometimes it can cause problems.

You can wake up a sleeping sprite by setting sprite.sleeping to false. You can also disable sleeping on a per sprite basis by setting sprite.allowSleeping to false.

Controlling Time

The world.timeScale ratio is set to 1 by default for real time physics simulation. Set it lower for slow motion. Make it 0 to pause time!

Note that the Box2D physics engine solver is only stable up to a time scale of 2. If you want to advance the simulation by a larger amount of time, run the world.physicsUpdate function multiple times.

Click the canvas in the example to make the physics simulation progress in slow motion, 1/4th real time. The Matrix bullet time effect is achieved by making the background of each frame slightly transparent.

world.realTime stores how many real time seconds have elapsed since the start of the world, including pauses.

world.physicsTime stores how many seconds have elapsed in the physics simulation.

Performance Testing

Set p5play.renderStats to true to display the number of sprites drawn, display rate, and FPS calculations. For more comprehensive results, use your web browser's performance testing tools.

FPS in this context refers to how many frames per second your computer can generate, not including the delay between when frames are actually shown on the screen. The higher the FPS, the better your game is performing.

Having less sprites and using a smaller canvas will make your game perform better. For better performance, don't use the q5.js clear function or sample the colors of pixels in your canvas using get.

By default the Box2D physics engine performs 8 velocity iterations world.velocityIterations and 3 position iterations world.positionIterations. Decreasing these values will make the simulation faster but also less accurate.

I've tested p5play in every web browser and found that Google Chrome performs the best.

Find Sprites

You can get an array of sprites found at a point with the world.getSpritesAt function.

world.getSpriteAt returns the first sprite found at a point, the one with the highest layer value.

Note that the sprites must have physics bodies to be found.

Try moving the mouse to make sprites stop moving in the example!

Ray Casting

The world.rayCastAll function finds all the sprites (with physics colliders) that intersects a ray (line), excluding any sprites that intersect with the starting point.

The world.rayCast function is similar, but only returns the first sprite.

Note that the sprites must have physics bodies to be detected.

Provide these functions with the ray's start and end points.

Alternatively, set the ray's starting point, direction, and optionally the maximum distance it should travel.

Try moving the mouse in the example, when the ray intersects with a sprite, it becomes orange.

➡️ full ray casting demo

World Sizing

The default world.meterSize is 60, so a sprite with a width of 60 units will be 1 meter wide in the physics simulation.

The physics simulation can't run well when sprites are too small or too big. Keep the sizing human scale!

Grid World

When p5play.snapToGrid is true, sprites will snap to a grid when they're moved with the move and moveTo functions. p5play.gridSize is set to 0.5 by default.

In this example, scale(32) makes each display unit 32 pixels in size. A grid is displayed for reference. The sprites are only 1x1 units in size, so the world's meter size is set to 2.

Previous Page Next Page