Fabric.js 修改画布交互方式作用详解

 更新时间:2022年09月08日 10:24:56   作者:德育处主任  
这篇文章主要为大家介绍了Fabric.js 修改画布交互方式作用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

本文简介

fabric.js 为我们提供了很多厉害的方法。今天要搞明白的一个东西是 canvas.interactive

官方文档对 canvas.interactive 的解释是:

Indicates that canvas is interactive. This property should not be changed.

canvas.interactive 默认值是 true ,官方建议我们不要修改该值,但我偏不。

动手试试

先来看看将 interactive 设为 false 之后有什么效果。

创建一个画布,并在上面添加一个矩形。

<canvas id="canvasBox" width="400" height="400" style="border: 1px solid #ccc;"></canvas>
<script>
  let canvas = new fabric.Canvas('canvasBox', {
    interactive: false // 隐藏交互模式
  })
  let rect = new fabric.Rect({
    top: 60,
    left: 60,
    width: 60,
    height: 60,
    fill: '#08d9d6'
  })
  canvas.add(rect)
</script>

从上面的效果可以看到,选中元素后并没有出现默认的控制点,但还是可以操作元素的缩放和旋转的(旋转的那个操作,我是猜了大概的操作点在那个位置)。

难怪官方劝大家不要修改 interactive ,确实有他的道理。

和 hasControls 、hasBorders 的区别

hasControlshasBorders 需要在图形元素上设置。

hasControls 设置成 false 就会取消元素选中时的控制角。

hasBorders 设置成 false 就会取消元素被选中时的控制边。

<canvas id="canvasBox" width="400" height="400" style="border: 1px solid #ccc;"></canvas>
<script>
  let canvas = new fabric.Canvas('canvasBox')
  let rect = new fabric.Rect({
    top: 60,
    left: 60,
    width: 60,
    height: 60,
    fill: '#08d9d6',
    hasControls: false, // 取消控制角
    hasBorders: false // 取消控制边
  })
  canvas.add(rect)
</script>

从上图的效果可以看出,将 hasControlshasBorders 设置成 false 后,元素可以移动,但不能缩放和旋转。

和 StaticCanvas 的区别

如果不希望画布可交互,可以使用 StaticCanvas 创建一个静态的画布。

只要将 new fabric.Canvas 改成 new fabric.StaticCanvas 就行了。

<canvas id="canvasBox" width="400" height="400" style="border: 1px solid #ccc;"></canvas>
<script>
  let canvas = new fabric.StaticCanvas('canvasBox')
  let rect = new fabric.Rect({
    top: 60,
    left: 60,
    width: 60,
    height: 60,
    fill: '#08d9d6'
  })
  canvas.add(rect)
</script>

瞧,使用了 StaticCanvas 创建的画布,里面的元素选不中也拉不动。

而只是将 interactive 设置成 false 的话,是可以进行操作的。

总结

  • interactive 设置为 false:可操作(移动、旋转、缩放等),但看不见控制角和控制边。
  • 将元素的 hasControlshasBorders 设置成 false :可移动,但不能旋转和缩放,同时看不见控制角和控制边。
  • 使用 StaticCanvas 创建画布:元素无法被选中,也无法移动、选中、缩放等操作。

综上所述,在日常开发中,canvas.interactive 真的好像没啥用耶(我还没想到有什么应用场景)。

代码仓库

Fabric.js 修改画布交互方式

以上就是Fabric.js 修改画布交互方式作用详解的详细内容,更多关于Fabric.js 修改画布交互的资料请关注脚本之家其它相关文章!

相关文章

  • 没有resolve及reject的Promise是否会造成内存泄露

    没有resolve及reject的Promise是否会造成内存泄露

    这篇文章主要为大家介绍了一直没有resolve及reject的Promise是否会造成内存泄露的问题解决,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • 微信小程序(二十一)switch组件详细介绍

    微信小程序(二十一)switch组件详细介绍

    这篇文章主要介绍了微信小程序switch组件详细介绍的相关资料,需要的朋友可以参考下
    2016-09-09
  • JS面试中你不知道的call apply bind方法及使用场景详解

    JS面试中你不知道的call apply bind方法及使用场景详解

    这篇文章主要为大家介绍了JS面试中你不知道的call apply bind方法及使用场景详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • delete 语法的本质深入解析

    delete 语法的本质深入解析

    这篇文章主要为大家介绍了delete 语法的本质深入解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • Umi4集成阿里低代码框架lowcode-engine实现

    Umi4集成阿里低代码框架lowcode-engine实现

    这篇文章主要为大家介绍了Umi4集成阿里低代码框架lowcode-engine实现详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • 微信小程序 详解下拉加载与上拉刷新实现方法

    微信小程序 详解下拉加载与上拉刷新实现方法

    这篇文章主要介绍了微信小程序 详解下拉加载与上拉刷新实现方法的相关资料,这里介绍了两种实现方法,需要的朋友可以参考下
    2017-01-01
  • Javascript基础知识中关于内置对象的知识

    Javascript基础知识中关于内置对象的知识

    这篇文章主要介绍了Javascript基础知识中关于内置对象的相关知识的相关资料,需要的朋友可以参考下面小编薇大家带来的精彩文章
    2021-09-09
  • ECMAScript 6数值扩展实例详解

    ECMAScript 6数值扩展实例详解

    这篇文章主要为大家介绍了ECMAScript6数值扩展实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • 带你理解JavaScript 原型原型链

    带你理解JavaScript 原型原型链

    理解js中原型、原型链这个概念,绝对是帮助我们更深入学习js的必要一步,比如,如果js开发者想理解js继承,new关键字原理,甚至封装组件、优化代码,弄明白js中原型、原型链更是前提条件。本篇文章,用最简洁的文字,清楚明白讲解原型链相等关系和原型、原型链存在的意义
    2021-09-09
  • 微信小程序 获取二维码实例详解

    微信小程序 获取二维码实例详解

    这篇文章主要介绍了 微信小程序 获取二维码实例详解的相关资料,需要的朋友可以参考下
    2017-06-06

最新评论