本文主要关注 Fabric.js 的主要 api 有: fireRightClick:允许右键点击 stopContextMenu:禁用默认右键菜单 mouse:down:鼠标点击事件 如果不知道 Fabric.js...的同学,可以看 《Fabric.js 从入门到___》 本案例是使用原生方式开发,不基于 Vue 、React 等框架,所以不用太担心运行环境等问题。...实现思路: 创建画布; 创建 “菜单” 的DOM元素; 去官网查找 “右键相关事件”; 右键单击在元素上,根据鼠标离画布边缘的距离,计算菜单要显示的位置; 左键单击在画布上,隐藏菜单; 实现 查文档...在 对象相关的文档 里,关于鼠标的事件好像没有右键,稍微沾边点的就是鼠标点击(这里我选了 mousedown)。...于是我去 画布的文档 里找了下,发现这两个属性: fireRightClick :画布是否可以触发右键事件 stopContextMenu:禁止默认右键菜单 哈哈哈哈,发达了~ 经我仔细观察,发现 mouse
本文简介 点赞 + 关注 + 收藏 = 学会了 使用 fabric.js 创建出来的画布默认是不能拖拽移动的。...不过我们可以利用一些小技巧让画布具有被拖拽的能力,fabric.js 官网也提供了一个 demo ,但文档上并没有详细的讲解拖拽画布的实现原理。 本文就粗略分析一下这个原理。...viewportTransform 是 fabric.js 在画布上的一个属性。...官方文档是这样介绍的: The transformation (a Canvas 2D API transform matrix) which focuses the viewport 上面的代码...以上就是在 fabric.js 中拖拽画布的方法。 代码仓库 ⭐拖拽移动画布
Fabric.js 也提供了缩放画布的功能,本文主要讲解设置画布大小的几种方法。 动手实现 在动手前先查查文档。...我把和本文相关的文档放在这 mouse:wheel:滚轮事件 getZoom:获取画布当前缩放级别 setZoom:设置画布缩放级别 zoomToPoint:设置画布缩放比例及缩放原点 其中 setZoom...-- 引入 Fabric.js --> fabric.js/521/fabric.js">...-- 引入 Fabric.js --> fabric.js/521/fabric.js">...-- 引入 Fabric.js --> fabric.js/521/fabric.js">
本文简介 点赞 + 关注 + 收藏 = 学会了 fabric.js 可以通过 viewportTransform 属性配置画布的视窗属性。...听上去很高级的样子,但其实这是原生 canvas 就已经存在的东西,fabric.js 的 viewportTransform 也就直接复用了原生 canvas 的 transform() 。...fabric.js 官方文档上也是这么说的 viewportTransform :Array The transformation (a Canvas 2D API transform matrix...学 fabric.js 最主要是动手实践,写多几次慢慢就能领悟其中原理。 viewportTransform 的6个参数主要实现3个功能:缩放、倾斜、平移。
---- 画布 Fabric.js 的画布操作性是非常强的,这里我列举几个常用例子,其他操作可以查看官方文档。...『Fabric.js 画布操作 - 文档』 本节案例在线预览 - 画布 本节代码仓库 基础版(可交互) 基础版就是“起步”章节所说的那个例子。...绘制路径 『Fabric.js 路径Path - 文档』 本节案例在线预览 - 绘制路径 本节代码仓库 <canvas width="400" height="375"...渐变 『Fabric.js 渐变 - 文档』 本节案例在线预览 - 渐变 本节代码仓库 线性渐变 image.png <canvas width="600" height=...动画 『Fabric.js animate - 文档』 本节案例在线预览 - 动画 本节代码仓库 绝对值动画 先别管什么 绝对值动画 和 相对值动画 ,等学完这节再往下看就知道了。
本文简介 元素是 Fabric.js 的重要组成部分,如果画布上没有元素,那其实没啥意义。 元素数量多了,难免会产生重叠。又或者某些效果需要几个元素重叠起来。这些情况大概率需要控制元素的层级。...本文将讲解 Fabric.js 中的5种控制元素层级的方法。...-- 省略引入 fabric.js 代码 --> // 省略部分代码 function bringToFront() { canvas.bringToFront(rect...-- 省略引入 fabric.js 代码 --> // 省略部分代码 function sendToBack() { canvas.sendToBack(triangle...-- 省略引入 fabric.js 代码 --> // 省略部分代码 function sendToBack() { canvas.bringForward(rect)
本文简介 点赞 + 关注 + 收藏 = 学会了 使用 fabric.js 创建的图形,默认的缩放原点是元素操作点的对角点。 如下图所示: 如果按住 alt 键 操作会把原点移动到元素中心。...rect.centeredScaling = true 代码仓库 ⭐ Fabric.js 中心缩放
本文介绍fabric.js框架使用,以及使用fabricjs打造一个高级画板程序....全局绘制颜色选择 护眼模式、网格模式切换 自由绘制 画箭头 画直线 画虚线 画圆/椭圆/矩形/直角三角形/普通三角形/等边三角形 文字输入 图片展示及相关移动、缩放等操作 删除功能 (文末附:画板GitHub地址&fabric.js...fabric.js介绍 fabric.js是什么 fabric.js是可以简化canvas编写的js库,提供canvas缺少的对象模型,包含动画、数据序列号和反序列化的等高级功能的js库,开源项目,在GitHub...fabric.js优缺点 优点:fabric提供超好的画布能力....缺点:api超级烂,没有相应的demo代码,上手难度较大. fabric.js使用笔记 对象 fabric.Circle 圆 fabric.Ellipse 椭圆 fabric.Line 直线 fabric.Polygon
在使用 Fabric.js 开发时,可能会需要将元素居中。...本文总结了 Fabric.js 常用的将元素居中的方法,其中包括: 基于视窗的水平居中 基于画布的水平居中 带动画效果的水平居中 基于视窗的垂直居中 基于画布的垂直居中 带动画效果的垂直居中 同时实现水平和垂直居中...阅读本文需要你有一定的 Fabric.js 基础,如果还不太了解 Fabric.js 是什么,可以阅读 《Fabric.js 从入门到膨胀》 创建基础项目 为了方便演示,我在初始化画布的时: 添加一个背景图...-- 引入 Fabric.js --> fabric.js/521/fabric.js">...元素自己根据画布进行居中 // rect.centerH() 复制代码 带动画效果 // 省略部分代码 canvas.fxCenterObjectV(rect) 复制代码 水平 + 垂直 同时居中 Fabric.js
本文介绍 Fabric.js 的圆形笔刷功能。 圆形笔刷是作用在 “自由绘制” 的画笔之上的。从名字就可以看出,这个笔刷会用一个个圆形来填充绘制的路径。...看图会更直观 Fabric.js 会使用不同频率、大小、颜色深浅来绘制出上图效果。 本文使用 Fabric.js 5.2.1 常用配置 要做出上图的效果,首先需要将画布设置成 绘画模式 。...-- 引入 Fabric.js --> fabric.js/521/fabric.js">
本文简介 带尬猴,我是德育处主任 虽然 Fabric.js 提供的基础功能已经很丰富了,但有时难免需要定制一些需求。比如本文要讲的 『自定义控件』。...尽管 Fabric.js 的文档很一般,但 demo 还挺丰富。本文讲解 Fabric.js 官网收录的 Custom controls, render and actions 。...如果你对这些代码还不太熟悉的话,推荐阅读一下 《Fabric.js 中文入门教程》 创建删除按钮 创建自定义控件通常有一下2步操作: 创建控件 添加功能事件 Fabric.js 提供了 fabric.Control...Custom controls, render and actions 的代码 前面讲到的就是创建自定义控件的基本方法, Fabric.js 官网收录的 Custom controls, render.../js/fabric.js"> var canvas = this.
如果你还不太了解 Fabric.js 的序列化和反序列化,可以看看 Fabric.js 序列化 和 Fabric.js 反序列化。 本文要讲的 “精简JSON” 其实是 精简版序列化 。...如果要重新渲染,就把这段 JSON 丢给 Fabric.js ,调用对应的方法即可渲染到页面上。...-- 引入 Fabric.js --> fabric.js/521/fabric.js">...则优先于对象值 }) console.log(canvas.toObject()) // 输出序列化的内容 复制代码 《canvas.includeDefaultValues 文档...源码仓库 ⭐Fabric.js 精简序列化
本文简介 点赞 + 关注 + 收藏 = 学会了 fabric.js 的铅笔其实是继承基础画笔的一个工具,在基础画笔的基础上多了“拐角平滑度”等配置项。 本文讲解铅笔的基础用法以及常用事件。...在 fabric.js 中,铅笔同样有不同配置。 开启绘图模式 要使用铅笔的话,首先要开启“绘图模式”。 下面这段代码是本文的基础代码,之后配置到的铅笔属性和铅笔相关的方法都是基于这段代码的基础。...引入 fabric.js 的代码我就不写了,如果不知道如何引入可以查看 《Fabric.js 从入门到膨胀》。...fabric.js 的铅笔可以通过 strokeLineJoin 属性设置拐角,支持 bevel 斜面、 round 圆形、 miter 斜面 三个属性。...straightLineKey 支持以下配置: shiftKey: shift键,默认 altKey: alt键 ctrlKey: ctrl键 'none'、'undefined'、'null': 取消组合键 事件 fabric.js
这是我参与「掘金日新计划 · 6 月更文挑战」的第2天,点击查看活动详情 本文简介 点赞 + 关注 + 收藏 = 学会了 本文讲解在 Fabric.js 中如何自由绘制椭圆形,如果你还不了解 Fabric.js...,可以查阅 《Fabric.js从入门到精通》。...效果如下图所示 思路 Fabric.js 在初始化画布之后,可以执行框选操作,但默认是使用矩形的方式来框选,如下图所示: 我希望使用鼠标创建椭圆的时候可以又一个椭圆的影子出来,这能让我更方便去观察当前要画的椭圆大概是什么样子.../521/fabric.js"> let canvas = null let currentType = 'default' let downPoint...代码仓库 ⭐Fabric.js 自由绘制椭圆
在 《Fabric.js 自由绘制矩形》 里讲到的思路,放在圆形里不太适用。 这次要做到的效果如下图所示。...思路 Fabric.js 默认的框选操作是矩形,如果需要做到上图的效果,需要做以下3步: 点击画布时 canvas.on('mouse:down', fn),创建一个圆形。...如果你想知道在 Vue3 环境下如何实现 Fabric.js 自由绘制矩形,可以在 代码仓库 里查找。 fabric.js --> fabric.js/460/fabric.js">...function canvasMouseDown(e) { downPoint = e.absolutePointer if (currentType === 'circle') { // 使用 Fabric.js
在 Fabric.js 中,IText 组件也提供了类似的方法。...-- 引入 Fabric.js --> fabric.js/521/fabric.js">...《enterEditing 文档》 再进一步 使用 enterEditing() 后输入框是激活了,也能看到光标一闪一闪。 但这就完了吗?...《setActiveObject 文档》 总结 Fabric.js 其实并不难,它比起直接使用原生 Canvas 要简单多了。...使用 Fabric.js 最主要是多看文档,然后把多个 api 结合起来使用,就能创造出多种效果~ 代码仓库 ⭐IText 激活输入框
本文使用 Fabric.js 的 IText 演示。如果你还不懂 Fabric.js ,我墙裂推荐你阅读 《Fabric.js从入门到精通》。...height="300" style="border: 1px solid #ccc">\n\nfabric.js.../521/fabric.js">\n\n const canvas = new fabric.Canvas('c')\n\n const iText...设置字号大小的例子还可以用在上标和下标里,比如 《Fabric.js 上标和下标的使用偏方》 一文中的用法。上标和小标适应用在合在数学公式和化学符号等场景。
本文简介 fabric.js 提供了一个方法可以检查对象是否与另一个对象相交(也可以叫元素是否重叠)。 这个方法叫 intersectsWithObject()。...本文主要想提一下 fabric.js 存在这么一个方便的方法。 检测元素是否相交有什么用呢? 这个功能在日常开发中其实很实用,在它的帮助下我们可以实现“防止对象碰撞”、“对象自动对齐贴合”等功能。.../js/fabric.js"> let canvas = new fabric.Canvas('c') // 矩形 - 亮粉色 let rect = new
要获取画布的边界,我在文档中找到 calcViewportBoundaries 方法。 要获取被操作图形的边界,文档也给出了 getBoundingRect 方法。
领取专属 10元无门槛券
手把手带您无忧上云