图片标注编辑平台搭建系列教程(2)——fabric.js简介

综述

fabric提供了二维图形编辑需要的所有基础能力,包括:数据管理、图形渲染、图形编辑和事件监听。其中,图形编辑可以通过事件监听和图形渲染来实现,所以可以弃用。数据管理方便对业务数据做定制化管理。

数据管理

fabric提供了数据管理能力,能很方便地存取图形数据。
代码如下:

var canvas = new fabric.Canvas('a');
var rect = new fabric.Rect();

// 新增object
canvas.add(rect);
// 按索引取object
canvas.item(0);
// 获取指定type的object
canvas.getObjects(type);
// 移除object
canvas.remove(rect);
// 遍历对象
canvas.forEachObject(callback);

图形渲染

fabric原生支持部分图形的渲染,Rect、Circle、Triangle、Polyline、Polygon、Point、Path、Text、Object等。通过这些类,你可以很方便地构建出对应的图形。
代码如下:

var circle = new fabric.Circle({ radius: 20, fill: 'green', left: 100, top: 100 });
var triangle = new fabric.Triangle({ width: 20, height: 30, fill: 'blue', left: 50, top: 50 });

canvas.add(circle, triangle);

// 设置背景图
canvas.setBackgroundImage('../assets/pug.jpg');

// 获取样式
circle.get('fill'); // 'green'

// 单独设置样式
circle.set('fill', 'blue');
circle.set('opacity', 0.7);
circle.set('stroke', 'red');
circle.set('strokeWidth', 5);

// 批量设置样式
circle.set({ fill: 'yellow', opacity: 0.5 });

// 触发重新渲染
canvas.renderAll();

// 渲染并初始化图形
canvas.renderAndReset();

// 选中object
canvas.setActiveObject(circle);

// 添加文字标注
var text = new fabric.Text('hello world', { left: 100, top: 100, fill: 'blue', fontSize: 12 });

canvas.add(text);

图形编辑

fabric原生支持了图形的编辑,例如平移、旋转和缩放。不过扩展性不强,本人不喜欢使用,禁用也很简单,如下。
用法如下:

circle.set({
    lockMovementX: true, // 禁止横向移动
	lockMovementY: true, // 禁止纵向移动
	lockRotation: true, // 禁止旋转
	lockScalingX: true, // 禁止横向缩放
	lockScalingY: true, // 禁止纵向缩放
});

事件监听

要想编辑功能强大,事件监听必不可少。fabric提供了很底层的事件监听,写法简单,如下:

// 鼠标事件
const mouseEvents = ['mouse:down', 'mouse:move', 'mouse:up']

// 渲染事件
const renderEvents = ['after:render']

// 选中事件
const selectEvents = ['selection:cleared', 'selection:created', 'selection:updated']

// 对象事件
const objectEvents = ['modified', 'selected', 'added', 'removed', 'moving', 'scaling', 'rotating', 'resizing']

canvas.on('mouse:down', (options) => { console.log(options.e.clientX, options.e.clientY); });

canvas.on('selection:created', (options) => { console.log(options.selected); });

canvas.on('object:added', (options) => { console.log(options.target); })

可以监听整个画布的鼠标事件,以及一些抽象后的事件。

预告

下一章,讲讲图片标注中,画布的拖拽、缩放涉及的坐标系相关知识。

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-27 07:42:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-27 07:42:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-27 07:42:05       82 阅读
  4. Python语言-面向对象

    2024-03-27 07:42:05       91 阅读

热门阅读

  1. 使用docker的好处???(docker的优势)

    2024-03-27 07:42:05       42 阅读
  2. MongoDB面试专题

    2024-03-27 07:42:05       35 阅读
  3. Spring框架与Spring Boot的区别和联系

    2024-03-27 07:42:05       35 阅读
  4. 【前端学习——js篇】7.函数缓存

    2024-03-27 07:42:05       44 阅读
  5. 一些常见的Docker问题和答案

    2024-03-27 07:42:05       48 阅读
  6. spring中的Singleton Bean(单例bean)是否为单例模式

    2024-03-27 07:42:05       38 阅读
  7. 浅析回归算法和分类算法的异同点

    2024-03-27 07:42:05       41 阅读
  8. gateway做负载均衡

    2024-03-27 07:42:05       33 阅读
  9. 【Pytorch】利用PyTorch实现图像识别

    2024-03-27 07:42:05       37 阅读