npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

runga

v1.0.2

Published

Runga is a library for rendering dynamic 2d scenes on canvas

Downloads

7

Readme

Runga

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.

Install

npm i runga

Usage

1. Create layers for your app

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 */
}

2. Gather layers to a scene

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.

3. Add dynamic to the 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 */
}