您的位置 首页 > 数码极客

微信小程序的text如何加入换行

内容导读

参数类型说明 x Number绘制文本的左上角x坐标位置 y Number绘制文本的左上角y坐标位置 color Color字体的颜色 size Number字体的字号 align String文字的对齐,可选值 'left'、'center'、'right' baseline String设置文字的水平对齐,可选值 'top'、'bottom'、'middle'、'normal' text String在画布上绘制被填充的文本。参数类型说明 x Number绘制文本的左上角x坐标位置 y Number绘制文本的左上角y坐标位置widthNumber文本区域宽度heightNumber文本行高lineNumber最多显示几行 color Color字体的颜色 size Number字体的字号 align String文字的对齐,可选值 'left'、'center'、'right' baseline String设置文字的水平对齐,可选值 'top'、'bottom'、'middle'、'normal' text String在画布上绘制被填充的文本。优化原理:通过基础库 1.9.90 开始支持的 measureText 接口返回的文本宽度,把每个字符宽度不断累加,精确计算在哪个位置应该换行去实现这个功能。参数类型说明widthNumber文本区域宽度 size Number字体的字号 text String在画布上绘制被填充的文本。仅支持 italic, oblique, normalweight字体粗细。仅支持 normal, boldsize字体大小family字体族名。

直接上代码

Page({ /** * 渲染文字 * * @param {Object} obj */ drawText: function (obj) { con('渲染文字') (); ); ); ); ); if ) { con('字体加粗') , obj.x, obj.y - 0.5); , obj.x - 0.5, obj.y); } , obj.x, obj.y); if ) { , obj.x, obj.y + 0.5); , obj.x + 0.5, obj.y); } (); }, /** * 文本换行 * * @param {Object} obj */ textWrap: function (obj) { con('文本换行') var td = Ma / )); var tr = Ma.length / td); for (var i = 0; i < tr; i++) { var txt = { x: obj.x, y: obj.y + (i * obj.height), color: obj.color, size: obj.size, align: obj.align, baseline: obj.baseline, text: obj.(i * td, (i + 1) * td), bold: obj.bold }; if (i < obj.line) { if (i == obj.line-1){ = txt.(0, .length - 3) +'......'; } (txt); } } }, })

参数说明

drawText:

let title = { x: 40, y: 524, color: '#333333', size: 32, align: 'left', baseline: 'top', text: '哈哈哈哈,加粗', bold: true }; (title);

参数 类型 说明 x Number 绘制文本的左上角x坐标位置 y Number 绘制文本的左上角y坐标位置 color Color 字体的颜色 size Number 字体的字号 align String 文字的对齐,可选值 'left'、'center'、'right' baseline String 设置文字的水平对齐,可选值 'top'、'bottom'、'middle'、'normal' text String 在画布上绘制被填充的文本。 bold Boolean 是否加粗 textWrap:

let details = { x: 40, y: 576, width: 520, height: 40, line: 2, color: '#666666', size: 24, align: 'left', baseline: 'top', text: '新建项目选择小程序项目,选择代码存放的硬盘路径,填入刚刚申请到的小程序的 AppID,给你的项目起一个好听的名字。', bold: false } (title);

参数 类型 说明 x Number 绘制文本的左上角x坐标位置 y Number 绘制文本的左上角y坐标位置 width Number 文本区域宽度 height Number 文本行高 line Number 最多显示几行 color Color 字体的颜色 size Number 字体的字号 align String 文字的对齐,可选值 'left'、'center'、'right' baseline String 设置文字的水平对齐,可选值 'top'、'bottom'、'middle'、'normal' text String 在画布上绘制被填充的文本。 bold Boolean 是否加粗 效果

生成图片效果

注意,以上是简单的实现,所有如果有英文会短缺,解决方法如下:

优化原理:通过基础库 1.9.90 开始支持的measureText接口返回的文本宽度,把每个字符宽度不断累加,精确计算在哪个位置应该换行去实现这个功能。

/** * 获取文本折行 * @param {Object} obj * @return {Array} arrTr */ getTextLine: function(obj){ ); let arrText = obj.(''); let line = ''; let arrTr = []; for (let i = 0; i < arrText.length; i++) { var testLine = line + arrText[i]; var metrics = (testLine); var width = me; if (width > obj.width && i > 0) { arrTr.push(line); line = arrText[i]; } else { line = testLine; } if (i == arrText.length - 1) { arrTr.push(line); } } return arrTr; },

参数 类型 说明 width Number 文本区域宽度 size Number 字体的字号 text String 在画布上绘制被填充的文本。 之后,textWrap方法改为:

/** * 文本换行 * * @param {Object} obj */ textWrap: function (obj) { con('文本换行') let tr = (obj); for (let i = 0; i < obj.line; i++) { let txt = { x: obj.x, y: obj.y + (i * obj.height), color: obj.color, size: obj.size, align: obj.align, baseline: obj.baseline, text: tr[i], bold: obj.bold }; if (i == obj.line-1){ = txt.(0, .length - 3) +'......'; } (txt); } },

效果

有英文字母生成图片效果

注:在开发工具截取圆形会失效,这张是开发者工具生成的,第一张是真机生成的。

优化前后对比

优化前后对比

补充,字体加粗

基础库 1.9.90 开始支持设置字体样式 canva

canva = value

value 支持的属性有:

属性 说明 style 字体样式。仅支持 italic, oblique, normal weight 字体粗细。仅支持 normal, bold size 字体大小 family 字体族名。注意确认各平台所支持的字体 加粗如果是不需要兼容的话直接用这个属性就好了,如果需要兼容低版本库,就用重复渲染的方式,希望小程序后续支持多行文本换行吧~

优化待续...

责任编辑: 鲁达

1.内容基于多重复合算法人工智能语言模型创作,旨在以深度学习研究为目的传播信息知识,内容观点与本网站无关,反馈举报请
2.仅供读者参考,本网站未对该内容进行证实,对其原创性、真实性、完整性、及时性不作任何保证;
3.本站属于非营利性站点无毒无广告,请读者放心使用!

“微信小程序的text如何加入换行”边界阅读