前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Fabric.js 元素被选中时保持原有层级🥁

Fabric.js 元素被选中时保持原有层级🥁

作者头像
德育处主任
发布2022-06-10 15:25:05
2.4K0
发布2022-06-10 15:25:05
举报
文章被收录于专栏:前端数据可视化

不知道你在使用 Fabric.js 时有没有发现,如果一个画布存在多个元素,而且它们之前是层叠的,当你选中底层的元素时,那个元素会跳到最顶层;当你释放该元素后,它又跑回原有层级。这是 Fabric.js 的默认状态。

如果你不希望操作时出现这种情况,你希望在元素被选中时还保持它原有的层级,那么我推荐你在初始化画布时,设置 preserveObjectStackingtrue

《preserveObjectStacking 文档》

接下来我将举例说明该属性的效果和用法。

默认情况

默认情况是被选中的元素会跑到最顶层,当它被释放后又跑回原来的层级。

01.gif
01.gif
代码语言:javascript
复制
<canvas id="canvasBox" width="600" height="600" style="border: 1px solid #ccc;"></canvas>

<!-- 引入 Fabric.js -->
<script src="https://cdn.bootcdn.net/ajax/libs/fabric.js/521/fabric.js"></script>

<script>
  const canvas = new fabric.Canvas('canvasBox')
  
  // 圆形
  circle = new fabric.Circle({
    name: 'circle',
    top: 60,
    left: 60,
    radius: 30, // 圆的半径 30
    fill: 'yellowgreen'
  })

  // 矩形
  rect = new fabric.Rect({
    name: 'rect',
    top: 30, // 距离容器顶部 60px
    left: 100, // 距离容器左侧 200px
    fill: 'orange', // 填充a 橙色
    width: 60, // 宽度 60px
    height: 60 // 高度 60px
  })
  
  // 将矩形添加到画布中
  canvas.add(circle, rect)
</script>
复制代码

上面的代码,我创建了一个绿色圆形和一个橙色矩形。

canvas.add(circle, rect) 中,先添加圆形,再添加矩形,所以矩形的层级会比圆形高。

我故意调整了两个图形的位置,让它们有一部分是重叠起来的。

所以最终出来的效果是圆形在矩形下面。

Fabric.js 默认情况下,被选中的元素会跳到顶层,所以你可以看看上图的操作效果。

保持原有层级的情况

如果你不想按照默认的情况来操作,尤其是画布中对象比较多的时候,希望被操作的对象一直保持在原有的层级,这样操作起来某些情况下会更直观。那么你可以在初始化画布时将 preserveObjectStacking 设为 true

02.gif
02.gif
代码语言:javascript
复制
// 省略部分代码

const canvas = new fabric.Canvas('canvasBox', {
  // 元素对象被选中时保持在当前z轴,不会跳到最顶层
  preserveObjectStacking: true // 默认false
})
复制代码

代码仓库

元素被选中时保持原有层级

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-06-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 默认情况
  • 保持原有层级的情况
  • 代码仓库
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档