
Product
Announcing Socket Fix 2.0
Socket Fix 2.0 brings targeted CVE remediation, smarter upgrade planning, and broader ecosystem support to help developers get to zero alerts.
Runga is a zero dependency library for rendering dynamic 2d scenes on html canvas. The library makes it possible to code layers of scene separately from each other.
npm i runga
Lets suppose you want to draw the sun and clouds on blue sky. You can create three new layers with passing rendrer functions to constructors.
import { Layer } from 'runga';
const sky = new Layer({ render: skyRenderFunction });
const sun = new Layer({ render: sunRenderFunction });
const clouds = new Layer({ render: cloudsRenderFunction });
Render function is a function which will receive an object. The field canvas
is an HTMLCanvasElement where you have to draw the content of clouds layer.
function cloudsRenderFunction({ canvas }) {
/* draw clouds here */
}
Now you need to draw all your layers to one canvas. Create an instance of Layer and pass your layers to it.
import { Layer } from 'runga';
const scene = new Layer({ children: [sky, sun, clouds] });
Class Scene
extends standard HTMLCanvasElement
so you will just append it to DOM.
document.body.append(scene);
When you create an instance of scene, it asks to each inside layer to render. Your render functions will be called with canvas
elements which have the same size of scene.
Now you want, say, to change the x
-position of the sun programmatically. You can define the sun layer with type of data used in this layer and you can set new data.
const sun = new Layer<{ x: number }>({ render: sunRenderFunction });
sun.setData({ x: 60 });
And you will receive data to the render function argument:
function sunRenderFunction({ data, canvas }) {
console.log(data); // {x: 60}
/* draw the sun here */
}
FAQs
Runga is a library for rendering dynamic 2d scenes on canvas
We found that runga demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Product
Socket Fix 2.0 brings targeted CVE remediation, smarter upgrade planning, and broader ecosystem support to help developers get to zero alerts.
Security News
Socket CEO Feross Aboukhadijeh joins Risky Business Weekly to unpack recent npm phishing attacks, their limited impact, and the risks if attackers get smarter.
Product
Socket’s new Tier 1 Reachability filters out up to 80% of irrelevant CVEs, so security teams can focus on the vulnerabilities that matter.