Fabric.js 实现文本自动换行

在Fabric.js中,可以通过 Text  IText;创建文字,但是文本是无法换行

 Fabric.js 提供了 Textbox 类,继承自 IText;

Textbox 类允许用户调整文本矩形的大小并自动换行。文本框的Y比例已锁定,用户只能更改宽度。高度将根据线的环绕自动调整。

 代码

  • 设置 splitByGrapheme
  • 设置 width
  • 设置 lockScalingY
let text = new fabric.Textbox(work, {
        stroke: "red",
        fill: "blue",
        width: 100,
        top: 0,
        left: 0,
        fontSize: 18,
        lineHeight: 1,
        fontWeight: "bold",
        textAlign: "left", // 文字对齐
        lockRotation: true, // 禁止旋转
        lockScalingY: true, // 禁止Y轴伸缩
        lockScalingFlip: true, // 禁止负值反转
        splitByGrapheme: true, // 拆分中文,可以实现自动换行
        objectCaching: false,
    });

效果

         控制 mr 的 control 可以动态对文本进行换行。

 


 Q:

        但是,当Textbox选中(selected)一次后,再次选中修改宽度时,问题就来了。

        修改宽度文本没有自动换行,而是文本被拉长压缩了。

        对比前后两次的target属性,发现再次修改时,target的属性出现了scaleX、controls等属性,以至于后面宽度变化不会自动换行,而是文字伸缩。

解决:

        监听 textbox 的 scaling 事件,修改 textbox 的 scaleX 和 width 属性

text.on("scaling", (ev)=>{
        let target = ev.transform.target
        let width = target.get("width") * target.get("scaleX")
        target.set("width", width)
        target.set("scaleX", 1)
    })

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值