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

canvas-area

v0.4.6

Published

lightweight html container element as a controller parent for one or more canvas elements. It allows zoom, pan and resize interactions

Downloads

11

Readme

canvas-area

What is it ... ?

canvas-area is a lightweight custom html element as a controller parent for one or more canvas elements. It allows zoom, pan and resize interactions.

Show me ...

show

Where is the markup code ...

<canvas-area id="ca" width="401" height="301" resizable="both">
    <canvas id="c"></canvas>
</canvas-area>

Attributes

  • width: width of element in px.
  • height: height of element in px.
  • resizable: one of ['none', 'horizontal', 'vertical', 'both'].
  • cartesian: true or false

Example please ...

try it out ...

Multiple Canvases

Multiple canvases are mostly used as layers in practice. It is up to you, how you organize, what to draw on which layer. Often there is a background layer holding static graphics, which does not need to be updated frequently. In contrast to that there might be a dynamic layer holding animated graphics for instance. There also might be an interactivity layer, containing editable geometry.

Separating low frequently updated geometry from high frequently updated geometry by different layers should result in a performance gain.

Please note, when using multiple canvases - and stacking them on top of each other:

  • For every canvas element, perhaps except the first one, use position:absolute; style.
  • Stacking level can be made explicite using z-index: 5; style.
  • canvas elements are transparent by default. So avoid giving them background colors.
  • canvas-area is managing the resize of its canvas children, but not their redraw.
  • canvas-area is managing the view parameters for pan and zoom, but does not apply those values to the canvas contexes. Do that by yourself while redrawing or using the on('view',...) handler.

Example:

<canvas-area id="ca" width="401" height="301">
    <canvas id="c1" style="position:absolute; z-index:1;"></canvas>
    <canvas id="c2" style="position:absolute; z-index:2;"></canvas>
</canvas-area>

Show me the scripting API ...

canvas-area behaves as a standard html container element with known inherited DOM properties and methods. Additionally it offers properties ...

| Property | Type | Value | Default | |:---|:---:|:---|:---:| |width|Number| width of element in px| 300 px | |height|Number| height of element in px| 150 px | |resizable|String| one of ['none', 'horizontal', 'vertical', 'both']| 'none'| |cursor|String| simple interface to CSS cursor attribute. | 'auto' | |view|{x,y,scl}| origin location x,y in px and scaling factor scl | {0,0,1} | |cartesian|Boolean| true: y-axis pointing up, false: y-axis pointing down | false |

... methods ...

| Method | Arguments | Returns |Comment | |:---|:---|:---:|:---| |pan({dx,dy})|dx: delta xdy: delta y | undefined| origin displacement. Modifies view property | |zoom({x,y,scl})|x: x-centery: y-centerscl: factor | undefined| zoom about point {x,y} by factor scl. Modifies view property | |pntToUsr({x,y})| point | point | transform argument point (device coordinates) to result point (user coordinates) with respect to view property | |notify(key,value)|key: event typevalue: event data |undefined| notify observers of event type key about event value| |on(key,handler)|key: event typehandler: event handler|this| register handler with event type key. |

... and events, which can be observed via observe method.

| Type | Object | Value | |:---|:---:|:---| |'pointer'|{x,y,...}| User has moved the pointer. | |'drag'|{x,y,...}| User has moved the pointer with left button down. | |'resize'|{width,height}| User did resize canvas-area element | |'view'|{x,y,scl}| User modified the view property via pan, zoom, ... | |'buttondown'|{x,y,...}| User has pressed the pointer device's button down. | |'buttonup'|{x,y,...}| User has released the pointer device's button. | |'pointerenter'|{x,y,...}| pointer has entered the canvas-area. | |'pointerleave'|{x,y,...}| pointer has left the canvas-area. |

{x,y,...}* custom event data object:

| Property | Description | |:---|:---| |x,y| Pointer location in device coordinates. | |dx,dy| Pointer displacement in device coordinates since last pointer event. | |buttons| Device buttons pressed (1:left, 2: right, 4: middle button). | |delta| Mouse wheel delta units. |

CDN

Use following link for canvas-area.js.

  • https://gitcdn.xyz/cdn/goessner/canvas-area/master/canvas-area.js

FAQ

  • Does not work properly with Mobile Device X and Touch Screen Y ?

    • Desktop browsers only are addressed primarily at current.
    • Implementation of touch events is experimental (pan works with touch and resize also using a pen now).
    • Issues with Microsoft Edge.
  • Can you implement feature X and possibly feature Y ?

    • canvas-area serves my personal needs very well as it is.
    • So ... no, I won't.
    • Please go ahead and implement it by yourself.
    • If you think, your enhancement is of common interest, you are very welcome, to send me a pull request.

Changelog

[0.4.5] on January 19, 2018

  • chainable method on(key,handler) added.
  • method observe(key,handler) marked as deprecated. Use on(key,handler) instead.
  • renamed event property buttons to btn in [drag,pointer,buttondown,buttonup,pointerenter,pointerleave] event.
  • necessary styles display: block; overflow: hidden; automatically added as inline style while constructing.
  • touch events experimentally implemented.

[0.4.0] on January 06, 2018

  • Initial release.

License

canvas-area is licensed under the MIT License

© Stefan Gössner