Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Fabric.js 禁止元素超出画布

Fabric.js 禁止元素超出画布

作者头像
德育处主任
发布于 2022-09-23 02:18:01
发布于 2022-09-23 02:18:01
4.5K00
代码可运行
举报
运行总次数:0
代码可运行

本文简介

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

本文主要讲解如何禁止元素超出画布范围。效果如下图所示。

就算是修改了元素尺寸也一样可以限制元素超出画布。

分析

要实现上图的效果,需要考虑2中情况:

  1. 【情况1】元素的左边和上边不能超出画布的左边和上边。
  2. 【情况2】元素的右边和下边不能超出画布的右边和下边。

这两句话看上去很像一句话,但其实真实情况是有点不一样的。

元素的坐标和画布的坐标,都是以左上角为原点。所以【情况1】只需考虑元素的 xy坐标 有没有超过画布的左边和上边。

【情况2】是用元素右边和下边跟画布做比较,而元素的原点是在元素的左上角,所以元素的右边是 元素原点x坐标 + 元素的宽度 ,元素的下边是 元素原点y坐标 + 元素的高度

要获取画布的边界,我在文档中找到 calcViewportBoundaries 方法。

要获取被操作图形的边界,文档也给出了 getBoundingRect 方法。

最后得出的公式:

  • 【公式1】超出画布左边:图形左上方x坐标 < 画布左上方x坐标,将图形的 left 设置成画布左上方x坐标的值。
  • 【公式2】超出画布上边:图形左上方y坐标 < 画布左上方y坐标,将图形的 top 设置成画布左上方y坐标的值。
  • 【公式3】超出画布右边:图形左上方x坐标 + 图形宽度 > 画布右下方x坐标,将图形的 left 设置成画布右下方x坐标 - 图形宽度
  • 【公式4】超出画布下边:图形左上方y坐标 + 图形高度 > 画布右下方y坐标,将图形的 top 设置成画布右下方y坐标 - 图形高度

动手编码

公式有了,接下来就思考一下触发公式的时机。

我将这时机设置在元素的 mouseup 事件,也就是移动元素后松开鼠标的时刻

代码如下所示

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<canvas id="canvasBox" width="600" height="600" style="border: 1px solid #ccc;"></canvas>

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

  // 矩形
  let rect = new fabric.Rect({
    width: 40,
    height: 40,
    left: 10,
    top: 10,
    fill: 'pink'
  })
  // 将矩形添加到画布中
  canvas.add(rect)

  // 作用在矩形的事件:松开鼠标
  rect.on('mouseup', ev => {
    // 获取画布视口边界
    let canvasBoundaries = canvas.calcViewportBoundaries()

    // 矩形本身
    let obj = ev.target

    // 矩形的边界
    let objBoundingRect = obj.getBoundingRect()

    // 【公式1】
    if (objBoundingRect.left < canvasBoundaries.tl.x) {
      ev.target.left = canvasBoundaries.tl.x
    }

    // 【公式2】
    if (objBoundingRect.left + objBoundingRect.width > canvasBoundaries.br.x) {
      ev.target.left = canvasBoundaries.br.x - objBoundingRect.width
    }

    // 【公式3】
    if (objBoundingRect.top < canvasBoundaries.tl.y) {
      ev.target.top = canvasBoundaries.tl.y
    }

    // 【公式4】
    if (objBoundingRect.top + objBoundingRect.height > canvasBoundaries.br.y) {
      ev.target.top = canvasBoundaries.br.y - objBoundingRect.height
    }

    // 刷新画布
    canvas.renderAll()
  })
</script>

在理解了原理之后,事情就变得非常简单了。

代码仓库

元素不超出画布

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

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

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

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

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Fabric.js 元素中心缩放
如果想将默认缩放操作设置为“中心缩放”,只需将 centeredScaling 属性设置为 true 即可。
德育处主任
2022/09/23
3.3K0
Fabric.js 元素中心缩放
Fabric.js 拖放元素进画布
上面的代码使用了 Fabric.js 绑定了页面上的画布,并创造了一个粉红色的矩形。
德育处主任
2023/01/13
3.5K0
Fabric.js 拖放元素进画布
使用Vue + fabric.js构建标注工具的细节
上篇文章大致介绍了使用Vue + fabric.js构建标注工具的流程,本篇则将其中的一些细节以及fabric的踩坑进行补充
扬起
2022/06/28
4K0
使用Vue + fabric.js构建标注工具的细节
Fabric.js 变换视窗
fabric.js 可以通过 viewportTransform 属性配置画布的视窗属性。
德育处主任
2022/09/23
3.5K0
Fabric.js 变换视窗
Fabric.js 自由绘制椭圆
持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第2天,点击查看活动详情
德育处主任
2022/09/23
2.8K0
Fabric.js 自由绘制椭圆
Fabric.js 修改画布交互方式到底有什么用?
fabric.js 为我们提供了很多厉害的方法。今天要搞明白的一个东西是 canvas.interactive 。
德育处主任
2022/09/23
1.5K0
Fabric.js 修改画布交互方式到底有什么用?
Fabric.js 缩放画布 🍬
getZoom 可以获取画布当前缩放级别,用 setZoom 设置一个新的缩放级别。
德育处主任
2022/06/10
6.2K0
Fabric.js 缩放画布 🍬
Fabric.js 使用图片遮盖画布(前景图)
在 《Fabric.js 使用纯色遮挡画布(前景色)》 中讲到使用纯色的方式遮盖画布。如果你的常见需要使用图片来遮盖的话,fabric.js 也提供了相应的属性来配置。
德育处主任
2022/09/23
2K0
Fabric.js 使用图片遮盖画布(前景图)
Fabric.js 居中元素 🎗️
阅读本文需要你有一定的 Fabric.js 基础,如果还不太了解 Fabric.js 是什么,可以阅读 《Fabric.js 从入门到膨胀》
德育处主任
2022/06/10
4K0
Fabric.js 居中元素 🎗️
基于Vue + fabric.js的图片标注组件搭建
做这个组件的初衷,是基于AI组的标注识别,传送一张图片以及图片上的一些坐标,返回对应的识别结果,前端要做的就是基于一张图片,在图片上绘制出相应的标注框,并将标注框对应的坐标以及宽高传送给后端进行识别,这是最基础的需求。在图片上进行绘制,首先想到的是用canvas,cancas强大的功能能让我们在图片上为所欲为,原生的canvasapi众多且繁杂,上手不易,fabric是一个基于canvas的强大的框架,提供一种类似面向对象的方法来编写canva,在原生canvas之上提供了交互式对象模型,通过简洁的api就可以在画布上进行丰富的操作。因此选择fabric来作为基础框架。
扬起
2022/06/28
6K1
基于Vue + fabric.js的图片标注组件搭建
Fabric.js 使用纯色遮挡画布(前景色)
如果你的项目使用到 fabric.js ,可以直接使用 fabric.js 提供的方法去遮盖画布,而且用法非常简单。
德育处主任
2022/09/23
1.6K0
Fabric.js 使用纯色遮挡画布(前景色)
Fabric.js 元素被遮挡的部分也可以操作~
其实 Fabric.js 已经提供了相应的 API 去完成上面的需求了。但直到今天, Fabric.js 官方文档还是那么晦涩难懂,于是就有了本文。
德育处主任
2022/09/23
1.5K0
Fabric.js 元素被遮挡的部分也可以操作~
Fabric.js 元素被选中时保持原有层级🥁
不知道你在使用 Fabric.js 时有没有发现,如果一个画布存在多个元素,而且它们之前是层叠的,当你选中底层的元素时,那个元素会跳到最顶层;当你释放该元素后,它又跑回原有层级。这是 Fabric.js 的默认状态。
德育处主任
2022/06/10
2.7K0
Fabric.js 元素被选中时保持原有层级🥁
Fabric.js 清空画布,甚至连画布元素也给你干掉😏
上面的代码可以把清空画布,但如果没有了解过 canvas ,或者不熟悉的工友,看到上面的代码可能会有点懵。
德育处主任
2022/09/23
4.7K0
Fabric.js 清空画布,甚至连画布元素也给你干掉😏
Fabric.js 自由绘制矩形(逐一分析4种操作方向带来的影响)
起始点 的 x 和 y 坐标 都小于 结束点,( 起始点x < 结束点x;起始点y < 结束点y ) :
德育处主任
2022/04/17
3.8K2
Fabric.js 自由绘制矩形(逐一分析4种操作方向带来的影响)
Fabric.js 右键菜单
Fabric.js 默认**没提供 鼠标右键事件**,只有 鼠标按键点击 、鼠标按键抬起 、鼠标移动 等事件。 但在工作中有可能需要用到 “右键” 事件,比如 “右键菜单” 。所以就有了本文。 本文主要关注 Fabric.js 的主要 api 有:
德育处主任
2022/04/17
7.9K0
Fabric.js 右键菜单
Fabric.js 从入门到________
如果你需要用 canvas 做特效,那我推荐你使用 Fabric.js ,因为 Fabric.js 语法更加简单易用,而且还提供了很多交互类的 api。
德育处主任
2022/04/17
13.9K0
Fabric.js 从入门到________
Fabric.js 拖拽平移画布
不过我们可以利用一些小技巧让画布具有被拖拽的能力,fabric.js 官网也提供了一个 demo ,但文档上并没有详细的讲解拖拽画布的实现原理。
德育处主任
2022/09/23
3.6K0
Fabric.js 拖拽平移画布
Fabric.js 删除元素(带过渡动画)
本文重点讲 带过渡动画 删除元素的方法,还会讲到设置 过渡时长 、删除后的 回调函数 等知识点。
德育处主任
2022/04/17
2.9K0
Fabric.js 删除元素(带过渡动画)
Fabric.js 锁定背景图,不受缩放和拖拽的影响🎃
如果你的项目有画布拖拽、缩放等功能,而且你不希望背景图跟随拖拽或缩放,那一定要往下读。
德育处主任
2022/06/10
3.4K0
Fabric.js 锁定背景图,不受缩放和拖拽的影响🎃
相关推荐
Fabric.js 元素中心缩放
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验