Member-only story
Creating a Game Loop in JavaScript
Let’s smooth out player movement with a recurring process.
data:image/s3,"s3://crabby-images/d1053/d1053fe5e40b9b56bdb601353c02256b309e40bb" alt=""
Over the past several months I have been building a JavaScript game where a player wanders through procedurally-generated caverns.
data:image/s3,"s3://crabby-images/b5113/b5113b62f6f86df2bcddad27731220bc9e276e94" alt=""
The game uses the HTML Canvas API with two <canvas>
elements: one for the blue player and one for the cavern, enemies, and items. In my early versions, the player would move from tile to tile with no animated transitions.
To smooth out the gameplay, I recently switched to animated pixel-by-pixel movement. Rather than having the player move immediately to an adjacent tile, it would move one pixel at a time — and instead of always being aligned to its current tile, the player could sit between two or more tiles.