您现在的位置是:网站首页> 编程资料编程资料
Fabric.js 修改画布交互方式作用详解_JavaScript_
2023-05-24
313人已围观
简介 Fabric.js 修改画布交互方式作用详解_JavaScript_
本文简介
fabric.js 为我们提供了很多厉害的方法。今天要搞明白的一个东西是 canvas.interactive 。
官方文档对 canvas.interactive 的解释是:
Indicates that canvas is interactive. This property should not be changed.
canvas.interactive 默认值是 true ,官方建议我们不要修改该值,但我偏不。
动手试试
先来看看将 interactive 设为 false 之后有什么效果。
创建一个画布,并在上面添加一个矩形。

从上面的效果可以看到,选中元素后并没有出现默认的控制点,但还是可以操作元素的缩放和旋转的(旋转的那个操作,我是猜了大概的操作点在那个位置)。
难怪官方劝大家不要修改 interactive ,确实有他的道理。
和 hasControls 、hasBorders 的区别
hasControls 和 hasBorders 需要在图形元素上设置。
将 hasControls 设置成 false 就会取消元素选中时的控制角。
将 hasBorders 设置成 false 就会取消元素被选中时的控制边。

从上图的效果可以看出,将 hasControls 和 hasBorders 设置成 false 后,元素可以移动,但不能缩放和旋转。
和 StaticCanvas 的区别
如果不希望画布可交互,可以使用 StaticCanvas 创建一个静态的画布。
只要将 new fabric.Canvas 改成 new fabric.StaticCanvas 就行了。

瞧,使用了 StaticCanvas 创建的画布,里面的元素选不中也拉不动。
而只是将 interactive 设置成 false 的话,是可以进行操作的。
总结
- 将
interactive设置为false:可操作(移动、旋转、缩放等),但看不见控制角和控制边。 - 将元素的
hasControls和hasBorders设置成false:可移动,但不能旋转和缩放,同时看不见控制角和控制边。 - 使用
StaticCanvas创建画布:元素无法被选中,也无法移动、选中、缩放等操作。
综上所述,在日常开发中,canvas.interactive 真的好像没啥用耶(我还没想到有什么应用场景)。
代码仓库
以上就是Fabric.js 修改画布交互方式作用详解的详细内容,更多关于Fabric.js 修改画布交互的资料请关注其它相关文章!
相关内容
- JavaScript第七种数据类型Symbol的用法详解_javascript技巧_
- axios中如何进行同步请求(async+await)_vue.js_
- vue与electron实现进程间的通信详情_vue.js_
- vuex中store存储store.commit和store.dispatch的区别及说明_vue.js_
- vue中复用vuex.store对象的定义_vue.js_
- Vite打包分割代码的详细过程记录_vue.js_
- Vue实现无限级树形选择器_vue.js_
- vue对象的深度克隆方式_vue.js_
- Vue uni-app以H5模式引入Jquery配置教程_vue.js_
- ES6字符串和数值新增方法总结_javascript技巧_
