前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Fabric.js 文本自动换行的实现方式

Fabric.js 文本自动换行的实现方式

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

本文简介

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

fabric.js 提供的文本组件中,默认状态是不会自动换行。如果你的使用场景中需要自动文本自动换行,可以使用 Textbox ,并将 splitByGrapheme 设置为 true 即可。

文本自动换行

如果需要实现本文自动换行的效果,可以使用 Textbox

我建议是在初始化时设置好 Textbox 的宽度,然后再将 splitByGrapheme 设置为 true

推荐操作

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

<script>
  // 创建画布
  let canvas = new fabric.Canvas('canvasBox')

  let textbox = new fabric.Textbox('雷猴',{
    width: 200,
    left: 20,
    top: 20,
    splitByGrapheme: true, // 自动换行
  })

  // 将文本添加到画布中
  canvas.add(textbox)
</script>

设置好宽度之后,输入文字时就可以根据宽度自动换行。

除了在初始化设置 splitByGrapheme 外,还可以拎出来设置。

代码语言:javascript
复制
// 省略部分代码
let textbox = new fabric.Textbox('雷猴', {...})
textbox.splitByGrapheme = true

没设置宽度的情况

如果没设置宽度,渲染时就会以1个字的宽度为准。

02.gif
02.gif
代码语言:javascript
复制
// 省略部分代码
let textbox = new fabric.Textbox('雷猴',{
  left: 20,
  top: 20,
  splitByGrapheme: true, // 自动换行
})

在运行时调整

除了初始化 Textbox 时设置宽度外,还可以在运行时让用户调整文本框的宽度,只要 splitByGraphemetrue 时,Textbox 里的文本就会实时根据宽度进行换行。

03.gif
03.gif

禁止用户调整文本框高度

了解过 fabric.js 的工友都知道,fabric.js 默认是允许用户缩放元素的。

如果 Textbox 元素的在页面上被用户垂直拉伸,里面的文本就会变形。

04.gif
04.gif

此时我们可以使用 setControlVisible 方法删除垂直缩放的操作点,禁止用户垂直缩放。

代码语言:javascript
复制
// 省略部分代码
textbox.setControlVisible('mt', false)
textbox.setControlVisible('mb', false)

setControlVisible 第一个参数是操作点(控件)的键,分别有 tl, tr, br, bl, ml, mt, mr, mb, mtr

mt 表示中间顶部的操作点,mb 表示中间底部的操作点。

第二个参数设置控件是否可见。true 是默认值,表示可见;设置成 false 代表指定控件不可见。

默认情况

最后回顾一下 Textbox 的默认情况。

在没将 splitByGrapheme 设置为 true 时,横向拉长文本框时,里面的文字不会变形。

但文本框的最小宽度取决于里面最长一行的文本宽度。

05.gif
05.gif

代码仓库

文本自动换行

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

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 本文简介
  • 文本自动换行
    • 推荐操作
      • 没设置宽度的情况
        • 在运行时调整
          • 禁止用户调整文本框高度
            • 默认情况
            • 代码仓库
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档