fabricat
Canvas-based version of the Scratch 3.0 renderer
Setup
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Fabricat canvas rendering demo</title>
</head>
<body>
<canvas id="myStage"></canvas>
<canvas id="myDebug"></canvas>
</body>
</html>
var canvas = document.getElementById('myStage');
var debug = document.getElementById('myDebug');
var renderer = new require('fabricat')(canvas);
renderer.setDebugCanvas(debug);
function drawStep() {
renderer.draw();
requestAnimationFrame(drawStep);
}
drawStep();
var worker = new Worker('worker.js');
renderer.connectWorker(worker);
Standalone Build
npm run build
<script src="/path/to/render.js"></script>
<script>
var renderer = new window.RenderCanvasLocal();
</script>
Testing
npm test
Credit
Most of this codebase was written by the Scratch Team for scratch-render, the official WebGL-based renderer for Scratch. I simply modified it to work via the 2D canvas drawing API.