首页
/ Fabric.js 技术文档

Fabric.js 技术文档

2024-12-20 06:30:44作者:段琳惟

1. 安装指南

使用 npm 或 yarn 安装

$ npm install fabric --save
# 或者
$ yarn add fabric

在浏览器中使用

可以通过 cdnjsjsdelivr 使用 Fabric.js。

在 Node.js 中使用

在 Node.js 中使用 Fabric.js 需要依赖 node-canvas 来实现画布功能,并使用 jsdom 来模拟 window 环境。请按照 node-canvas 安装指南 进行安装。

2. 项目使用说明

Fabric.js 是一个简单而强大的 JavaScript HTML5 画布库,支持多种交互、内置形状、控件、动画等功能。以下是快速入门示例:

普通 HTML

<canvas id="canvas" width="300" height="300"></canvas>

<script src="https://cdn.jsdelivr.net/npm/fabric"></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>

ReactJS

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);
    // 在应用中使用 canvas 实例
    updateCanvasContext(canvas);
    return () => {
      updateCanvasContext(null);
      canvas.dispose();
    }
  }, []);

  return <canvas width="300" height="300" ref={canvasEl}/>;
};

Node.js

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`,
    );
  });

3. 项目API使用文档

请参考 Fabric.js 官方网站GitHub 项目 wiki 获取详细的 API 文档。

4. 项目安装方式

如前所述,可以使用 npm 或 yarn 在项目中安装 Fabric.js。在浏览器中,可以通过 CDN 链接直接引用。在 Node.js 环境中,需要安装 node-canvasjsdom

以上就是 Fabric.js 的技术文档,希望对您的使用有所帮助。

登录后查看全文
热门项目推荐
相关项目推荐