6.5.1 • Published 4 days ago

fabric v6.5.1

Weekly downloads
109,060
License
MIT
Repository
github
Last release
4 days ago

Fabric.js

A simple and powerful Javascript HTML5 canvas library.


🩺 🧪 CodeQL


cdnjs jsdelivr Gitpod Ready-to-Code

NPM Downloads per month Bower


Sponsor asturur Sponsor melchiar Sponsor ShaMan123 Patreon


Features

  • Out of the box interactions such as scale, move, rotate, skew, group...
  • Built in shapes, controls, animations, image filters, gradients, patterns, brushes...
  • JPG, PNG, JSON and SVG i/o
  • Typed and modular
  • Unit tested

Supported Browsers/Environments

ContextSupported VersionNotes
Firefox✔️58
Safari✔️11
Opera✔️chromium based
Chrome✔️64
Edge✔️chromium based
Edge Legacy
IE11
Node.js✔️Node.js installation

Fabric.js Does not use transpilation by default, the browser version we support is determined by the level of canvas api we want to use and some js syntax. While JS can be easily transpiled, canvas API can't.

Installation

$ npm install fabric --save
// or
$ yarn add fabric

Browser

cdnjs jsdelivr

See browser modules for using es6 imports in the browser or use a dedicated bundler.

Node.js

Fabric.js depends on node-canvas for a canvas implementation (HTMLCanvasElement replacement) and jsdom for a window implementation on node. This means that you may encounter node-canvas limitations and bugs.

Follow these instructions to get node-canvas up and running.

Quick Start

// v6
import { Canvas, Rect } from 'fabric'; // browser
import { StaticCanvas, Rect } from 'fabric/node'; // node

// v5
import { fabric } from 'fabric';
<canvas id="canvas" width="300" height="300"></canvas>

<script src="https://cdn.jsdelivr.net/npm/fabric@6.4.3/dist/index.js"></script>
<script>
  const canvas = new fabric.Canvas('canvas');
  const rect = new fabric.Rect({
    top: 100,
    left: 100,
    width: 60,
    height: 70,
    fill: 'red',
  });
  canvas.add(rect);
</script>
import React, { useEffect, useRef } from 'react';
import * as fabric from 'fabric'; // v6
import { fabric } from 'fabric'; // v5

export const FabricJSCanvas = () => {
  const canvasEl = useRef<HTMLCanvasElement>(null);
  useEffect(() => {
    const options = { ... };
    const canvas = new fabric.Canvas(canvasEl.current, options);
    // make the fabric.Canvas instance available to your app
    updateCanvasContext(canvas);
    return () => {
      updateCanvasContext(null);
      canvas.dispose();
    }
  }, []);

  return <canvas width="300" height="300" ref={canvasEl}/>;
};
import http from 'http';
import * as fabric from 'fabric/node'; // v6
import { fabric } from 'fabric'; // v5

const port = 8080;

http
  .createServer((req, res) => {
    const canvas = new fabric.Canvas(null, { width: 100, height: 100 });
    const rect = new fabric.Rect({ width: 20, height: 50, fill: '#ff0000' });
    const text = new fabric.Text('fabric.js', { fill: 'blue', fontSize: 24 });
    canvas.add(rect, text);
    canvas.renderAll();
    if (req.url === '/download') {
      res.setHeader('Content-Type', 'image/png');
      res.setHeader('Content-Disposition', 'attachment; filename="fabric.png"');
      canvas.createPNGStream().pipe(res);
    } else if (req.url === '/view') {
      canvas.createPNGStream().pipe(res);
    } else {
      const imageData = canvas.toDataURL();
      res.writeHead(200, '', { 'Content-Type': 'text/html' });
      res.write(`<img src="${imageData}" />`);
      res.end();
    }
  })
  .listen(port, (err) => {
    if (err) throw err;
    console.log(
      `> Ready on http://localhost:${port}, http://localhost:${port}/view, http://localhost:${port}/download`,
    );
  });

See our ready to use templates.


Other Solutions

ProjectDescription
Three.js3D graphics
PixiJSWebGL renderer
KonvaSimilar features
html-to-imageHTML to image/canvas

More Resources

Credits Patreon

@kubric/creative-rendererlive-toolbar-test-internallive-toolbar-test1ziflow-js-microservicepsd2template-ccpsd2templates@gzc/x-canvasoshinstar-frontendcontent-file-preview-rendererarno-image-editorcustom-arno-image-editorcustom-vue-image-editorvectr-core2appup-componentsappup-components-dynamicxtbg-screenshots@gzc/xtbg-drawingdynos.viewer.componentzwwl-image-editor@thebird956/angular-editor-fabric-jscov-aureussmt-trendexp-annotation-toolexp-canvasredpen-canvasiwbplot-plan-editornobokye-feedbackshirtnetwork-designercover-maplsjghldshngvkjdghiahgoashgiuhdsgramdom-6060picture-toolstui-image-editor-sivazuniconsoft-ng-pdfviewerreact-image-akashvue_fabric_canvaszx-editly@uibox-pro/custom-control-sample@uibox-pro/custom-onetui-image-editor-sswtegaki-image-editortegaki-key-valuezrfikry-practice-package@garib_dev/tri3d-croppercyldesignersreact-design-editor-test-rishdesignercopycylrishtesttcyldesignereagle-designerdesignernew3dengine@vue3d/uv-editorreact-design-editor-andres-mestrafabric-textareav-fabricindus-trendngx-design-creator@inthepanchine/image-edit@cityfun.dev/mapbox-gl-export-with-cnlayoutlab-react@scenify/core@scenify/renderer@scenify/sdkdesign_editor_poclaserpecker-vue-editorminime-pillowminime-pillow-vuefloor-map-component@infinitebrahmanuniverse/nolb-fabdsg-editorimage-mark-pen-box@everything-registry/sub-chunk-1643aime-workflow-feedback2caseark-uieviewer7-libfabritorfabritor-designfabritor-webcanvas-fabric-editcanvas-fabric-edit100canvas-fabric-edit97canvas-fabric-edit98canvas-fabric-edit99mv-executor-view@rovahub/scenify-sdkt-image-editortass-canvas-editortass-fabric-historytater-tastetagpackagetag-graphtagging-masterteng-xinsvg-png-convertersvg-png-converter2svg-png-converter3svgjsonconvertersvgjsonifier
6.5.0

9 days ago

5.4.1-browser

9 days ago

5.4.2

5 days ago

5.4.2-browser

5 days ago

5.4.1

9 days ago

6.5.1

4 days ago

6.4.3

2 months ago

6.4.2

2 months ago

6.4.1

3 months ago

6.4.0

3 months ago

5.4.0

3 months ago

6.2.0

3 months ago

6.3.0

3 months ago

5.4.0-browser

3 months ago

6.1.0

4 months ago

6.0.0-rc4

5 months ago

6.0.0-rc3

5 months ago

6.0.1

5 months ago

6.0.0

5 months ago

6.0.2

5 months ago

6.0.0-rc2

6 months ago

6.0.0-rc1

7 months ago

6.0.0-beta20

8 months ago

6.0.0-beta19

9 months ago

6.0.0-beta18

10 months ago

6.0.0-beta17

11 months ago

6.0.0-beta16

12 months ago

6.0.0-beta14

1 year ago

6.0.0-beta15

1 year ago

6.0.0-beta13

1 year ago

6.0.0-beta12

1 year ago

6.0.0-beta11

1 year ago

6.0.0-beta10

1 year ago

6.0.0-beta6

2 years ago

6.0.0-beta9

1 year ago

6.0.0-beta8

1 year ago

6.0.0-beta7

2 years ago

6.0.0-beta5

2 years ago

6.0.0-beta4

2 years ago

6.0.0-beta3

2 years ago

5.3.0

2 years ago

6.0.0-beta1

2 years ago

6.0.0-rc.0

2 years ago

5.3.0-browser

2 years ago

5.2.4-browser

2 years ago

5.2.4

2 years ago

5.2.2

2 years ago

5.2.2-browser

2 years ago

5.0.0

3 years ago

5.0.0-browser

3 years ago

5.1.0

3 years ago

5.2.1

3 years ago

5.2.1-browser

3 years ago

5.1.0-browser

3 years ago

4.6.0

3 years ago

4.6.0-browser

3 years ago

4.5.1-browser

3 years ago

4.5.1

3 years ago

4.5.0

4 years ago

4.5.0-browser

4 years ago

4.4.0

4 years ago

4.4.0-browser

4 years ago

4.3.1-browser

4 years ago

4.3.1

4 years ago

4.3.0

4 years ago

4.3.0-browser

4 years ago

4.2.0-browser

4 years ago

4.2.0

4 years ago

4.1.0-browser

4 years ago

3.6.6-browser

4 years ago

3.6.6

4 years ago

4.1.0

4 years ago

3.6.5-browser

4 years ago

3.6.4-browser

4 years ago

3.6.5

4 years ago

3.6.4

4 years ago

4.0.0

4 years ago

4.0.0-browser

4 years ago

4.0.0-rc.1

4 years ago

4.0.0-beta.12

5 years ago

4.0.0-beta.11

5 years ago

4.0.0-beta.10

5 years ago

4.0.0-beta.9

5 years ago

4.0.0-beta.8

5 years ago

3.6.3

5 years ago

3.6.3-browser

5 years ago

4.0.0-beta.7

5 years ago

4.0.0-beta.6

5 years ago

3.6.2

5 years ago

3.6.2-browser

5 years ago

4.0.0-beta.5

5 years ago

4.0.0-beta.4

5 years ago

4.0.0-beta.3

5 years ago

4.0.0-beta.2

5 years ago

4.0.0-beta1

5 years ago

3.6.1

5 years ago

3.6.1-browser

5 years ago

3.6.0

5 years ago

3.6.0-browser

5 years ago

3.5.1-browser

5 years ago

3.5.1

5 years ago

3.5.0

5 years ago

3.5.0-browser

5 years ago

3.4.0

5 years ago

3.4.0-browser

5 years ago

3.3.2

5 years ago

3.3.2-browser

5 years ago

3.3.1

5 years ago

3.3.1-browser

5 years ago

3.3.0-browser

5 years ago

3.3.0

5 years ago

3.2.0

5 years ago

3.1.0

5 years ago

3.0.0

6 years ago

2.7.0

6 years ago

2.6.0

6 years ago

2.5.0

6 years ago

2.4.6

6 years ago

2.4.5

6 years ago

2.4.4

6 years ago

2.4.3

6 years ago

2.4.2-b

6 years ago

2.4.2

6 years ago

2.4.1

6 years ago

2.4.0

6 years ago

2.3.6

6 years ago

2.3.5

6 years ago

2.3.4

6 years ago

2.3.3

6 years ago

2.3.2

6 years ago

2.3.1

6 years ago

2.3.0

7 years ago

2.2.4

7 years ago

2.2.3

7 years ago

2.2.2

7 years ago

2.2.1

7 years ago

2.2.0

7 years ago

2.1.0

7 years ago

2.0.3

7 years ago

2.0.2

7 years ago

2.0.1

7 years ago

2.0.0

7 years ago

1.7.22

7 years ago

1.7.21

7 years ago

2.0.0-rc.4

7 years ago

2.0.0-rc.3

7 years ago

2.0.0-rc.2

7 years ago

2.0.0-rc.1

7 years ago

1.7.20

7 years ago

1.7.19

7 years ago

2.0.0-beta.7

7 years ago

1.7.18

7 years ago

2.0.0-beta.6

7 years ago

2.0.0-beta.5

7 years ago

2.0.0-beta.4

7 years ago

1.7.17

7 years ago

1.7.16

7 years ago

2.0.0-beta.3

7 years ago

1.7.15

7 years ago

1.7.14

7 years ago

1.7.13

7 years ago

1.7.12

7 years ago

2.0.0-beta.2

7 years ago

1.7.11

8 years ago

1.7.10

8 years ago

2.0.0-beta.1

8 years ago

2.0.0-beta0

8 years ago

1.7.9

8 years ago

1.7.8

8 years ago

1.7.7

8 years ago

1.7.6

8 years ago

1.7.4

8 years ago

1.7.3

8 years ago

1.7.2

8 years ago

1.7.1

8 years ago

1.7.0

8 years ago

1.6.7

8 years ago

1.6.6

8 years ago

1.6.5

8 years ago

1.6.4

8 years ago

1.6.3

8 years ago

1.6.2

9 years ago

1.6.1

9 years ago

1.6.0

9 years ago

1.6.0-rc.1

9 years ago

1.5.0

10 years ago

1.4.13

10 years ago

1.4.12

10 years ago

1.4.11

10 years ago

1.4.9

10 years ago

1.4.7

10 years ago

1.4.6

11 years ago

1.4.3

11 years ago

1.4.2

11 years ago

1.4.1

11 years ago

1.4.0

11 years ago

1.3.12

11 years ago

1.3.9

11 years ago

1.3.8

11 years ago

1.3.7

11 years ago

1.3.6

11 years ago

1.3.5

11 years ago

1.3.4

11 years ago

1.3.3

11 years ago

1.3.2

11 years ago

1.3.1

11 years ago

1.2.11

11 years ago

1.2.10

11 years ago

1.2.9

11 years ago

1.2.6

11 years ago

1.2.5

11 years ago

1.2.4

11 years ago

1.2.3

11 years ago

1.2.2

11 years ago

1.2.1

11 years ago

1.2.0

11 years ago

1.1.21

11 years ago

1.1.20

11 years ago

1.1.19

11 years ago

1.1.18

11 years ago

1.1.16

12 years ago

1.1.14

12 years ago

1.1.13

12 years ago

1.1.11

12 years ago

1.1.9

12 years ago

1.1.6

12 years ago

1.1.4

12 years ago

1.1.3

12 years ago

1.0.9

12 years ago

1.0.8

12 years ago

1.0.7

12 years ago

1.0.6

12 years ago

1.0.1

12 years ago

1.0.0

12 years ago

0.9.21

12 years ago

0.9.19

12 years ago

0.9.17

12 years ago

0.9.14

12 years ago

0.9.10

12 years ago

0.9.9

12 years ago

0.9.8

12 years ago

0.9.7

12 years ago

0.9.5

12 years ago

0.9.3

12 years ago

0.9.2

12 years ago

0.9.1

12 years ago

0.9.0

12 years ago

0.8.52

12 years ago

0.8.51

12 years ago

0.8.50

12 years ago

0.8.47

12 years ago

0.8.46

12 years ago

0.8.44

12 years ago

0.8.42

12 years ago

0.8.4

12 years ago

0.8.35

12 years ago

0.8.34

12 years ago

0.8.26

12 years ago

0.8.20

12 years ago

0.8.19

12 years ago

0.8.13

12 years ago

0.8.12

12 years ago

0.8.11

12 years ago

0.8.10

12 years ago

0.8.7

13 years ago

0.8.0

13 years ago

0.7.24

13 years ago

0.7.23

13 years ago

0.7.22

13 years ago

0.7.18

13 years ago

0.7.17

13 years ago

0.7.16

13 years ago

0.7.15

13 years ago

0.7.14

13 years ago

0.7.13

13 years ago

0.7.11

13 years ago

0.7.9

13 years ago

0.7.4

13 years ago

0.7.3

13 years ago

0.7.1

13 years ago

0.6.12

13 years ago

0.6.11

13 years ago

0.6.8

13 years ago

0.6.7

13 years ago

0.6.6

13 years ago

0.6.4

13 years ago

0.5.13

13 years ago

0.5.10

13 years ago

0.5.7

13 years ago

0.5.6

13 years ago

0.5.5

13 years ago

0.5.3

13 years ago

0.5.2

13 years ago