当前位置:网站首页>Fabric.js 动态设置字号大小
Fabric.js 动态设置字号大小
2022-08-02 13:17:00 【51CTO】
点赞 + 关注 + 收藏 = 学会了
本文使用 Fabric.js 的 IText 演示。如果你还不懂 Fabric.js ,我墙裂推荐你阅读 《Fabric.js从入门到精通》。
一图胜千言,先看看图我们再写作文~

分析
需求
从上图可以看出以下功能需求:
- 文本被选中后才能修改字号
- 整体修改字号
- 修改被选中的几个字的字号,没被选中的不进行修改
解决思路
- 获取被选中的文字:
canvas.getActiveObject()。 - 是否只选中一部分文字:
- 我通过编辑状态来判断是否只选中一部分文字:
isEditing。 - 修改被选中文字的样式:
setSelectionStyles({...})。
- 我通过编辑状态来判断是否只选中一部分文字:
- 修改
fontSize属性。 - 如果是全文修改,还要判断是否有些字符在自身设置了
fontSize,如果文字自己设置了fontSize,那全文设置的权重没独立设置的那么高。
编码
使用 isEditing 判断当前是否进入编辑状态,我是根据编辑状态下是否有选中文字来修改字号大小的。
最后有2层循环:
第一层循环 i 是行数的遍历;第二层循环 j 是当前行的文字的遍历。
这么做是因为如果只使用 setSelectionStyles 设置字号大小是无法覆盖每个字本身被设置的 fontSize 。所以还是需要循环一遍,保证每个字都修改到位。
设置字号大小的例子还可以用在上标和下标里,比如 《Fabric.js 上标和下标的使用偏方》 一文中的用法。上标和小标适应用在合在数学公式和化学符号等场景。
代码仓库
推荐阅读
《Fabric.js 锁定背景图,不受缩放和拖拽的影响》点赞 + 关注 + 收藏 = 学会了
边栏推荐
- Js scratchable latex style draw plug-in
- FreeRTOS creation tasks - dynamic creation, static creation
- js array recursively use
- RestTemplate use: set request header, request body
- 路由-嵌套路由
- 网络流详解(流网图一般能够反映什么信息)
- Oracle update error operation single table rollback
- Introduction to Graph Neural Networks (GNN) "Recommended Collection"
- "Second Uncle" is popular, do you know the basic elements of "exploding" short videos from the media?
- js semi-circle loading progress animation js special effects
猜你喜欢
随机推荐
Closures in JS
Automatically generate code generator recommendation-code-gen
【C语言】剖析函数递归(1)
单例模式的七种写法,你都知道吗?
Mysql索引详解(图文并茂)
86.(cesium之家)cesium叠加面接收阴影效果(gltf模型)
js array recursively use
你知道图论的Dijkstra吗?
First acquaintance of scrapy framework 1
我的创作纪念日
【C语言】手撕循环结构 ——do...while语句及循环练习题(1)
RESTful style (detailed introduction + case implementation)
【C语言】函数哪些事儿,你真的get到了吗?(1)
第48篇-timestamp2参数分析【2022-08-01】
The uniapp/applet onload method executes the interpretation every time the page is opened
A powerful js pop-up alert plugin
【C语言】手撕循环结构 —— while语句
使用Amazon SageMaker 构建基于自然语言处理的文本摘要应用
【C语言】手撕循环结构 —— for语句
鲁大师7月新机性能/流畅榜:骁龙8+正面对决天玑9000+,性能跑分突破123万!









