Fabric.js 使用纯色遮挡画布(前景色)

2023-10-08 21:59

本文主要是介绍Fabric.js 使用纯色遮挡画布(前景色),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


theme: smartblue

我报名参加金石计划1期挑战——瓜分10万奖池,这是我的第8篇文章,点击查看活动详情


本文简介

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

如果要覆盖 canvas 里的所有内容你会用什么方法?

清空画布内容?

直接移除 canvas 元素?

创建一个新元素放在 canvas 的上一层?

如果你的项目使用到 fabric.js ,可以直接使用 fabric.js 提供的方法去遮盖画布,而且用法非常简单。

设置 canvas.overlayColor

前景色 overlayColor

fabric.js 提供了一个属性可以设置覆盖色,也可以说是设置前景色。

overlayColor :String|fabric.Pattern

Overlay color of canvas instance. Should be set via fabric.StaticCanvas#setOverlayColor

使用这个属性可以在画布顶层覆盖一层颜色,可以覆盖画布内所有背景和元素。

能覆盖默认背景色

比如我设置了遮盖色为粉红色

01.png

```html

```

如果上面的代码没有设置 overlayColorpink 的话,画布应该是呈现红色背景的。

能覆盖背景图

01.png

```html

```

我在初始完画布之后,再通过 setBackgroundImage 方法设置画布背景图。

从代码书写顺序看,背景图是最后才设置的,但也不会覆盖到 overlayColor

能覆盖元素

如果从直觉上看,背景图是在最底层,所以无法越级覆盖 overlayColor 的话,那我们可以试试创建元素并将元素设置到最顶层,测试一下效果。

01.png

```html

```

使用了 bringToFront() 方法将矩形的层级调到最顶层,也是无法越过 overlayColor

移除覆盖层

在某些应用场景(比如游戏)需要提前把画布加载出来,但用户在某一时刻还没权限查看画布内容时,就可以使用 overlayColor 将画布遮盖起来。

我使用 setTimeout 模拟达成某些业务条件后,移除覆盖层的效果。

02.gif

```html

```

canvas.overlayColor 设置为 null 后,覆盖层就被移除了,设置成 transparent 或者 空字符串 也可以。

移除覆盖层之后,还需要刷新一下画布,我使用了 canvas.renderAll()

更灵活的方法 setOverlayColor

除了在创建画布时设置 overlayColor 外,还可以使用 setOverlayColor() 方法在某个时刻设置画布遮罩颜色。

setOverlayColor(overlayColor, callback) 接收2个参数:

  • overlayColor: 设置前景色或者图案
  • callback: 回调函数(设置完要刷新画布)

你没看错,setOverlayColor 是可以设置图案的,传入一张图片就行。

我将画布的宽高设置成 800 * 800,方便演示。

设置纯色

03.png

js // 省略部分代码 canvas.setOverlayColor( 'yellowgreen', // 设置颜色 canvas.renderAll.bind(canvas) // 刷新画布 )

如果你还想在回调函数中做点其他事情,可以这样写

js // 省略部分代码 canvas.setOverlayColor('pink', function() { console.log('完成') canvas.renderAll() })

设置图像

04.png

js // 省略部分代码 canvas.setOverlayColor( { source: '../../images/bg4.png' }, canvas.renderAll.bind(canvas) )

第一个参数是对象,在 source 里传入图片路径即可。

上面的例子中,图像是会自动重复渲染的,会铺满整个画布。

除此之外,还可以调节不同属性参数。

js // 省略部分代码 canvas.setOverlayColor( { source: '../../images/bg4.png', repeat: 'no-repeat', // 不重复 offsetX: 200, // x轴方向的偏移 offsetY: 100 // y轴方向的偏移 }, canvas.renderAll.bind(canvas) )

注意

有一点是需要注意的,overlayColor 的作用是在画布顶部设置一层覆盖色,但画布的操作并没有限制。

还是上面有矩形的例子。

05.gif

从图中可以看到鼠标指针的变化,可以判断出画布上的矩形仍然能被操作。

代码仓库

⭐ Fabric.js 使用纯色遮盖画布

⭐ Fabric.js setOverlayColor

推荐阅读

👍《Fabric.js 从入门到_ _ _ _ _ _》

👍《Fabric.js 上划线、中划线(删除线)、下划线》

👍《Fabric.js 激活输入框》

👍《Fabric.js 输出精简的JSON》

👍《Fabric.js 动态设置字号大小》

👍《Fabric.js IText 手动设置斜体》

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

这篇关于Fabric.js 使用纯色遮挡画布(前景色)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/168242

相关文章

C#中checked关键字的使用小结

《C#中checked关键字的使用小结》本文主要介绍了C#中checked关键字的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录✅ 为什么需要checked? 问题:整数溢出是“静默China编程”的(默认)checked的三种用

C#中预处理器指令的使用小结

《C#中预处理器指令的使用小结》本文主要介绍了C#中预处理器指令的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 第 1 名:#if/#else/#elif/#endif✅用途:条件编译(绝对最常用!) 典型场景: 示例

Mysql中RelayLog中继日志的使用

《Mysql中RelayLog中继日志的使用》MySQLRelayLog中继日志是主从复制架构中的核心组件,负责将从主库获取的Binlog事件暂存并应用到从库,本文就来详细的介绍一下RelayLog中... 目录一、什么是 Relay Log(中继日志)二、Relay Log 的工作流程三、Relay Lo

使用Redis实现会话管理的示例代码

《使用Redis实现会话管理的示例代码》文章介绍了如何使用Redis实现会话管理,包括会话的创建、读取、更新和删除操作,通过设置会话超时时间并重置,可以确保会话在用户持续活动期间不会过期,此外,展示了... 目录1. 会话管理的基本概念2. 使用Redis实现会话管理2.1 引入依赖2.2 会话管理基本操作

Springboot请求和响应相关注解及使用场景分析

《Springboot请求和响应相关注解及使用场景分析》本文介绍了SpringBoot中用于处理HTTP请求和构建HTTP响应的常用注解,包括@RequestMapping、@RequestParam... 目录1. 请求处理注解@RequestMapping@GetMapping, @PostMappin

springboot3.x使用@NacosValue无法获取配置信息的解决过程

《springboot3.x使用@NacosValue无法获取配置信息的解决过程》在SpringBoot3.x中升级Nacos依赖后,使用@NacosValue无法动态获取配置,通过引入SpringC... 目录一、python问题描述二、解决方案总结一、问题描述springboot从2android.x

SpringBoot整合AOP及使用案例实战

《SpringBoot整合AOP及使用案例实战》本文详细介绍了SpringAOP中的切入点表达式,重点讲解了execution表达式的语法和用法,通过案例实战,展示了AOP的基本使用、结合自定义注解以... 目录一、 引入依赖二、切入点表达式详解三、案例实战1. AOP基本使用2. AOP结合自定义注解3.

Python中Request的安装以及简单的使用方法图文教程

《Python中Request的安装以及简单的使用方法图文教程》python里的request库经常被用于进行网络爬虫,想要学习网络爬虫的同学必须得安装request这个第三方库,:本文主要介绍P... 目录1.Requests 安装cmd 窗口安装为pycharm安装在pycharm设置中为项目安装req

使用Python将PDF表格自动提取并写入Word文档表格

《使用Python将PDF表格自动提取并写入Word文档表格》在实际办公与数据处理场景中,PDF文件里的表格往往无法直接复制到Word中,本文将介绍如何使用Python从PDF文件中提取表格数据,并将... 目录引言1. 加载 PDF 文件并准备 Word 文档2. 提取 PDF 表格并创建 Word 表格

使用Python实现局域网远程监控电脑屏幕的方法

《使用Python实现局域网远程监控电脑屏幕的方法》文章介绍了两种使用Python在局域网内实现远程监控电脑屏幕的方法,方法一使用mss和socket,方法二使用PyAutoGUI和Flask,每种方... 目录方法一:使用mss和socket实现屏幕共享服务端(被监控端)客户端(监控端)方法二:使用PyA