详解微信小程序-canvas绘制文字实现自动换行


Posted in Javascript onApril 26, 2019

在使用微信小程序canvas绘制文字时,时常会遇到这样的问题:因为canvasContext.fillText参数为

详解微信小程序-canvas绘制文字实现自动换行

我们只能设置文本的最大宽度,这就产生一定的了问题。如果我们绘制的文本长度不确定或者我们希望文本超出自动换行或者用省略号表示,光靠这个API是无法完成的。下面本人就讲下我在开发中是如何解决这个问题的。

1 wxml代码

<canvas canvas-id="myCanvas" style="border: 1px solid;"/>

 2 wxss代码

canvas {
 width: 99%;
 height: 600rpx;
}

3 js代码

Page({
 data: {

 },
 onLoad: function (options) {
  const context = wx.createCanvasContext('myCanvas')
  var text = '这是一段文字用于文本自动换行文本长度自行设置欢迎大家指出缺陷';//这是要绘制的文本
  var chr =text.split("");//这个方法是将一个字符串分割成字符串数组
  var temp = "";
  var row = [];
  context.setFontSize(18)
  context.setFillStyle("#000")
  for (var a = 0; a < chr.length; a++) {
   if (context.measureText(temp).width < 250) {
    temp += chr[a];
   }
   else {
    a--; //这里添加了a-- 是为了防止字符丢失,效果图中有对比
    row.push(temp);
    temp = "";
   }
  }
  row.push(temp); 

  //如果数组长度大于2 则截取前两个
  if (row.length > 2) {
   var rowCut = row.slice(0, 2);
   var rowPart = rowCut[1];
   var test = "";
   var empty = [];
   for (var a = 0; a < rowPart.length; a++) {
    if (context.measureText(test).width < 220) {
     test += rowPart[a];
    }
    else {
     break;
    }
   }
   empty.push(test);
   var group = empty[0] + "..."//这里只显示两行,超出的用...表示
   rowCut.splice(1, 1, group);
   row = rowCut;
  }
  for (var b = 0; b < row.length; b++) {
   context.fillText(row[b], 10, 30 + b * 30, 300);
  }
  context.draw()  
 } 
})

4 效果展示

添加了a- -和没有a- -的对比

详解微信小程序-canvas绘制文字实现自动换行

以上就是换行的方法,如果想设置为不换行超出用省略号显示,也可参照上面的方法,将数组截取为一行再设置,道理是一样的。

以上所述是小编给大家介绍的微信小程序canvas绘制文字实现自动换行详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript游戏之优化篇
Nov 08 Javascript
javascript高级程序设计第二版第十二章事件要点总结(常用的跨浏览器检测方法)
Aug 22 Javascript
JS实现随机化快速排序的实例代码
Aug 01 Javascript
JavaScript闭包详解
Feb 02 Javascript
js基于FileSaver.js 浏览器导出Excel文件的示例
Aug 15 Javascript
vue引入新版 vue-awesome-swiper插件填坑问题
Jan 25 Javascript
详解angular路由高亮之RouterLinkActive
Apr 28 Javascript
详解vue中移动端自适应方案
May 05 Javascript
vue项目中mock.js的使用及基本用法
May 22 Javascript
移动端 Vue+Vant 的Uploader 实现上传、压缩、旋转图片功能
Jun 10 Javascript
微信小程序缓存支持二次开发封装实现解析
Dec 16 Javascript
javascript绘制简单钟表效果
Apr 07 Javascript
vue 进阶之实现父子组件间的传值
Apr 26 #Javascript
详解JS判断页面是在手机端还是在PC端打开的方法
Apr 26 #Javascript
配置一个vue3.0项目的完整步骤
Apr 26 #Javascript
关于Vue源码vm.$watch()内部原理详解
Apr 26 #Javascript
JS异步错误捕获的一些事小结
Apr 26 #Javascript
原生JS实现图片懒加载之页面性能优化
Apr 26 #Javascript
vue请求本地自己编写的json文件的方法
Apr 25 #Javascript
You might like
推荐一款MAC OS X 下php集成开发环境mamp
2014/11/08 PHP
利用PHP将图片转换成base64编码的实现方法
2016/09/13 PHP
js通过地址栏给action传值(中文乱码全是问号)
2013/05/02 Javascript
Node.js服务器环境下使用Mock.js拦截AJAX请求的教程
2016/05/23 Javascript
【经验总结】编写JavaScript代码时应遵循的14条规律
2016/06/20 Javascript
JavaScript 计算笛卡尔积实例详解
2016/12/02 Javascript
基于JavaScript实现轮播图原理及示例
2020/04/10 Javascript
原生js实现鼠标跟随效果
2017/02/28 Javascript
jQuery插件zTree实现更新根节点中第i个节点名称的方法示例
2017/03/08 Javascript
Vue CLI2升级至Vue CLI3的方法步骤
2019/05/20 Javascript
vue全屏事件开发详解
2020/06/17 Javascript
vue 组件间的通信之子组件向父组件传值的方式
2020/07/29 Javascript
在vue中实现嵌套页面(iframe)
2020/07/30 Javascript
node.js 如何监视文件变化
2020/09/01 Javascript
Python函数中的函数(闭包)用法实例
2016/03/15 Python
Python脚本实时处理log文件的方法
2016/11/21 Python
Django实现组合搜索的方法示例
2018/01/23 Python
浅析Python数据处理
2018/05/02 Python
Python Pandas对缺失值的处理方法
2019/09/27 Python
Windows上安装tensorflow  详细教程(图文详解)
2020/02/04 Python
python3中使用__slots__限定实例属性操作分析
2020/02/14 Python
django中related_name的用法说明
2020/05/20 Python
Python 内存管理机制全面分析
2021/01/16 Python
Burt’s Bees英国官网:世界领先的天然个人护理品牌
2020/08/17 全球购物
电焊工工作岗位职责
2014/02/06 职场文书
丧事答谢词
2015/01/05 职场文书
以权谋私检举信范文
2015/03/02 职场文书
2015年公民道德宣传日活动总结
2015/03/23 职场文书
2015年销售内勤工作总结
2015/04/27 职场文书
525心理健康活动总结
2015/05/08 职场文书
道士塔读书笔记
2015/06/30 职场文书
通讯稿格式及范文
2015/07/22 职场文书
中学教代会开幕词
2016/03/04 职场文书
jQuery class属性操作addClass()与removeClass()、hasClass()、toggleClass()
2021/03/31 jQuery
英镑符号 £
2022/02/17 杂记
解决Git推送错误non-fast-forward的方法
2022/06/25 Servers