欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 金融 > uni-app canvas文本自动换行

uni-app canvas文本自动换行

2025/5/5 18:17:01 来源:https://blog.csdn.net/qq_42618566/article/details/142566671  浏览:    关键词:uni-app canvas文本自动换行

封装

支持单行文本超出换行。多行文本顺位排版

	// 填充自动换行的文本function fillFeedText({ctx, text, x, y, maxWidth, lineHeight, color, size}) {// 文本配置ctx.setFontSize(size);ctx.setFillStyle(color);// 计算文本换行宽高,换行逻辑const words = text.split('');let line = '';const lines = [];for (let i = 0; i < words.length; i++) {const word = words[i];const testLine = line + word;const metrics = ctx.measureText(testLine);if (metrics.width > maxWidth && i > 0) {lines.push(line);line = word;} else {line = testLine;}};// 填充文本lines.push(line);let nextStart = 0;lines.forEach((line, index) => {ctx.fillText(line, x, y + ((index++) * lineHeight), maxWidth);nextStart = y + ((index++) * lineHeight)});}

使用

// 文本集合const text = ["时间:" + Tool.now(), state.address, "第三行的文本 试试试试试试试试试试试试试试试试试试试试试试试试试试试试试试"]; // 需要填充两个文本let nextStart = state.height * 0.88;  // 文本的起点text.forEach((line) => {nextStart = fillFeedText({ctx,text: line,x: padding,y: nextStart,maxWidth: state.width - padding - 10,lineHeight,color: '#FFFFFF',size: 10})});

在这里插入图片描述

效果

在这里插入图片描述

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词