JS-在canvas中渲染文字的时候文本自动换行

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
drawText: function (ctx, str, leftWidth, initHeight, titleHeight, canvasWidth) {
  var lineWidth = 0;
  var num = 1;
  var lastSubStrIndex = 0; //每次开始截取的字符串的索引
  str=str.replace(/\s*/g,"");
  for (let i = 0; i < str.length; i++) {
    lineWidth += ctx.measureText(str[i]).width;
    if (lineWidth > canvasWidth) {
      num++;
      if (num < 3) {
        ctx.fillText(str.substring(lastSubStrIndex, i), leftWidth, initHeight); //绘制截取部分
      } else {
        ctx.fillText(str.substring(lastSubStrIndex, i-3) + "...", leftWidth, initHeight); //绘制截取部分
        return
      }
      
      initHeight += 26; //16为字体的高度
     
       
      lineWidth = 0;
      lastSubStrIndex = i;
      titleHeight += 30;
    }
    if (i == str.length - 1) { //绘制剩余部分
      ctx.fillText(str.substring(lastSubStrIndex, i + 1), leftWidth, initHeight);
    }
  }
  // 标题border-bottom 线距顶部距离
  titleHeight = titleHeight + 10;
  return titleHeight
},

  

posted @   MiniDuck  阅读(599)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2018-10-22 小程序-支持的最小像素px
2018-10-22 js-图片img转base64格式
点击右上角即可分享
微信分享提示