Fabric.js 元素中心缩放

本文简介

点赞 + 关注 + 收藏 = 学会了


使用 fabric.js 创建的图形,默认的缩放原点是元素操作点的对角点。

如下图所示:

file


如果按住 alt 键 操作会把原点移动到元素中心。

如下图所示:

file


如果想将默认缩放操作设置为“中心缩放”,只需将 centeredScaling 属性设置为 true 即可。



设置中心缩放

虽然只要将 ``centeredScaling 设置为 true 就行了,但还能再细分成2种情况。

一个是全局设置,一个是只设置指定元素。

在实际操作之前,我先创建画布,并在画布上添加2个元素,一个矩形,一个圆形。

file

<canvas id="canvasBox" width="600" height="400" style="border: 1px solid #ccc;"></canvas>

<script>
  // 初始化画布
  let canvas = new fabric.Canvas('canvasBox')

  // 矩形元素
  let rect = new fabric.Rect({
    width: 100,
    height: 60,
    left: 100,
    top: 100,
    fill: 'pink'
  })

  // 将矩形添加到画布里
  canvas.add(rect) 

  // 圆形元素
  let circle = new fabric.Circle({
    radius: 50,
    left: 300,
    top: 80,
    fill: 'green'
  })

  // 将圆形添加到画布里
  canvas.add(circle)
</script>

全局设置

全局设置的话,画布上所有元素都会生效。

只需在创建画布时将 centeredScaling 设为 true 即可。

file

// 省略部分代码.

// 方式1
let canvas = new fabric.Canvas('canvasBox', {
  centeredScaling: true // 全局所有元素都生效
})


// 方式2
let canvas = new fabric.Canvas('canvasBox')
canvas.centeredScaling = true

从上图中可以看到,不管是圆形还是矩形都是以中心点为缩放原点。因为在 new fabric.Canvas 时或者其返回的实例对象上设置 centeredScaling 都是全局生效的。


单独设置指定元素

如果只是设置指定元素以中心点为缩放原点,那么被设置的元素会生效,其他元素不会生效。

本例只将矩形设置成以中心点为缩放原点,圆形还是默认的操作。

file

// 省略部分代码

// 矩形
let rect = new fabric.Rect({
  width: 100,
  height: 60,
  left: 100,
  top: 100,
  fill: 'pink',
  centeredScaling: true // 单个元素生效
})

// 将矩形添加到画布里
canvas.add(rect)

上面的代码只设置了矩形的 centeredScaling ,圆形还是默认值。

所以在操作矩形缩放时是以中心点为原点,圆形还是默认值。


同样,也支持在创建元素后再设置。

// 省略部分代码

let rect = new fabric.Rect({...})

rect.centeredScaling = true


代码仓库

Fabric.js 中心缩放



推荐阅读

👍《Fabric.js 从入门到 _ _ _ _ _ _》

👍《Fabric.js IText 手动设置斜体》

👍《Fabric.js 动态设置字号大小》

👍《Fabric.js 锁定背景图,不受缩放和拖拽的影响》

👍《Fabric.js 自由绘制椭圆》

👍《Fabric.js 橡皮擦的用法(包含恢复功能)》


点赞 + 关注 + 收藏 = 学会了 代码仓库

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Fabric.js 中可以使用 group() 方法将选中的多个元素组合在一起。示例代码如下: ``` var canvas = new fabric.Canvas('canvas'); // 创建三个矩形 var rect1 = new fabric.Rect({ left: 100, top: 100, width: 50, height: 50, fill: 'red' }); var rect2 = new fabric.Rect({ left: 150, top: 150, width: 50, height: 50, fill: 'green' }); var rect3 = new fabric.Rect({ left: 200, top: 200, width: 50, height: 50, fill: 'blue' }); // 将这三个矩形添加到画布中 canvas.add(rect1); canvas.add(rect2); canvas.add(rect3); // 选择这三个矩形 canvas.setActiveObject(rect1); canvas.setActiveObject(rect2); canvas.setActiveObject(rect3); // 将选中的矩形组合在一起 var group = new fabric.Group(canvas.getActiveObjects()); canvas.add(group); ``` 需要注意的是,组合后的元素将成为一个新的元素,并且原来的元素将从画布中移除。 ### 回答2: fabric.js 是一种基于canvas的JavaScript图形库,它提供了丰富的功能来处理图形和交互。在fabric.js中,可以使用多种方法将多个选定的元素组合成一个组。以下是使用fabric.js中的组合方法的步骤: 1. 创建canvas对象:使用fabric.js创建一个新的canvas对象。 2. 创建元素:使用fabric.js创建需要多选的多个元素,并将它们添加到canvas对象中。 3. 选择元素:使用fabric.js中的选择器方法,选择需要组合的多个元素。可以使用鼠标拖拽选择多个元素,也可以使用代码选择。 4. 组合元素:使用fabric.js中的group方法,将选定的多个元素组合成一个组。可以通过调用`canvas.getActiveObject()`方法获取选中元素的数组,然后调用`canvas.getActiveGroup()`方法将这些元素组合成一个组。 5. 操作组:一旦元素被组合,可以对整个组进行操作。这包括移动、旋转、缩放等。可以使用fabric.js提供的各种方法对组进行操作。 通过上述步骤,可以使用fabric.js将多选的元素组合成一个组。这样可以更方便地对多个元素进行操作,同时也可以进行更高级的交互和动画效果。fabric.js的强大功能使得多选元素组合变得简单而灵活。 ### 回答3: fabric.js 是一个强大的基于 HTML5 canvas 的绘图库,它提供了各种功能来处理图形元素。要将多个元素组合起来,可以使用 fabric.js 中的 Group 类。 首先,我们需要创建一个 Group 对象,并将要组合的元素作为参数传入。可以使用 `new fabric.Group()` 来创建一个 Group 对象。例如,假设我们有三个矩形元素 rect1、rect2 和 rect3: ```javascript var group = new fabric.Group([rect1, rect2, rect3], {left: 100, top: 200}); canvas.add(group); ``` 上述代码将创建一个包含 rect1、rect2 和 rect3 的分组,并将其添加到 canvas 中。`left` 和 `top` 参数用于指定组合后的元素相对于画布左上角的位置。 要取消组合并将元素拆分,可以使用 `group.destroy()` 方法: ```javascript group.destroy(); ``` 上述代码将取消组合,并将组合后的元素从画布中移除。 可以通过 `group.getObjects()` 方法获取组合中的所有元素,进而可以对每个元素进行操作。此外,可以使用 `group.set()` 方法设置组合元素的属性,例如位置、大小、旋转角度等。 以上就是使用 fabric.js 将多选的元素组合的方法。fabric.js 提供了许多方便的功能,可以轻松处理各种绘图需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值