Canvas Transform Context
data:image/s3,"s3://crabby-images/99e89/99e89236335c36839e2146ee8967bdf746dddc72" alt="npm version"
A canvas context extension based on this example by phrogz.
Extends the 2d canvas context to support zooming and panning, allowing any canvas to be easily extended with panning and zooming functionalities. Perfect for visual web apps that requires extra canvas functionalities without the hassle of custom canvas implementations.
Installation
via npm
npm i canvas-transform
import { toTransformedContext } from "canvas-transform"
via browser
import { toTransformedContext } from "https://unpkg.com/canvas-transform-context@0.0.2/dist/index.min.js";
Usage
// import { toTransformedContext } from "canvas-transform"
import { toTransformedContext } from "https://unpkg.com/canvas-transform-context@0.0.2/dist/index.min.js"
const canvas = getDocumentById("myCanvas")
const ctx = canvas.getContext('2d')
toTransformedContext(ctx)
function draw(ctx) {
}
canvas.addEventListener("mousedown", (e) => {
ctx.beginPan(e);
draw(ctx);
});
canvas.addEventListener("mousemove", (e) => {
ctx.pan(e);
draw(ctx);
});
canvas.addEventListener("mouseup", (e) => {
ctx.endPan(e);
draw(ctx);
});
canvas.addEventListener("wheel", (e) => {
ctx.zoom(-Math.sign(e.deltaY));
draw(ctx);
})
Documentation
Function | Description |
---|
toTransformedContext(ctx) | Extends the canvas context with new methods for rotation and panning (see below). Since the context is directly modified, the value does not need to be reassigned. However, the function does also return the modified context for the sake of typing when using with Typescript. |
Utility methods
Method | Description |
---|
ctx.transformedPoint(x, y) | Converts a coordinate to the correct translated/scaled coordinates. Returns a DOMPoint (contains x and y properties). |
Panning methods
Method | Description |
---|
ctx.beginPan(mouseEvent) | Sets the initial panning point. Call from mousedown . |
ctx.pan(mouseEvent) | Pans the canvas. Call from mousemove . |
ctx.endPan(mouseEvent) | Stops the panning. Call form mouseup . |
Zooming methods
Method | Description |
---|
ctx.zoom(amount, factor?, center?) | Zooms the canvas. amount represents the increment to zoom (in integers). factor is the percentage to scale by. Defaults to 1.1. center is the canvas position to zoom to; if undefined, it will infer from the latest panned position from endPan . |
Attributions
Main implementation based on code by phrogz: